python fabric实现远程部署
pythonfabric实现远程部署
需求描述
在多人协同开发项目的过程中,几乎每天我们都要提交代码到git服务器,然后部署到测试服务器,每天都在敲那重复的几行命令,实在是无趣。怎么办?运维自动化!接下来就说说fabric这玩意儿,替我们完成一些重复繁杂的工作,相信你会跟我一样喜欢上它的!
本文项目背景
我们这次做的项目是用的django框架,每天我们提交代码到git服务器后,都要手动上传代码到测试服务器,然后执行一系列django框架的命令。每天都要浪费10多分钟的时间,做着重复的劳动,这些工作实在不是一个程序员该干的。。。
解决方案
借助Python的fabric模块可以将自动化部署或者多机操作的命令固化到一个脚本里,然后通过此脚本去执行。
安装fabric
注意:本机和目标服务器都要安装一下
sudoeasy_installfabric
或者用pip安装:
pipinstallfabric
编写脚本
local是在本机执行;run是在远程机执行
fromfabric.apiimporthosts,run,env,local,cd,get,lcd fromfabric.tasksimportexecute env.hosts=["fab@192.168.1.101:22","root@192.168.1.101:22"] env.passwords={"fab@192.168.1.101:22":"fab","root@192.168.1.101:22":"tofabor"} @hosts("ktv@192.168.1.101:22") defupdate(): """更新测试服务器代码""" withcd("/opt/project/project"):#进入测试服务器的项目目录 run("gitpulloriginmaster")#从git服务器的master分支下拉最新代码 run("/usr/local/bin/python2.7/opt/project/project/manage.pymakemigrations")#这是django框架检测数据库变动的命令 run("/usr/local/bin/python2.7/opt/project/project/manage.pymigrate")#这是django框架执行数据库变更的命令 @hosts("ktv@192.168.1.101:22") defrestart(): """重启服务""" execute('stop') execute('start') @hosts("root@192.168.1.101:22") defstart(): """开始服务""" withcd("/opt/project/project"): run("supervisorctlstartdev") @hosts("ktv@192.168.1.101:22") defstop(): """停止服务""" pids=run("ps-ef|grep'9001'|awk'{print$2}'") pid_list=pids.split('\r\n') foriinpid_list[:-2]: run('kill-9%s'%i)#杀掉运行服务进程
如上脚本保存为fabfile.py(也可保存为其他名称,只是运行命令不一样,下面会详述)
执行脚本
如果你的脚本名称为fabfile.py,那么可以在终端进入你fabfile.py的目录,敲入如下命令回车:
fabupdate
紧接着,你会看到终端提示你输入git账号及密码,待你输入成功后,将自动下拉git服务器的代码到测试服务器。
之后运行如下命令,重启服务:
fabrestart
如果你的文件名为其他名称,比如ab.py,那么执行fabupdate/restart是错误的,怎么云运行呢?
fab-fabupdate
fab-fabrestart
注:fabric相当强大,此文只是列举一小功能。如需深入学习,请参见官方文档http://docs.fabfile.org/en/1.6/
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持毛票票。