如何将整个运行环境打包成docker

场景

某个项目,用的tomcat+redis+zookeeper,然后这个项目已经产品化,很多地方都需要部署,并且有很多有细微差别的版本。

然后我这边是需要部署测试环境,一台机可能会部署好几个。

按照传统部署方式,要好几个tomcat,好几个redis,好几个zookeeper。理论上部署确实没问题,但是数量一上来,发现端口的配置非常麻烦:tomcat端口到处改,redis端口到处改,zookeeper也是。部署的时候都不知道下一个服务要用什么端口了。。哪个系统对应哪个端口也记不住,非常混乱。

思路

鉴于以上情况,我考虑将整个环境打包成一个docker镜像(数据库除外),然后只要拿着这个镜像,需要部署的时候直接拿着这个镜像部署就行,一个服务指定一个端口,完事,好管理的多。

实现

首先需要准备tomcat,redis,zookeeper的安装包(因为docker的基础环境没办法用yum,或者很麻烦),然后在真实环境中将这些组件解压,安装好(也就是拿到一个能够运行的文件夹)

然后就可以写Dockerfile了。

bash 复制代码
# 使用jdk8作为基础镜像
FROM eclipse/centos_jdk8:latest

# 复制tomcat
COPY tomcat /usr/local/tomcat
COPY redis-5.0.6 /root/redis
COPY apache-zookeeper-3.9.2-bin /root/zookeeper
COPY start.sh /root/

# 暴露Tomcat的端口
EXPOSE 8080

# 启动Tomcat
USER root
RUN chmod a+x /usr/local/tomcat/bin/catalina.sh
RUN chmod a+x /usr/local/tomcat/bin/startup.sh
RUN chmod a+x /root/redis/src/redis-server
RUN chmod a+x /root/zookeeper/bin/zkServer.sh
RUN chmod a+x /root/start.sh
# 处理tomcat日志乱码问题
ENV TZ 'Asia/Shanghai'
ENV LANG en_US.UTF-8
ENV LANGUAGE en_US:en
ENV LC_ALL en_US.UTF-8

#CMD ["/root/redis/src/redis-server","/root/redis/redis.conf"]
#CMD ["/root/zookeeper/bin/zkServer.sh","start"]
#cmd命令只能有一个,后面的会覆盖前面的
#CMD ["/usr/local/tomcat/bin/catalina.sh", "run"]
CMD ["/root/start.sh"]

此处注意,如果docker还没有登录,要先docker login一下,不然拉不到基础镜像

bash 复制代码
docker login -u username  -p password
bash 复制代码
#然后使用
docker build -t ddhmw .
#进行打包,ddhmw是你要打出来的包的名称,注意最后面还有个点,代表是当前目录,不能省略
#这个命令会自动识别当前目录下的DockerFile
bash 复制代码
#然后启动容器,1300是宿主机的端口,8080是docker容器里面暴露的端口
docker run -d -p 1300:8080 --privileged --name ddhmw ddhmw
#完成
#可以这样查看日志
docker logs -f --tail 500 ddhmw
相关推荐
xiaoliuliu123456 分钟前
Xftp-7.0.0109p文件传输安装步骤详解(附FTP/SFTP连接与文件传输教程)
运维·服务器
小鸡食米33 分钟前
LVS(Linux Virtual Server)
运维·服务器·网络
罗技1232 小时前
Docker启动Coco AI Server后,如何访问内置Easysearch?
人工智能·docker·容器
DeeplyMind2 小时前
第14章 挂载宿主机目录(Bind Mount)(最常用,重要)
运维·docker·云原生·容器·eureka
DeeplyMind2 小时前
第17章 Docker网络实战与高级管理
网络·docker·容器
FJW0208143 小时前
《Nginx 进阶实战:配置详解、站点发布与常用功能大全》(2)
运维·nginx
DeeplyMind3 小时前
第19章 Docker Compose进阶
运维·docker·容器
srhtrnbdfg4 小时前
Discuz!NT负载均衡方案
运维·负载均衡
小锋学长生活大爆炸4 小时前
【教程】PicoClaw:在嵌入式设备上部署OpenClaw
docker·github·教程·工具·openclaw·picoclaw
Hello.Reader5 小时前
从 0 到 1 理解硬盘数据恢复工具原理与工程实现
linux·运维·服务器·网络·数据库