«

python fabric实现远程部署

时间:2024-3-2 13:07     作者:韩俊     分类: Python


python fabric实现远程部署

需求描述

在多人协同开发项目的过程中,几乎每天我们都要提交代码到git服务器,然后部署到测试服务器,每天都在敲那重复的几行命令,实在是无趣。怎么办?运维自动化!接下来就说说fabric这玩意儿,替我们完成一些重复繁杂的工作,相信你会跟我一样喜欢上它的!

本文项目背景

我们这次做的项目是用的django框架,每天我们提交代码到git服务器后,都要手动上传代码到测试服务器,然后执行一系列django框架的命令。每天都要浪费10多分钟的时间,做着重复的劳动,这些工作实在不是一个程序员该干的。。。

解决方案

借助Python的fabric模块可以将自动化部署或者多机操作的命令固化到一个脚本里,然后通过此脚本去执行。

安装fabric

注意:本机和目标服务器都要安装一下
sudo easy_install fabric

或者用pip安装:

pip install fabric

编写脚本

local 是在本机执行;run 是在远程机执行

from fabric.api import hosts, run, env, local, cd, get, lcd
from fabric.tasks import execute

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")
def update():
  """更新测试服务器代码"""
  with cd("/opt/project/project"): # 进入测试服务器的项目目录
    run("git pull origin master") # 从git服务器的master分支下拉最新代码
    run("/usr/local/bin/python2.7 /opt/project/project/manage.py makemigrations") # 这是django框架检测数据库变动的命令
    run("/usr/local/bin/python2.7 /opt/project/project/manage.py migrate") # 这是django框架执行数据库变更的命令

@hosts("ktv@192.168.1.101:22")
def restart():
  """重启服务"""
  execute('stop')
  execute('start')

@hosts("root@192.168.1.101:22")
def start():
  """开始服务"""
  with cd("/opt/project/project"):
    run("supervisorctl start dev")

@hosts("ktv@192.168.1.101:22")
def stop():
  """停止服务"""
  pids = run("ps -ef |grep '9001'| awk '{print $2}'")
  pid_list = pids.split('rn')
  for i in pid_list[:-2]:
    run('kill -9 %s' % i) # 杀掉运行服务进程

如上脚本保存为fabfile.py (也可保存为其他名称,只是运行命令不一样,下面会详述)

执行脚本

如果你的脚本名称为fabfile.py,那么可以在终端进入你fabfile.py的目录,敲入如下命令回车:

fab update

紧接着,你会看到终端提示你输入git账号及密码,待你输入成功后,将自动下拉git服务器的代码到测试服务器。
之后运行如下命令,重启服务:

fab restart

如果你的文件名为其他名称,比如ab.py, 那么执行 fab update /restart是错误的,怎么云运行呢?

fab -f ab update
fab -f ab restart

注:fabric相当强大,此文只是列举一小功能。如需深入学习,请参见官方文档http://docs.fabfile.org/en/1.6/

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持毛票票。

标签: python

热门推荐