赞
踩
在我们构建镜像的时候, 我们即可以手工的去构建对象, 也可以通过dockerfile来进行构建镜像, 而很多应用开发的过程中, 我们可能都需要通过dockerfile来制作我们的镜像, 就需要通过dockefile来帮我们构建镜像, 可以帮助我们省去很多人工的操作, 下面, 我们就来熟悉一下dockerfile的语法吧
Dockerfile 是记录了镜像是如何被构建出来的配置文件, 可以被 docker 直接执行以创建一个镜像.
示例:
- FROM ubuntu:14.04
- MAINTAINER YS.Zou <>
-
- ADD run /root/run
- ADD sources.list /etc/apt/sources.list
- ADD id_rsa.pub /tmp/pubkey
- ADD requirements /root/requirements
-
- RUN mkdir -p /root/.ssh && \
- cat /tmp/pubkey >> /root/.ssh/authorized_keys && \
- rm -rf /tmp/pubkey
- ...
-
- CMD ["bash", "/root/run"]
- FROM:基础镜像,当前新的镜像是基于哪个已经存在的镜像的
- MAINTAINER:镜像作者及其邮箱
- RUN:容器构建时需要执行的命令
- EXPOSE:暴露镜像的端口号
- WORKDIR:指定在创建容器后,终端默认登录进来的工作目录,一个落脚点
- ENV:用来在构建镜像过程中设置环境变量
- ADD:将宿主机目录下的文件拷贝进镜像且ADD命令会自动处理URL和解压tar压缩包
- COPY:跟ADD类似,拷贝文件和目录到镜像中
- VOLUME:容器数据卷,用于数据保存和持久化工作
- CMD:指定一个容器启动时要执行的命令,dockefile可以有多个cmd指令,但只有最后一个生效,cmd会被docker run之后的参数替换
- ENTRYPOINT:指定一个容器启动时要执行的命令,和CMD的目的一样,都是在指定容器启动程序及参数
- ONBUILD:当构建一个被继承的dockefile时运行命令,父镜像在被子继承后父镜像的onbuild被触发
docker从基础镜像中运行一个容器
执行一条命令并对容器做出修改
执行类似docker commit的操作提交一个新的镜像
docker在基于刚提交的镜像运行一个新的容器
执行dockerfile中的下一条指令知道所有指令都执行完成
准备一个文件, 名为: Dockerfile
- FROM nginx
- RUN echo '<h1>TSF Demo Application and Docker</h1>' >
- /usr/share/nginx/html/index.html
在Dockerfile所在的目录下, 执行命令用于构建镜像
docker build -t nginx:my
注意: docker build命令会根据 Dockerfile 文件及上下文构建新 Docker 镜 像。构建上下文是指 Dockerfile 所在的本地路径或一个URL(Git仓 库地址)。构建上下文环境会被递归处理,所以构建所指定的路 径还包括了子目录,而URL还包括了其中指定的子模块
Dockerfile 一般位于构建上下文的根目录下,也可以通过-f指定该 文件的位置:
构建时,还可以通过-t参数指定构建成镜像的仓库、标签。
使用Docker镜像创建容器
docker run -d -p 7788:80 nginx:my
使用浏览器访问宿主主机的7788端口
curl http://127.0.0.1:7788
相应的Dockerfile如下:
- FROM centos
- MAINTAINER stromling stromling@example.com
- RUN mkdir /root/training
- RUN mkdir /root/tools
- COPY jdk-8u144-linux-x64.tar.gz /root/tools
- RUN tar zxvf /root/tools/jdk-8u144-linux-x64.tar.gz -C /root/training/
- ENV JAVA_HOME /root/training/jdk1.8.0_144
- ENV PATH $JAVA_HOME/bin:$PATH
- ADD http://mirror.bit.edu.cn/apache/tomcat/tomcat-8/v8.5.35/bin/apache- tomcat-8.5.35.tar.gz /root/tools
- RUN tar zxvf /root/tools/apache-tomcat-8.5.35.tar.gz -C /root/training/ COPY MyDemoWeb.war /root/training/apache-tomcat-8.5.35/webapps
- ENTRYPOINT ["/root/training/apache-tomcat-8.5.35/bin/catalina.sh","run"]
编译生成容器:docker build -f MyDockerfile -t mywebapp .
启动容器:docker run -d -p 8080:8080 mywebapp
通过浏览器访问Web应用
登录到容器检查我们创建的镜像
docker exec -it 34217bdce6bc bash
注意 默认是centos8,如果想构建7则写centos:7
- FROM centos
- MAINTAINER hnf<hnf167@126.com>
-
- ENV MYPATH /usr/local
- WORKDIR $MYPATH
- RUN echo "nameserver 144.144.144.144" >> /etc/resolv.conf
- RUN yum -y install vim
- #RUN yum -y install net-tools
-
- EXPOSE 80
-
- CMD echo $MYPATH
- CMD echo "success--------------ok"
- CMD /bin/bash
然后运行dockerfile
docker build -f /mydocker/Dockerfile -t hnf/centos8 .
然后查看新镜像是否生成
期间遇到的问题是yum的时候报错,是因为宿主机没有开启ipv4转发
然后再次构建,就正常了
1 新建/mydockerfile/tomcat目录
2 将jdk和tocmat包放到该目录下面
3 创建dockerfile文件
- FROM centos:7
- MAINTAINER zzyy<zzyybs@126.com>
- #把宿主机当前上下文的c.txt拷贝到容器/usr/local/路径下
- COPY c.txt /usr/local/cincontainer.txt
- #把java与tomcat添加到容器中
- ADD jdk-8u144-linux-x64.tar.gz /usr/local/
- ADD apache-tomcat-7.0.63.tar.gz /usr/local/
- #安装vim编辑器
- RUN yum -y install vim
- #设置工作访问时候的WORKDIR路径,登录落脚点
- ENV MYPATH /usr/local
- WORKDIR $MYPATH
- #配置java与tomcat环境变量
- ENV JAVA_HOME /usr/local/jdk1.8.0_144
- ENV CLASSPATH $JAVA_HOME/lib/dt.jar:$JAVA_HOME/lib/tools.jar
- ENV CATALINA_HOME /usr/local/apache-tomcat-7.0.63
- ENV CATALINA_BASE /usr/local/apache-tomcat-7.0.63
- ENV PATH $PATH:$JAVA_HOME/bin:$CATALINA_HOME/lib:$CATALINA_HOME/bin
- #容器运行时监听的端口
- EXPOSE 8080
- #启动时运行tomcat
- # ENTRYPOINT ["/usr/local/apache-tomcat-9.0.8/bin/startup.sh" ]
- # CMD ["/usr/local/apache-tomcat-9.0.8/bin/catalina.sh","run"]
- CMD /usr/local/apache-tomcat-7.0.63/bin/startup.sh && tail -F /usr/local/apache-tomcat-7.0.63/bin/logs/catalina.out
4 构建镜像
docker build -t hnftomcat .
查看是否成功
- [root@bogon tomcat]# docker images
- REPOSITORY TAG IMAGE ID CREATED SIZE
- hnftomcat latest d3fd0d9890bb 14 minutes ago 755MB
5 启动容器
docker run -d -p 9080:8080 --name myt9 -v /mydockerfile/tomcat/test:/usr/local/apache-tomcat-7.0.63/webapps/test -v /mydockerfile/tomcat/tomcatlogs/:/usr/local/apache-tomcat-7.0.63/logs --privileged=true hnftomcat
查看是否启动成功
- [root@bogon tomcat]# docker ps
- CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
- d7e0201305d8 hnftomcat "/bin/sh -c '/usr/lo…" 11 minutes ago Up 11 minutes 0.0.0.0:9080->8080/tcp myt9
6 访问容器端口为9080
补充:在tomcat里面启动一个jar包
docker run -p 8080:8080 -d --rm --name tomcat_jdk -v /mydockerfile/tomcat/test:/usr/local/apache-tomcat-7.0.63/webapps/test -v /mydockerfile/tomcat/tomcatlogs/:/usr/local/apache-tomcat-7.0.63/logs --privileged=true hnftomcat java -jar /usr/local/apache-tomcat-7.0.63/webapps/test/demo-0.0.1-SNAPSHOT.jar
1 下载镜像
docker pull mysql:5.6
2 启动容器
docker run -p 3306:3306 --name mysql -v /mydockerfile/mysql/conf:/etc/mysql/conf.d -v /mydockerfile/mysql/logs:/logs -v /mydockerfile/mysql/data:/var/lib/mysql -e MYSQL_ROOT_PASSWORD=123456 -d mysql:5.6
查看是否启动成功
- [root@bogon ~]# docker ps
- CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
- 51fb6b3d85a9 mysql:5.6 "docker-entrypoint.s…" 5 minutes ago Up 5 minutes 0.0.0.0:12345->3306/tcp mysql
命令说明:
- -p 12345:3306:将主机的12345端口映射到docker容器的3306端口。
- --name mysql:运行服务名字
- -v /zzyyuse/mysql/conf:/etc/mysql/conf.d :将主机/zzyyuse/mysql录下的conf/my.cnf 挂载到容器的 /etc/mysql/conf.d
- -v /zzyyuse/mysql/logs:/logs:将主机/zzyyuse/mysql目录下的 logs 目录挂载到容器的 /logs。
- -v /zzyyuse/mysql/data:/var/lib/mysql :将主机/zzyyuse/mysql目录下的data目录挂载到容器的 /var/lib/mysql
- -e MYSQL_ROOT_PASSWORD=123456:初始化 root 用户的密码。
- -d mysql:5.6 : 后台程序运行mysql5.6
3 登录进去
先进去容器,然后登录mysql,也可以直接用
docker exec -it 51fb6b3d85a9 mysql -uroot -p123456 这个登录数据库
1 下载redis镜像
docker pull redis:3.2
2 启动容器
docker run -p 6379:6379 -v /mydockerfile/myredis/data:/data -v /mydockerfile/myredis/conf/redis.conf:/usr/local/etc/redis/redis.conf -d redis:3.2 redis-server /usr/local/etc/redis/redis.conf --appendonly yes
挂载目录,并开启持久化,并且启动服务,开放端口
3 登录测试
- [root@bogon data]# docker exec -it 147ebad83967 redis-cli
-
- 127.0.0.1:6379> set k1 v1
- OK
- 127.0.0.1:6379> get k2
- (nil)
- 127.0.0.1:6379> get k1
- "v1"
4 查看对应目录是否生成持久化文件
- [root@bogon data]# pwd
- /mydockerfile/myredis/data
- [root@bogon data]# ls
- appendonly.aof
1 下载ngixn镜像
docker pull nginx
2 启动一个容器
docker run -p 80:80 --rm -v /mydockerfile/nginx/conf:/etc/nginx/conf.d/ -v /mydockerfile/nginx/logs/:/var/log/nginx -v /mydockerfile/nginx/html/:/usr/share/nginx/html -d nginx
挂载 配置文件 ,日志,和网页静态目录
3 查看并访问
- [root@bogon nginx]# docker ps
- CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
- e324f5c21186 nginx "nginx -g 'daemon of…" 9 minutes ago Up 6 minutes 0.0.0.0:80->80/tcp xenodochial_kare
然后直接在宿主机上面修改静态文件,然后重新启动容器,即可生效,如果是修改的静态文件是不需要重启容器的
这里我直接修改的是html静态文件,去(/usr/share/nginx/html)目录下面,修改index.html,然后去浏览器访问
Dockerfile内容如下:
- from huningfei/tomcat8:v1
- MAINTAINER huningfei
- RUN rm -rf /usr/local/tomcat/webapps/*
- COPY java/target/ly-simple-tomcat-0.0.1-SNAPSHOT.war /usr/local/tomcat/webapps/ROOT.war
- CMD /usr/local/tomcat/bin/startup.sh && tail -F /usr/local/tomcat/logs/catalina.out
说明 在COPY的时候,这个路径是根据Dockerfile这个文件所处的相对路径写的。如果写绝对路径会报错
然后构建镜像, docker build -t war . -f Dockerfile 即可,构建完成之后,启动容器
docker run -it -p 8084:8080 war 把8080端口映射到8084上即可
Dockerfile内容如下:
- FROM java:8
- WORKDIR /root/.jenkins/jobs/docker-pipline
- COPY target/demo-0.0.1-SNAPSHOT.jar /demo-0.0.1-SNAPSHOT.jar
- CMD java -jar /demo-0.0.1-SNAPSHOT.jar
然后构建镜像, docker build -t jar . -f Dockerfile
首先畅捷一个空文件夹,并创建以下文件
server.js
package.json
Dockerfile
然后在server.js写入
- const Koa = require('koa');
- const app = new Koa();
-
- app.use(async ctx => {
- ctx.body = 'Hello docker';
- });
-
- app.listen(3000);
在package.json中写入
- {
- "name": "docker_demo",
- "version": "0.1.0",
- "private": true,
- "scripts": {
- "start": "node server.js"
- },
- "dependencies": {
- "koa": "^2.5.0"
- }
- }
- #制定node镜像的版本
- FROM node
- #声明作者
- MAINTAINER robin
- #移动当前目录下面的文件到app目录下
- ADD . /app/
- #进入到app目录下面,类似cd
- WORKDIR /app
- #安装依赖
- RUN npm install
- #对外暴露的端口
- EXPOSE 3000
- #程序启动脚本
- CMD ["npm", "start"]
- docker build -t docker_demo .
- 然后启动容器
- docker run -d -p 9000:3000 docker_demo
查看启动的容器
然后访问
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。