Docker之自定义 Tomcat构建JDK和haproxy镜像

本文一共28个步骤,看完会花点时间,有兴趣的可以看下去,一起学习!

一.构建 JDK 镜像

1.自定义centos基础镜像

# docker pull centos
# mkdir /opt/dockerfile/{web/{nginx,tomcat,jdk,apache},system/{centos,ubuntu,redhat}} -pv
# cd /opt/dockerfile/system/centos/

2.构建dockerfile

vim Dockerfile
# Centos Base Image
#
FROM centos:latest
LABEL maintainer="alang"
RUN yum install -y vim wget tree lrzsz gcc gcc-c++ automake pcre pcre-devel zlib zlib-devel openssl openssl-devel iproute net-tools iotop
RUN groupadd www -g 2020 && useradd www -u 2020 -g www #添加系统账户

在这里插入图片描述
3.#通过脚本构建镜像

vim build-command.sh #通过脚本构建镜像
#!/bin/bash
docker build -t centos-base:v1 .

4.通过脚本还行镜像构建

bash build-command.sh
也可以直接执行docker build -t centos-base:v1 .

5.自定义基础镜像制作完成:在这里插入图片描述
6.执行构建 JDK 镜像:

#cd /opt/dockerfile/web/jdk/
#vim Dockerfile
FROM  centos-base:v1


LABEL maintainer="jack 2973707860@qq.com"

ADD jdk-8u251-linux-x64.tar.gz  /usr/local/src/
RUN ln -sv /usr/local/src/jdk1.8.0_251 /usr/local/jdk 
ADD profile /etc/profile
RUN  rm -rf /etc/localtime && ln -snf /usr/share/zoneinfo/Asia/Shanghai /etc/localtime


ENV JAVA_HOME /usr/local/jdk
ENV JRE_HOME $JAVA_HOME/jre
ENV CLASSPATH $JAVA_HOME/lib/:$JRE_HOME/lib/
ENV PATH $PATH:$JAVA_HOME/bin

将上一个容器的profile文件拷贝出来 再进行修改
我这里直接将另外一台主机上的拷贝过来
scp profile 10.0.0.77:/opt/dockerfile/web/jdk/
在这里插入图片描述
在最后面增加三行变量

export JAVA_HOME=/usr/local/jdk
export CLASSPATH=.:$JAVA_HOME/jre/lib/rt.jar:$JAVA_HOME/lib/dt.jar:$JAVA_HOME/lib/tools.jar
export PATH=$PATH:$JAVA_HOME/bin

在这里插入图片描述
2.上传 JDK 压缩包和 profile 文件

提前下载准备好的jdk脚本,直接上传

3.通过脚本构建

   # cat build-commint.sh
    #!/bin/bash
    docker build -t jdk-8u251 .
    bash build-command.sh  #执行脚本构建 

在这里插入图片描述
4.验证构建完成;验证镜像 JDK 环境:jdk-8u251
在这里插入图片描述
5.小结:
在这里插入图片描述
在docker里面若是切换普通用户,则没有jdk;
所以profile是给普通用户使用的
在这里插入图片描述

二从 JDK 镜像构建 tomcat 8 Base 镜像

1.#切换到tomcat选项

[root@dokcer-mt1 tomcat]#pwd
/opt/dockerfile/web/tomcat

#编辑Dockerfile文件
[root@dokcer-mt1 tomcat]#cat Dockerfile

FROM  jdk-8u251

LABEL maintainer="martin is god"

ADD apache-tomcat-8.5.55.tar.gz /apps/
RUN ln -sv /apps/apache-tomcat-8.5.55 /apps/tomcat

2.上传 tomcat 压缩包后通过脚本构建 tomcat 基础镜像

vim build-command.sh
#!/bin/bash
docker build -t tomcat-base:v8.5.55 .

3.执行构建,bash build-command.sh
在这里插入图片描述
4.查看构建
在这里插入图片描述
5.验证tomcat
在这里插入图片描述
6.浏览器访问

在容器里执行 /apps/tomcat/bin/catalina.sh run
浏览器访问:http://10.0.0.77:8080/
在这里插入图片描述
7.构建业务镜像

测试一个镜像中有多个服务
创建app文件夹
在tomcat下建立两个文件夹mkdir tomcat-app{1…2}
在这里插入图片描述
8.准备自定义 myapp 页面

mkdir myapp
[root@dokcer-mt1 myapp]#cat index.jsp 
<h1>tomcat app1</h1>
[root@dokcer-mt1 tomcat-app1]#tar czvf myapp.tar.gz myapp/ #执行创建解压包
myapp/
myapp/index.jsp

9.准备Dockerfile

FROM tomcat-base:v8.5.55

LABEL maintainer="martin is god"


#ADD server.xml /apps/tomcat/conf/server.xml
RUN mkdir /data/tomcat/webapps -p
ADD myapp.tar.gz /data/tomcat/webapps

EXPOSE 8080 8443 8009 #暴露端口


CMD ["/apps/tomcat/bin/catalina.sh","run"]

10.准备server.xml文件 将tomcat的配置文件修改后放到宿主机上
在这里插入图片描述
复制到宿主机:

docker cp 06fca146e4fa:/apps/tomcat/conf/server.xml .
  1. 修改server.xml
    在这里插入图片描述
    改完后 加入Dockerfile
    在这里插入图片描述
FROM tomcat-base:v8.5.55

LABEL maintainer="martin is god"


#ADD server.xml /apps/tomcat/conf/server.xml
RUN mkdir /data/tomcat/webapps -p
ADD myapp.tar.gz /data/tomcat/webapps

EXPOSE 8080 8443 8009 #暴露端口


CMD ["/apps/tomcat/bin/catalina.sh","run"] 

12.构建脚本执行

[root@dokcer-mt1 tomcat-app1]#cat build-command.sh 
#!/bin/bash

docker build -t tomcat-app1:v1 .
bash build-command.sh#执行构建

在这里插入图片描述
13. 启动测试

从镜像启动容器测试, 执行docker run -it --rm -p 8080:8080 tomcat-app1:v1
在这里插入图片描述
在这里插入图片描述
14.访问测试:
10.0.0.77:8080/myapp/
在这里插入图片描述
15.构建业务镜像 2

将tomcat-app1的文件 拷贝到tomcat-app2
[root@dokcer-mt1 tomcat]#cp -r tomcat-app1/* /tomcat-app2/  #递归拷贝

在这里插入图片描述
16.修改build-command.sh
在这里插入图片描述
17.修改vim myapp/index.jsp
在这里插入图片描述
18.重新生成tar包(会替换原来的tar包)
在这里插入图片描述
19.然后重新构建;bash build-command.sh
在这里插入图片描述
docker run -it --rm -p 8080:8080 tomcat-app2:v1
20.访问浏览器
在这里插入图片描述
21.总结
tomcat不能停止(关机重启)容器会被回收
dockerfile只能执行一个命令
但是脚本可以;

22.构建 haproxy 镜像

[root@dokcer-mt1 web]#mkdir haproxy
[root@dokcer-mt1 web]#cd haproxy/
[root@dokcer-mt1 haproxy]#pwd
/opt/dockerfile/web/haproxy

23.准备dockerfile

FROM centos-base:v1

LABEL maintainer="martin is god"

RUN yum install -y vim iotop bc gcc make  gcc-c++ glibc glibc-devel pcre pcre-devel openssl openssl-devel systemd-devel net-tools vim iotop bc zip unzip zlib-devel lrzsz tree lsof tcpdump wget  psmisc traceroute bash-completion  readline-devel  telnet libevent libevent-devel

ADD lua-5.4.2.tar.gz /usr/local/src
RUN cd /usr/local/src/lua-5.4.2 && make linux test

ADD haproxy-2.2.11.tar.gz  /usr/local/src
RUN cd /usr/local/src/haproxy-2.2.11 && make  ARCH=x86_64 TARGET=linux-glibc  USE_PCRE=1 USE_OPENSSL=1 USE_ZLIB=1  USE_SYSTEMD=1  USE_CPU_AFFINITY=1 USE_LUA=1 LUA_INC=/usr/local/src/lua-5.4.2/src/  LUA_LIB=/usr/local/src/lua-5.4.2/src/ PREFIX=/apps/haproxy && make install PREFIX=/apps/haproxy && cp haproxy  /usr/sbin/
RUN mkdir /var/lib/haproxy

ADD run_haproxy.sh /usr/sbin
ADD haproxy.cfg /etc/haproxy/haproxy.cfg

EXPOSE 80 9999

CMD ["/usr/sbin/run_haproxy.sh"]

24.准备 haproxy 配置文件 # cat haproxy.cfg

global
chroot /apps/haproxy
stats socket /var/lib/haproxy/haproxy.sock mode 600 level admin
uid 99
gid 99
daemon
nbproc 1
pidfile /var/lib/haproxy/haproxy.pid
log 127.0.0.1 local3 info

defaults
option http-keep-alive
option  forwardfor
mode http
timeout connect 300000ms
timeout client  300000ms
timeout server  300000ms

listen stats
 mode http
 bind 0.0.0.0:9999
 stats enable
 log global
 stats uri     /haproxy-status
 stats auth    haadmin:123456

listen  web_port
 bind 0.0.0.0:80
 mode http
 log global
 balance roundrobin
 server web1  10.0.0.77:8888  check inter 3000 fall 2 rise 5
 server web2  10.0.0.77:8888  check inter 3000 fall 2 rise 5

25.准备镜像构建脚本

vim build-command.sh
#!/bin/bash

docker build -t haproxy:v2.2.11 .

26.从镜像启动容器:
docker run -it -d -p 80:80 -p 9999:9999 haproxy:2.2.11
出现报错
在这里插入图片描述
将run_haproxy.sh改成755权限后。要再次构建docker build -t haproxy:v2.2.11 .
在这里插入图片描述
再次执行;在这里插入图片描述
27. web 访问验证: 10.0.0.77/myapp/
在这里插入图片描述
28.访问 haproxy 控制端
访问10.0.0.77:9999/haproxy-status
在这里插入图片描述
在这里插入图片描述
操作完成
在这里插入图片描述

评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值