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

3. EMQ: 下载emqtt的docker镜像,http://www.emqtt.com/downloads

ESL系统的Docker化部署-LMLPHP

wget http://www.emqtt.com/downloads/2318/docker
unzip <下载到的zip文件>
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中将各个服务的访问地址改为运行别名。(部署配置侵入到了代码中!需要寻找更优的解决方案!)

04-30 18:16