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 redisdocker run --name=musing_ramanujan -d -p 26379:6379 redis
3. EMQ: 下载emqtt的docker镜像,
wget http://www.emqtt.com/downloads/2318/dockerunzip <下载到的zip文件> docker load < <解压后的文件> docker image lsdocker run -tid –name=emq20 -p 21883:1883 -p 28083:8083 -p 28883:8883 -p 28084:8084 -p 38083:18083 <镜像名称>镜像名称> 解压后的文件> 下载到的zip文件>
4. ESL web系统
新建Dockerfile,如:
FROM java:8EXPOSE 9999VOLUME /tmpADD demo-0.0.1-SNAPSHOT.jar app.jarRUN bash -c 'touch /app.jar'ENTRYPOINT ["java","-jar","/app.jar"]
新建目录eslapp,并把Dockerfile和demo-0.0.1-SNAPSHOT.jar放入其中
mkdir eslappcd eslappdocker 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中将各个服务的访问地址改为运行别名。(部署配置侵入到了代码中!需要寻找更优的解决方案!)