Contents
实战案例¶
使用 Supervisor 来管理进程¶
进程管理工具supervisor来管理容器中的多个进程。使用
Supervisor可以更好的控制、管理、重启我们希望运行的进程。
supervisor详细使用参考如下文章:
https://blog.csdn.net/zou79189747/article/details/80403016
首先创建一个 Dockerfile
root@hujianli:~# cat Dockerfile
FROM ubuntu:13.04
MAINTAINER examples@docker.com
RUN echo "deb http://archive.ubuntu.com/ubuntu precise main universe" > /etc/apt/sources.list
RUN apt-get update
RUN apt-get upgrade -y
RUN apt-get install -y --force-yes perl-base=5.14.2-6ubuntu2
RUN apt-get install -y apache2.2-common
RUN apt-get install -y openssh-server apache2 supervisor
RUN mkdir -p /var/run/sshd
RUN mkdir -p /var/log/supervisor
COPY supervisord.conf /etc/supervisor/conf.d/supervisord.conf
EXPOSE 22 80
CMD ["/usr/bin/supervisord"]
touch supervisord.conf
supervisord.conf配置文件如下
root@hujianli:~# cat supervisord.conf
[supervisord]
nodaemon=true
[program:sshd]
command=/usr/sbin/sshd -D
[program:apache2]
command=/bin/bash -c "source /etc/apache2/envvars && exec /usr/sbin/apache2 -DFOREGROUND"
使用方法
创建镜像。
$ sudo docker build -t test/supervisord .
启动 supervisor 容器。
root@hujianli:~# sudo docker run -p 22 -p 80 -t -i test/supervisord
2019-06-01 02:37:54,263 CRIT Supervisor running as root (no user in config file)
2019-06-01 02:37:54,264 WARN Included extra file "/etc/supervisor/conf.d/supervisord.conf" during parsing
2019-06-01 02:37:54,314 INFO RPC interface 'supervisor' initialized
2019-06-01 02:37:54,315 WARN cElementTree not installed, using slower XML parser for XML-RPC
2019-06-01 02:37:54,318 CRIT Server 'unix_http_server' running without any HTTP authentication checking
2019-06-01 02:37:54,320 INFO supervisord started with pid 1
2019-06-01 02:37:55,324 INFO spawned: 'sshd' with pid 7
2019-06-01 02:37:55,333 INFO spawned: 'apache2' with pid 8
2019-06-01 02:37:56,439 INFO success: sshd entered RUNNING state, process has stayed up for > than 1 seconds (startsecs)
2019-06-01 02:37:56,440 INFO success: apache2 entered RUNNING state, process has stayed up for > than 1 seconds (startse
cs)^C2019-06-01 02:43:00,856 WARN received SIGINT indicating exit request
2019-06-01 02:43:00,863 INFO waiting for sshd, apache2 to die
2019-06-01 02:43:00,887 INFO stopped: apache2 (exit status 0)
^C2019-06-01 02:43:01,791 INFO stopped: sshd (exit status 0)
2019-06-01 02:43:01,792 WARN received SIGINT indicating exit request
root@hujianli:~# sudo docker run -d -p 22 -p 80 -t -i test/supervisord
0b84da816a55a8ea90e11f5a9dc89632e3cf6023656591b7dd388a50d2043ea8
使用 docker run 来启动我们创建的容器。使用多个 -p 来映射多个端口,这样我们就能同时访问 ssh 和 apache 服务了。
可以使用这个方法创建一个只有 ssh 服务的基础镜像,之后创建镜像可以使用这个镜像为基础来创建
参考文献
创建tomcat/weblogic集群¶
安装 tomcat 镜像
准备好需要的 jdk、tomcat 等软件放到 home 目录下面,启动一个容器
root@hujianli:/home# docker run -it -v /home/:/opt/data --name mk_tomcat ubuntu:14.04 /bin/bash
这条命令挂载本地 home 目录到容器的 /opt/data 目录,容器内目录若不存在,则会自动创建。接下来就是 tomcat 的基本配置,jdk 环境变量设置好之后,将 tomcat 程序放到 /opt/apache-tomcat 下面
apt-get install -y openssh-server apache2 supervisor
编辑 /etc/supervisor/conf.d/supervisor.conf 文件,添加 tomcat 项
[supervisord]
nodaemon=true
[program:tomcat]
command=/opt/apache-tomcat/bin/startup.sh
[program:sshd]
command=/usr/sbin/sshd -D
提交修改后新增supervisor的镜像
docker commit ac6474aeb31d hu_tomcat
Dockerfile
[root@bogon tomcat]# cat Dockerfile
FROM hu_tomcat
EXPOSE 22 8080
ENV JAVA_HOME=/opt/data/jdk1.8/
ENV JAVA_BIN=/opt/data/jdk1.8/bin
ENV JRE_HOME=/opt/data/jdk1.8/jre
ENV PATH=$PATH:/opt/data/jdk1.8/bin:/opt/data/jdk1.8/jre/bin
ENV CLASSPATH=/opt/data/jdk1.8/jre/lib:/opt/data/jdk1.8/lib:/opt/data/jdk1.8/jre/lib/charsets.jar
CMD ["/usr/bin/supervisord"]
根据 Dockerfile 创建镜像。
docker build -t hu_tomcat .
安装 weblogic 镜像 步骤和 tomcat 基本一致,这里贴一下配置文件
supervisor.conf
[supervisord]
nodaemon=true
[program:weblogic]
command=/opt/Middleware/user_projects/domains/base_domain/bin/startWebLogic.sh
[program:sshd]
command=/usr/sbin/sshd -D
tomcat/weblogic 镜像的使用
存储的使用
在启动的时候,使用 -v 参数
-v, --volume=[] Bind mount a volume (e.g. from the host: -v /host:/container, from docker: -v /container)
将本地磁盘映射到容器内部,它在主机和容器之间是实时变化的,所以我们更新程序、上传代码只需要更新物理主机的目录就可以了
tomcat 和 weblogic 集群的实现 tomcat 只要开启多个容器即可
docker run -d -p 204:22 -p 7003:8080 -v /home/data:/opt/data --name tm1 tomcat /usr/bin/supervisord
docker run -d -p 205:22 -p 7004:8080 -v /home/data:/opt/data --name tm2 tomcat /usr/bin/supervisord
docker run -d -p 206:22 -p 7005:8080 -v /home/data:/opt/data --name tm3 tomcat /usr/bin/supervisord
这里说一下 weblogic 的配置,大家知道 weblogic 有一个域的概念。如果要使用常规的 administrator +node 的方式部署,就需要在 supervisord 中分别写出 administartor server 和 node server 的启动脚本,这样做的优点是:
可以使用 weblogic 的集群,同步等概念 部署一个集群应用程序,只需要安装一次应用到集群上即可 缺点是:
Docker 配置复杂了 没办法自动扩展集群的计算容量,如需添加节点,需要在 administrator 上先创建节点,然后再配置新的容器 supervisor 启动脚本,然后再启动容器 另外种方法是将所有的程序都安装在 adminiserver 上面,需要扩展的时候,启动多个节点即可,它的优点和缺点和上一种方法恰恰相反。(建议使用这种方式来部署开发和测试环境)
docker run -d -v -p 204:22 -p 7001:7001 -v /home/data:/opt/data --name node1 weblogic /usr/bin/supervisord
docker run -d -v -p 205:22 -p 7002:7001 -v /home/data:/opt/data --name node2 weblogic /usr/bin/supervisord
docker run -d -v -p 206:22 -p 7003:7001 -v /home/data:/opt/data --name node3 weblogic /usr/bin/supervisord
这样在前端使用 nginx 来做负载均衡就可以完成配置了