kafka开发技巧hadoop

mall-swarm微服务电商系统如何部署?用Jenkins自动

2020-11-09  本文已影响0人  程序员知识圈

之前对mall-swarm项目做了升级,注册中心和配置中心都改为使用Nacos,但是Jenkins的自动化部署文档一直都没更新。有些朋友参考原来的文档部署有点小问题,这次对mall-swarm的自动化部署文档做个升级,希望对大家有所帮助!

Jenkins的基本使用

使用该部署方案需要对Jenkins有所了解

部署准备

部署之前需要先安装mall-swarm需要的依赖服务,并打包好所有应用的Docker镜像。由于之前已经写过相关教程,这里只提示下关键的步骤。

执行脚本准备

Jenkins自动化部署是需要依赖Linux执行脚本的,我们先把需要执行的脚本准备好。

chmod +x ./mall-*
image.png

Jenkins中创建任务

接下来我们将通过在Jenkins中创建任务来实现自动化部署。由于我们的mall-swarm是个多模块的项目,部署上面和曾经的单模块项目还是有所区别的。

mall-admin

由于各个模块执行任务的创建都大同小异,下面将详细讲解mall-admin模块任务的创建,其他模块将简略讲解。

# 只install mall-common,mall-mbg两个模块
clean install -pl mall-common,mall-mbg -am

mall-gateway

mall-gateway和其他模块与mall-admin的创建任务方式基本一致,只需修改构建模块时的pom.xml文件位置和执行脚本位置即可。

其他模块

其他模块的执行任务创建,参考mall-admin和mall-gateway的创建即可。

任务创建完成

image.png

Docker网络问题

如果之前使用的是Docker Compose启动所有依赖服务,会默认创建一个网络,所有的依赖服务都会在此网络之中,不同网络内的服务无法互相访问。我这里创建的网络是deploy_default,所以需要指定sh脚本中服务运行的的网络,否则启动的应用服务会无法连接到依赖服务。

[root@local-linux ~]# docker network ls
NETWORK ID          NAME                     DRIVER              SCOPE
59b309a5c12f        bridge                   bridge              local
3a6f76a8920d        deploy_default           bridge              local
ef34fe69992b        host                     host                local
a65be030c632        none     

模块启动顺序问题

由于作为注册中心和配置中心的Nacos已经启动了,其他模块基本没有启动顺序的限制,但是最好还是按照下面的顺序启动。

推荐启动顺序:

运行完成效果展示

总结

我们通过在Jenkins中创建任务,完成了mall-swarm项目的自动化部署工作,这样当我们每次修改完代码后,只需点击启动任务,就可以实现一键打包部署,省去了频繁打包部署的麻烦。

上一篇下一篇

猜你喜欢

热点阅读