Python自動化運維和部署項目工具Fabric使用實例
Fabric 是使用 Python 開發(fā)的一個自動化運維和部署項目的一個好工具,可以通過 SSH 的方式與遠程服務器進行自動化交互,例如將本地文件傳到服務器,在服務器上執(zhí)行shell 命令。
下面給出一個自動化部署 Django 項目的例子
# -*- coding: utf-8 -*-
# 文件名要保存為 fabfile.py
from __future__ import unicode_literals
from fabric.api import *
# 登錄用戶和主機名:
env.user = 'root'
# 如果沒有設置,在需要登錄的時候,fabric 會提示輸入
env.password = 'youpassword'
# 如果有多個主機,fabric會自動依次部署
env.hosts = ['www.example.com']
TAR_FILE_NAME = 'deploy.tar.gz'
def pack():
"""
定義一個pack任務, 打一個tar包
:return:
"""
tar_files = ['*.py', 'static/*', 'templates/*', 'vue_app/', '*/*.py', 'requirements.txt']
exclude_files = ['fabfile.py', 'deploy/*', '*.tar.gz', '.DS_Store', '*/.DS_Store',
'*/.*.py', '__pycache__/*']
exclude_files = ['--exclude=\'%s\'' % t for t in exclude_files]
local('rm -f %s' % TAR_FILE_NAME)
local('tar -czvf %s %s %s' % (TAR_FILE_NAME, ' '.join(exclude_files), ' '.join(tar_files)))
print('在當前目錄創(chuàng)建一個打包文件: %s' % TAR_FILE_NAME)
def deploy():
"""
定義一個部署任務
:return:
"""
# 先進行打包
pack()
# 遠程服務器的臨時文件
remote_tmp_tar = '/tmp/%s' % TAR_FILE_NAME
run('rm -f %s' % remote_tmp_tar)
# 上傳tar文件至遠程服務器, local_path, remote_path
put(TAR_FILE_NAME, remote_tmp_tar)
# 解壓
remote_dist_base_dir = '/home/python/django_app'
# 如果不存在, 則創(chuàng)建文件夾
run('mkdir -p %s' % remote_dist_dir)
# cd 命令將遠程主機的工作目錄切換到指定目錄
with cd(remote_dist_dir):
print('解壓文件到到目錄: %s' % remote_dist_dir)
run('tar -xzvf %s' % remote_tmp_tar)
print('安裝 requirements.txt 中的依賴包')
# 我使用的是 python3 來開發(fā)
run('pip3 install -r requirements.txt')
remote_settings_file = '%s/django_app/settings.py' % remote_dist_dir
settings_file = 'deploy/settings.py' % name
print('上傳 settings.py 文件 %s' % settings_file)
put(settings_file, remote_settings_file)
nginx_file = 'deploy/django_app.conf'
remote_nginx_file = '/etc/nginx/conf.d/django_app.conf'
print('上傳 nginx 配置文件 %s' % nginx_file)
put(nginx_file, remote_nginx_file)
# 在當前目錄的子目錄 deploy 中的 supervisor 配置文件上傳至服務器
supervisor_file = 'deploy/django_app.ini'
remote_supervisor_file = '/etc/supervisord.d/django_app.ini'
print('上傳 supervisor 配置文件 %s' % supervisor_file)
put(supervisor_file, remote_supervisor_file)
# 重新加載 nginx 的配置文件
run('nginx -s reload')
run('nginx -t')
# 刪除本地的打包文件
local('rm -f %s' % TAR_FILE_NAME)
# 載入最新的配置文件,停止原有進程并按新的配置啟動所有進程
run('supervisorctl reload')
# 執(zhí)行 restart all,start 或者 stop fabric 都會提示錯誤,然后中止運行
# 但是服務器上查看日志,supervisor 有重啟
# run('supervisorctl restart all')
執(zhí)行 pack 任務
fab pack
執(zhí)行 deploy 任務
fab deploy
再給大家分享一個使用Fabric進行代碼的自動化部署
#coding=utf-8
from fabric.api import local, abort, settings, env, cd, run
from fabric.colors import *
from fabric.contrib.console import confirm
env.hosts = ["root@115.28.×××××"]
env.password = "×××××"
def get_git_status():
git_status_result = local("git status", capture=True)
if "無文件要提交,干凈的工作區(qū)" not in git_status_result:
print red("****當前分支還有文件沒有提交")
print git_status_result
abort("****已經(jīng)終止")
def local_unit_test():
with settings(warn_only=True):
test_result = local("python manage.py test")
if test_result.failed:
print test_result
if not confirm(red("****單元測試失敗,是否繼續(xù)?")):
abort("****已經(jīng)終止")
def server_unit_test():
with settings(warn_only=True):
test_result = run("python manage.py test")
if test_result.failed:
print test_result
if not confirm(red("****單元測試失敗,是否繼續(xù)?")):
abort("****已經(jīng)終止")
def upload_code():
local("git push origin dev")
print green("****代碼上傳成功")
def deploy_at_server():
print green("****ssh到服務器進行下列操作")
with cd("/var/www/××××××"):
#print run("pwd")
print green("****將在遠程倉庫下載代碼")
run("git checkout dev")
get_git_status()
run("git pull origin dev")
print green("****將在服務器上運行單元測試")
server_unit_test()
run("service apache2 restart", pty=False)
print green("****重啟apache2成功")
print green("********代碼部署成功********")
def deploy():
get_git_status()
local("git checkout dev", capture=False)
print green("****切換到dev分支")
get_git_status()
print green("****將開始運行單元測試")
local_unit_test()
print green("****單元測試完成,開始上傳代碼")
upload_code()
deploy_at_server()
fabric可以將自動化部署或者多機操作的命令固化到一個腳本里,從而減少手動的操作。上面是今天第一次接觸這東西后寫的,確實很實用。運行fab deploy就行了。
主要邏輯就是將本地的dev分支跑單元測試,然后提交到服務器,ssh登陸到服務器,然后pull下來,再跑單元測試,然后重啟apache2。第一次寫,可能比較簡單,將持續(xù)改進。
相關文章
在Python3 numpy中mean和average的區(qū)別詳解
今天小編就為大家分享一篇在Python3 numpy中mean和average的區(qū)別詳解,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2019-08-08
Python標準庫:內(nèi)置函數(shù)max(iterable, *[, key, default])說明
這篇文章主要介紹了Python標準庫:內(nèi)置函數(shù)max(iterable, *[, key, default])說明,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-04-04

