+
96
-

回答

像BAT这样的大公司,都是有一套自动化流水线的,出于公司安全红线要求,我无法讲的太细,但是我可以提供些思路给题主参考。


工具

工欲善其事,必先利其器,我们先来说需要哪些工具

1 git,用于保存最新要上线的代码

2 maven,用于打包项目

3 Jenkins,用于触发任务

4 sh脚本或者Python脚本,执行Jenkins任务的脚本

流程

接下来是实际的流程。

首先,由开发人员把要上线的代码上传到指定代码库。

然后,开发人员触发Jenkins任务。

这个Jenkins的任务是自动化部署的核心,包含以下步骤

1 开始对代码进行打包

2 把包放到服务器指定文件夹下

插一句,为了安全起见,我们建议的是进行热部署,何为热部署?

热部署需要Nginx+多台Tomcat的配合。

假设目前只有一台Tomcat连接到了Nginx上,那么可以把要更新的代码部署在另一台Tomcat上,然后启动新的Tomcat,确认该服务启动成功,各能力已经启动后,再去修改Nginx的conf文件,把原本给旧Tomcat的请求切到新Tomcat上,这样就实现了热部署。如果不使用这种办法,而是直接在旧的Tomcat上部署新的war包的话,重启Tomcat的过程,就会有几秒停服,这对用户来说是不可接受的。既然说到这里,再介绍两个热部署用到的Nginx的命令。在修改Nginx的conf文件后,要在Nginx的根目录下执行sbin/nginx -t 来检查当前conf文件配置是否正确,如果是“successful”的,就可以执行sbin/nginx -s reload来进行实现把新的流量切到新的机器上,即使新的conf文件生效。

好的,关于热部署的部分说完了,我们再说回来。

3 将旧的服务器根目录下的war包用cp命令放到一个专门备份的文件夹下

4 将新的war包同样用cp命令放到即将启动的Tomcat根目录下的webapps文件夹下,然后解压

5 执行sh bin/

start.sh

启动新的Tomcat
6 检查该Tomcat是否启动成功,包括进程存在,tail -f

catalina.out

日志一直在打,api能够调通
7 修改Nginx的conf文件

8 检查Nginx配置文件是否successful

9 更新Nginx配置,即sbin/nginx -s reload

10 继续观察新Tomcat是否运行正常,如果不正常则立刻切回原Tomcat,本次自动更新失败

11 如果正常,则停止旧的Tomcat。

以上,自动化部署完成。

网友回复

我知道答案,我要回答