需求:

写一个自动化部署脚本,能根据git push动作自动更新发布代码(补丁文件(或更新文件,以下简称补丁))

解决方案:

通过git webhooks、python脚本、Linux Shell脚本完成,所有动作均自动完成,人工部分仅限于发布补丁文件之前

  • git webhooks实现触发执行脚本

  • python脚本用于接收git webhooks的post数据并根据这些数据判断是否执行shell脚本

  • Linux Shell脚本用于实现部署、备份、回滚等操作

具体步骤(方案实现):

实现原理:

用 户在编写补丁后,除了将补丁文件push到git外,将补丁文件的路径以及相关操作写到指定文件(如名称为update.conf,以下简称配置文件) 中,自动化部署脚本(以下简称脚本)会根据配置文件,在生产服务器执行相关操作,并将这些文件赋予正确的权限,如果需要缓存,则清除缓存(关于是否需要根 据需要清除缓存,可以从上面提到的指定文件中获取),再根据需要重启相关服务

关于指定文件格式的约定。可以按照以下格式:

1
2
3
4
5
6
7
8
9
10
file     path /to/filename1       add
file     path /to/filename2       remove
file     path /to/filename3       update
file     path /to/filename4       add
config  cleancache              enable
config  cleancache             disable
config  restartservice          enable
config  restartservice         disable
target  serverid             
...     ...                    ...
  • file表示补丁文件,path/to/filename1表示文件路径,add、remove以及update表示文件执行的动作

  • config表示配置,分清除缓存和重启服务,由enable和disable决定是否执行

  • target表示生产服务器的IP或主机名,每一个target均能由更新服务器ssh连接

脚本完成的工作和步骤(有些是原理及相关解释):

  1. git服务端会根据用户的git push动作,触发git服务端的webhooks动作,git服务器将json数据post到更新服务器上

  2. 更新服务器上能捕获到git服务端发送过来的json数据,从中获取repository的url以及branch等信息,并且根据json中的信息,判断是否需要执行git fetch以获取这些补丁文件,以及是否需要执行部署操作

  3. 当执行部署操作时,更新服务器将生产服务器上的代码备份到备份服务器或生产服务器上的其他备份位置,根据上文的配置文件决定是否增删改文件,是否清除缓存和是否重启服务

  4. 更新服务器能ssh到生产服务器,文件操作、清除缓存和重启服务的命令全部通过ssh完成

  5. 检测相关API,判断是否更新成功,如果更新成功,则记录更新日志;如果更新失败,则回滚文件,再根据需要决定是否清除缓存和是否重启服务

tag:Git WebHooks,自动化部署,Shell脚本,python BaseHTTPServer,python接收webhooks

--end--