使用Dockerfile创建一个tomcat镜像,并运行一个简单war包

使用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文件生成镜像

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值