Python自動(dòng)化運(yùn)維和部署項(xiàng)目工具Fabric使用實(shí)例
Fabric 是使用 Python 開發(fā)的一個(gè)自動(dòng)化運(yùn)維和部署項(xiàng)目的一個(gè)好工具,可以通過 SSH 的方式與遠(yuǎn)程服務(wù)器進(jìn)行自動(dòng)化交互,例如將本地文件傳到服務(wù)器,在服務(wù)器上執(zhí)行shell 命令。
下面給出一個(gè)自動(dòng)化部署 Django 項(xiàng)目的例子
# -*- coding: utf-8 -*- # 文件名要保存為 fabfile.py from __future__ import unicode_literals from fabric.api import * # 登錄用戶和主機(jī)名: env.user = 'root' # 如果沒有設(shè)置,在需要登錄的時(shí)候,fabric 會(huì)提示輸入 env.password = 'youpassword' # 如果有多個(gè)主機(jī),fabric會(huì)自動(dòng)依次部署 env.hosts = ['www.example.com'] TAR_FILE_NAME = 'deploy.tar.gz' def pack(): """ 定義一個(gè)pack任務(wù), 打一個(gè)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('在當(dāng)前目錄創(chuàng)建一個(gè)打包文件: %s' % TAR_FILE_NAME) def deploy(): """ 定義一個(gè)部署任務(wù) :return: """ # 先進(jìn)行打包 pack() # 遠(yuǎn)程服務(wù)器的臨時(shí)文件 remote_tmp_tar = '/tmp/%s' % TAR_FILE_NAME run('rm -f %s' % remote_tmp_tar) # 上傳tar文件至遠(yuǎn)程服務(wù)器, 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 命令將遠(yuǎn)程主機(jī)的工作目錄切換到指定目錄 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) # 在當(dāng)前目錄的子目錄 deploy 中的 supervisor 配置文件上傳至服務(wù)器 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) # 載入最新的配置文件,停止原有進(jìn)程并按新的配置啟動(dòng)所有進(jìn)程 run('supervisorctl reload') # 執(zhí)行 restart all,start 或者 stop fabric 都會(huì)提示錯(cuò)誤,然后中止運(yùn)行 # 但是服務(wù)器上查看日志,supervisor 有重啟 # run('supervisorctl restart all')
執(zhí)行 pack 任務(wù)
fab pack
執(zhí)行 deploy 任務(wù)
fab deploy
再給大家分享一個(gè)使用Fabric進(jìn)行代碼的自動(dòng)化部署
#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("****當(dāng)前分支還有文件沒有提交") 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("****單元測(cè)試失敗,是否繼續(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("****單元測(cè)試失敗,是否繼續(xù)?")): abort("****已經(jīng)終止") def upload_code(): local("git push origin dev") print green("****代碼上傳成功") def deploy_at_server(): print green("****ssh到服務(wù)器進(jìn)行下列操作") with cd("/var/www/××××××"): #print run("pwd") print green("****將在遠(yuǎn)程倉庫下載代碼") run("git checkout dev") get_git_status() run("git pull origin dev") print green("****將在服務(wù)器上運(yùn)行單元測(cè)試") 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("****將開始運(yùn)行單元測(cè)試") local_unit_test() print green("****單元測(cè)試完成,開始上傳代碼") upload_code() deploy_at_server()
fabric可以將自動(dòng)化部署或者多機(jī)操作的命令固化到一個(gè)腳本里,從而減少手動(dòng)的操作。上面是今天第一次接觸這東西后寫的,確實(shí)很實(shí)用。運(yùn)行fab deploy
就行了。
主要邏輯就是將本地的dev分支跑單元測(cè)試,然后提交到服務(wù)器,ssh登陸到服務(wù)器,然后pull下來,再跑單元測(cè)試,然后重啟apache2。第一次寫,可能比較簡(jiǎn)單,將持續(xù)改進(jìn)。
相關(guān)文章
在Python 不同級(jí)目錄之間模塊的調(diào)用方法
今天小編就為大家分享一篇在Python 不同級(jí)目錄之間模塊的調(diào)用方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2019-01-01Python基礎(chǔ)之教你怎么在M1系統(tǒng)上使用pandas
這篇文章主要介紹了Python基礎(chǔ)之教你怎么在M1系統(tǒng)上使用pandas,文中有非常詳細(xì)的代碼示例,對(duì)正在學(xué)習(xí)python基礎(chǔ)的小伙伴們有很好地幫助,需要的朋友可以參考下2021-05-05Python人工智能構(gòu)建簡(jiǎn)單聊天機(jī)器人示例詳解
這篇文章主要為大家介紹了Python人工智能構(gòu)建簡(jiǎn)單聊天機(jī)器人示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-03-03DataFrame窗口函數(shù)rolling()的用法
這篇文章主要介紹了DataFrame窗口函數(shù)rolling()的用法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-02-02