使用Dockerfile创建一个tomcat镜像,并运行一个简单war包
docker已经看了有一段时间了,对镜像和容器也有了一个大致了解,参考书上的例子制作一个tomcat镜像,并简单运行一个HelloWorld.war
1.首先下载linux环境的tomcat和jdk,并分别解压至helloworld目录
2.新建Dockerfile文件
touch Dockerfile
Dockerfile文件的内容如下:
1 FROM ccc7a11d65b1 (这串数字是我已经创建好一个ubuntu镜像的镜像id,在这里作为tomcat的基础镜像
2 MAINTAINER hmk
3 ENV REFRESHED_AT 2018-03-10 (这个环境变量用来表名该镜像模板的最后更新时间)
4
5 #切换镜像目录,进入/usr目录
6 WORKDIR /usr
7 #在/usr/下创建jdk目录,用来存放jdk文件
8 RUN mkdir jdk
9 #在/usr/下创建tomcat目录,用来存放tomcat
10 RUN mkdir tomcat
11
12 #将宿主机的jdk目录下的文件拷至镜像的/usr/jdk目录下
13 ADD jdk1.8.0_131 /usr/jdk/
14 #将宿主机的tomcat目录下的文件拷至镜像的/usr/tomcat目录下
15 ADD apache-tomcat-7.0.81 /usr/tomcat/
16
17 #设置环境变量
18 ENV JAVA_HOME=/usr/jdk
19 ENV JRE_HOME=$JAVA_HOME/jre
20 ENV CLASSPATH=.:$JAVA_HOME/lib/dt.jar:$JAVA_HOME/lib/tools.jar:$JRE_HOME/lib:$CLASSPATH
21 ENV PATH=/sbin:$JAVA_HOME/bin:$PATH
22
23 #公开端口
24 EXPOSE 8080
25 #设置启动命令
26 ENTRYPOINT ["/usr/tomcat/bin/catalina.sh","run"]
3.构建镜像
[root@localhost helloword]# docker build -t jamtur01/tomcat .
成功的话,会有镜像id显示
4.使用docker images查看创建好的镜像
5.通过创建好的镜像,启动一个容器
[root@localhost helloword]# docker run -d -p 8080:8080 --name hmk_tomcat jamtur01/tomcat:latest
访问一下
6.进入容器,看下之前在Dockerfile中写好命令要创建的tomcat和jdk目录
[root@localhost helloword]# docker exec -it 480f45dc4c00284690b378c063daf7371719c1cddf0efc2032223bfb318b2076 /bin/bash
<============分割线===============>
下面部署一个HelloWorld.war包
1.在helloworld目录下新建一个webapps目录,把war包放进去
2.使用-v参数将war包挂载至容器内的 tomcat/webapps目录
[root@localhost helloword]# docker run -d -p 8080:8080 -v /HMK/helloword/webapps/HelloWorld.war:/usr/tomcat/webapps/HelloWorld.war --name hmk_tomcat jamtur01/tomcat
注意:-v /HMK/helloword/webapps/HelloWorld.war:/usr/tomcat/webapps/HelloWorld.war,这里是挂载的单个文件
3.说明下我尝试的几种挂载方法
第一次是将宿主机webapps目录挂载至容器的webapps
[root@localhost helloword]# docker run -d -p 8080:8080 -v /HMK/helloword/webapps:/usr/tomcat/webapps --name hmk_tomcat jamtur01/tomcat
但是后来发现,启动容器后,容器内的webapps目录和宿主机一样了,也就是容器中tomcat/webapps原本的内容被置换为宿主机的webapps内容了(这和我预期的不符)
通过单个文件挂载的话,则只是把这个war包丢进容器中,并没有影响容器中原本的内容(虽然我知道一般不建议挂载单个文件,但是如何通过挂载目录来读取容器外的程序包、配置文件等的方法还没有找到。。。)
另外挂载单个文件时注意宿主机的路径是绝对路径,容器中也是绝对路径+文件名(也就是说虽然容器中没有这个war文件,但是我们要假设有,然后映射到宿主机的文件,然后容器就能运行宿主机的war文件了)
Docker命令详解(build篇)
命令格式:docker build [OPTIONS] <PATH | URL | ->
Usage: Build an image from a Dockerfile.
中文意思即:使用build命令,在Dockerfile的基础上构建一个镜像。
- 常用选项说明
--build-arg
,设置构建时的变量--no-cache
,默认false。设置该选项,将不使用Build Cache构建镜像--pull
,默认false。设置该选项,总是尝试pull镜像的最新版本--compress
,默认false。设置该选项,将使用gzip压缩构建的上下文--disable-content-trust
,默认true。设置该选项,将对镜像进行验证--file
, -f,Dockerfile的完整路径,默认值为‘PATH/Dockerfile’--isolation
,默认--isolation="default",即Linux命名空间;其他还有process或hyperv--label
,为生成的镜像设置metadata--squash
,默认false。设置该选项,将新构建出的多个层压缩为一个新层,但是将无法在多个镜像之间共享新层;设置该选项,实际上是创建了新image,同时保留原有image。--tag, -t
,镜像的名字及tag,通常name:tag或者name格式;可以在一次构建中为一个镜像设置多个tag--network
,默认default。设置该选项,Set the networking mode for the RUN instructions during build--quiet, -q
,默认false。设置该选项,Suppress the build output and print image ID on success--force-rm
,默认false。设置该选项,总是删除掉中间环节的容器--rm
,默认--rm=true,即整个构建过程成功后删除中间环节的容器
- PATH | URL | -说明:
给出命令执行的上下文。
上下文可以是构建执行所在的本地路径,也可以是远程URL,如Git库、tarball或文本文件等。
如果是Git库,如https://github.com/docker/rootfs.git#container:docker,则隐含先执行git clone --depth 1 --recursive,到本地临时目录;然后再将该临时目录发送给构建进程。
构建镜像的进程中,可以通过ADD命令将上下文中的任何文件(注意文件必须在上下文中)加入到镜像中。
-表示通过STDIN给出Dockerfile或上下文。
示例
docker build -t bjc/demo:latest --rm .
解析:-t bjc/demo:latest
,为构建的镜像标记名称,即镜像名为:bjc/demo,打标为latest;--rm
,整个构建过程成功后删除中间环节的容器;.
,单独的点,意思为根据当前目录下的Dockerfile文件生成镜像