ESL需要四台服务器:分别是数据库Mysql服务器,Redis服务器,EMQ服务器,以及Spring Boot所在web服务器。Docker化部署就是将这四台服务器全部放在container中运行,通过--link的方式,实现web服务器对其他三台服务器的访问。
1. Mysql的docker化:操作参考上一篇博文,只需要将两个sql文件,根据实际情况进行修改,将镜像打包为zkong/database, 启动: docker run --name=elsdata -d -p 23306:3306 zkong/database
2. Redis:可通过redis的docker官方镜像进行安装。 docker pull redis
docker run --name=musing_ramanujan -d -p 26379:6379 redis
wget /downloads/2318/docker
unzip
docker load <
docker image ls
docker run -tid –name=emq20 -p 21883:1883 -p 28083:8083 -p 28883:8883 -p 28084:8084 -p 38083:18083
4. ESL web系统
新建Dockerfile,如: FROM java:8
EXPOSE 9999
VOLUME /tmp
ADD demo-0.0.1-SNAPSHOT.jar app.jar
RUN bash -c 'touch /app.jar'
ENTRYPOINT ["java","-jar","/app.jar"]
新建目录eslapp,并把Dockerfile和demo-0.0.1-SNAPSHOT.jar放入其中 mkdir eslapp
cd eslapp
docker build -t zkong/esl .
启动,使用--link方式,使得web服务器可以访问其他三个容器的服务,所以其他三个容器启动时都会带上--name指定container名称 docker run -p 29999:9999 --link emq20:emq20 --link musing_ramanujan:eslredis --link esldata:esldata zkong/esl
在web服务器的container中使用的其他container的别名进行访问,所以需要在application.yml中将各个服务的访问地址改为运行别名。(部署配置侵入到了代码中!需要寻找更优的解决方案!)