docker 实战---部署tomcat\weblogic集群 (二)

安装tomcat镜像

准备好须要的jdk tomcat等软件放到home文件夹以下
启动一个虚拟机

docker run -t -i -v /home:/opt/data  --name mk_tomcat ubuntu /bin/bash
这条命令挂载本地home文件夹到虚拟机的/opt/data文件夹,虚拟机内文件夹若不存在,则会自己主动创建
接下来就是tomcat的基本配置,jdk设置环境变量好之后,将tomcat程序放到/opt/apache-tomcat以下
编辑/etc/supervisor/conf.d/supervisor.conf文件。加入tomcat项
docker 实战---部署tomcat\weblogic集群 (二)

退出!
使用docker commit  ac6474aeb31d  tomcat
新建tomcat目录。新建Dockerfile
docker 实战---部署tomcat\weblogic集群 (二)
docker build tomcat tomcat 
docker 实战---部署tomcat\weblogic集群 (二)

watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvc21hbGxmaXNoMTk4Mw==/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/SouthEast" alt="">


安装weblogic镜像

步骤和tomcat基本一致。这里贴一下配置文件
supervisor.conf
docker 实战---部署tomcat\weblogic集群 (二)

watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvc21hbGxmaXNoMTk4Mw==/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/SouthEast" alt="">

dockerfile
docker 实战---部署tomcat\weblogic集群 (二)

tomcat/weblogic 镜像的使用


1、存储的使用

在启用docker run 的时候,使用 -v參数

-v, --volume=[]            Bind mount a volume (e.g. from the host: -v /host:/container, from docker: -v /container)
将本地磁盘映射到虚拟机内部,它在主机和虚拟机容器之间是实时变化的,所以我们更新程序、上传代码仅仅须要更新物理主机的文件夹就能够了,数据存储的具体使用參见我的还有一篇博文http://blog.csdn.net/smallfish1983/article/details/38637839

2、tomcat和weblogic集群的实现

tomcat仅仅要开启多个容器就可以
docker run -d -v -p 204:22 -p 7003:8080 -v /home/data:/opt/data --name tm1 tomcat /usr/bin/supervisord
docker run -d -v -p 205:22 -p 7004:8080 -v /home/data:/opt/data --name tm2 tomcat /usr/bin/supervisord
docker run -d -v -p 206:22 -p 7005:8080 -v /home/data:/opt/data --name tm3 tomcat /usr/bin/supervisord

docker 实战---部署tomcat\weblogic集群 (二)
这里说一下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

docker 实战---部署tomcat\weblogic集群 (二)

watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvc21hbGxmaXNoMTk4Mw==/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/SouthEast" alt="">

这样在前端使用nginx 来做负载均衡完毕配置了

上一篇:C#之生成树形菜单数据


下一篇:Docker实战部署应用——Redis