Fabric 是使用 Python 開發的一個自動化運維和部署項目的一個好工具,可以通過 SSH 的方式與遠程服務器進行自動化交互,例如將本地文件傳到服務器,在服務器上執行shell 命令。
下面給出一個自動化部署 Django 項目的例子
# -*- coding: utf-8 -*-# 文件名要保存為 fabfile.pyfrom __future__ import unicode_literalsfrom 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('在當前目錄創建一個打包文件: %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' # 如果不存在, 則創建文件夾 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 來開發 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') # 執行 restart all,start 或者 stop fabric 都會提示錯誤,然后中止運行 # 但是服務器上查看日志,supervisor 有重啟 # run('supervisorctl restart all')執行 pack 任務
fab pack
執行 deploy 任務
fab deploy
再給大家分享一個使用Fabric進行代碼的自動化部署
#coding=utf-8from fabric.api import local, abort, settings, env, cd, runfrom fabric.colors import *from fabric.contrib.console import confirmenv.hosts = ["root@115.28.×××××"]env.password = "×××××"def get_git_status(): git_status_result = local("git status", capture=True) if "無文件要提交,干凈的工作區" not in git_status_result: print red("****當前分支還有文件沒有提交") print git_status_result abort("****已經終止")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("****單元測試失敗,是否繼續?")): abort("****已經終止")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("****單元測試失敗,是否繼續?")): abort("****已經終止")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。第一次寫,可能比較簡單,將持續改進。
|
新聞熱點
疑難解答
圖片精選