Python學習筆記—自動化部署【新手必學】

来源:https://www.cnblogs.com/chengxuyuanaa/archive/2019/12/09/12013740.html
-Advertisement-
Play Games

前言本文的文字及圖片來源於網路,僅供學習、交流使用,不具有任何商業用途,版權歸原作者所有,如有問題請及時聯繫我們以作處理。作者:唯戀殊雨 目錄 pexpect fabric pexpect Pexpect 是 Don Libes 的 Expect 語言的一個 Python 實現,是一個用來啟動子程式 ...


 

 

前言
本文的文字及圖片來源於網路,僅供學習、交流使用,不具有任何商業用途,版權歸原作者所有,如有問題請及時聯繫我們以作處理。
作者:唯戀殊雨

 

目錄

pexpect

fabric


pexpect

Pexpect 是 Don Libes 的 Expect 語言的一個 Python 實現,是一個用來啟動子程式,並使用正則表達式對程式輸出做出特定響應,以此實現與其自動交互的 Python 模塊。 Pexpect 的使用範圍很廣,可以用來實現與 ssh、ftp 、telnet 等程式的自動交互;可以用來自動複製軟體安裝包併在不同機器自動安裝;還可以用來實現軟體測試中與命令行交互的自動化。當然如果你還沒學到自動化,建議可以先去小編的Python交流.裙 :一久武其而而流一思(數字的諧音)轉換下可以找到了,裡面有最新Python教程項目,多交流進步更快

  1.   import pexpect
  2.   import sys
  3.    
  4.   child = pexpect.spawn('ssh [email protected]')
  5.   child.logfile = sys.stdout
  6.   #fout = file('mylog.txt', 'w')
  7.   #child.logfile = fout
  8.   child.expect('password:')
  9.   child.sendline('std20')
  10.   child.expect('std20.*')
  11.   child.sendline('ls /')
  12.   child.expect('std20.*')
  13.   child.sendline('exit')
  1.   #coding=utf_8
  2.    
  3.   from pexpect import pxssh
  4.   import sys
  5.    
  6.   s = pxssh.pxssh()
  7.   s.logfile = sys.stdout
  8.   hostname = '123.57.211.212'
  9.   username = 'std20'
  10.   password = 'std20'
  11.   s.login(hostname, username, password)
  12.   s.sendline('ls /')
  13.   s.prompt() #匹配系統提示符
  14.   s.sendline('whoami')
  15.   s.prompt()
  16.   s.logout()

fabric

項目發佈和運維的工作相當機械,頻率還蠻高,導致時間浪費在敲大量重覆的命令上。

修複bug什麼的,測試,提交版本庫(2分鐘),ssh到測試環境pull部署(2分鐘),rsync到線上機器A,B,C,D,E(1分鐘),分別ssh到ABCDE五台機器,逐一重啟(8-10分鐘) = 13-15分鐘

其中鬱悶的是,每次操作都是相同的,命令一樣,要命的是在多個機器上,很難在本機一個腳本搞定,主要時間都浪費在ssh,敲命令上了,寫成腳本,完全可以一鍵執行,花兩分鐘看下執行結果。

安裝

pip install fabric

入門示例

  1.   #fabfile.py
  2.   from fabric.api import run
  3.    
  4.   def host_type():
  5.   run('uname -s')

啟動

  1.   itcast@ubuntu:~/tmp/fab$ fab -H 127.0.0.1 host_type
  2.   [127.0.0.1] Executing task 'host_type'
  3.   [127.0.0.1] run: uname -s
  4.   [127.0.0.1] Login password for 'itcast':
  5.   [127.0.0.1] out: Linux
  6.   [127.0.0.1] out:
  7.    
  8.    
  9.   Done.
  10.   Disconnecting from 127.0.0.1... done.
  11.   itcast@ubuntu:~/tmp/fab$ fab -H 127.0.0.1 host_type
  12.   [127.0.0.1] Executing task 'host_type'
  13.   [127.0.0.1] run: uname -s
  14.   [127.0.0.1] Login password for 'itcast':
  15.   [127.0.0.1] out: Linux
  16.   [127.0.0.1] out:

fabric常用參數

  • -l : 顯示定義好的任務函數名
  • -f : 指定fab入口文件,預設入口文件名為fabfile.py
  • -H : 指定目標主機,多台主機用","號分割

fabric常用API

  • local : 執行本地命令,如:local('uname -s')
  • lcd : 切換本地目錄,如:lcd('/home')
  • cd : 切換遠程目錄,如:cd('/etc')
  • run : 執行遠程命令,如:run('free -m')
  • sudo : sudo方式執行遠程命令,如:sudo('touch /abc')
  • put : 上傳本地文件到遠程主機,如:put('/hello', '/home/itcast/hello')
  • get : 從遠程主機下載文件到本地,如:get('/home/python/world', '/home/itcast/world')
  • reboot : 重啟遠程主機,如:reboot()
  • @task : 函數裝飾器,標識的函數為fab可調用的,非標記的對fab不可見,純業務邏輯
  • @runs_once : 函數裝飾器,標識的函數只會執行一次,不受多台主機影響

fabric全局屬性設定

  • env.host : 定義目標主機,如:env.host=['192.168.17.192', '192.168.17.193']
  • env.user : 定義用戶名,如:env.user="root"
  • env.port : 定義目標主機埠,預設為22,如:env.port="22"
  • env.password : 定義密碼,如:env.password="chuanzhi"
  • env.passwords : 不同的主機不同的密碼,如:env.passwords={'[email protected]:22':'chuanzhi', '[email protected]:22':'python'}

示例1:動態獲取遠程目錄列表

  1.   from fabric.api import *
  2.    
  3.   env.hosts=['192.168.17.192', '192.168.17.193']
  4.   #env.password='python'
  5.   env.passwords = {
  6.   '[email protected]:22':'python',
  7.   '[email protected]:22':'python',
  8.   }
  9.    
  10.   @runs_once
  11.   def input_raw():
  12.   return prompt("please input directory name:", default="/home")
  13.    
  14.   def workask(dirname):
  15.   run('ls -l ' + dirname)
  16.    
  17.   @task
  18.   def go():
  19.   print('start ...')
  20.   getdirname = input_raw()
  21.   workask(getdirname)
  22.   print('end ...')

示例2:上傳文件並執行

  1.   from fabric.api import *
  2.    
  3.   env.user = 'itcast'
  4.   env.hosts = ['192.168.17.192', '192.168.17.193']
  5.   env.password = 'python'
  6.    
  7.   @task
  8.   @runs_once
  9.   def tar_task():
  10.   with lcd('/home/itcast/testdemo'):
  11.   local('tar zcvf demo.tar.gz demo.py')
  12.    
  13.   @task
  14.   def put_task():
  15.   run('mkdir -p /home/itcast/testdemo')
  16.   with cd('/home/itcast/testdemo'):
  17.   put('/home/itcast/testdemo/demo.tar.gz', '/home/itcast/testdemo/demo.tar.gz')
  18.    
  19.   @task
  20.   def check_task():
  21.   lmd5 = local('md5sum /home/itcast/testdemo/demo.tar.gz', capture=True).split(' ')[0]
  22.   rmd5 = run('md5sum /home/itcast/testdemo/demo.tar.gz').split(' ')[0]
  23.   if lmd5 == rmd5:
  24.   print('OK ...')
  25.   else:
  26.   print('ERROR ...')
  27.    
  28.   @task
  29.   def run_task():
  30.   with cd('/home/itcast/testdemo'):
  31.   run('tar zxvf demo.tar.gz')
  32.   run('python demo.py')
  33.    
  34.   @task
  35.   def go():
  36.   tar_task()
  37.   put_task()
  38.   check_task()
  39.   run_task()

代碼自動化部署

  1.   from fabric.api import *
  2.    
  3.   env.user = 'itcast'
  4.   env.hosts = ['192.168.17.192', '192.168.17.193']
  5.   env.password = 'python'
  6.    
  7.   @runs_once
  8.   @task
  9.   def local_update():
  10.   with lcd("/home/itcast/tmp/itcasthello"):
  11.   local("git add -A")
  12.   local("git commit -m 'update'")
  13.   local("git pull origin master")
  14.   local("git push origin master")
  15.    
  16.    
  17.   @task
  18.   def remote_update():
  19.   with cd("/home/itcast/tmp/itcasthello"):
  20.   run("git checkout master")
  21.   run("git pull origin master")
  22.    
  23.   @task
  24.   def deploy():
  25.   local_update()
  26.   remote_update()
 
您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 題目: 編程式將給定字元串中指定字元刪除。要求刪除指定字元後原字元串不能留下空位置,字元串和指定字元均由鍵盤輸入 基本思路 將字元串與要刪除的字元進行比較,若為相同字元,則將字元串中的該字元替換為原字元串中下一個字元,並依次將後面的字元提前,從而達到刪除字元的目的。 註意 :字元前移一位後,需要判斷 ...
  • 1. "Spot The Discrepancies with Dialyzer for Erlang" . 如何在大型Erlang項目中從零開始一步步踐行Dialyzer。 2. "Which companies are using Erlang, and why?" 哪一些公司正在生產上使用Er ...
  • 這篇文章主要介紹redis的使用。 簡單介紹下redis,一個高性能key-value的存儲系統,支持存儲的類型有string、list、set、zset和hash。在處理大規模數據讀寫的場景下運用比較多。 1.連接Redis資料庫: 1)直接連接 2)連接池連接 連接池的原理是, 通過預先創建多個 ...
  • 1.在setting.py中,將DEBUG改為False,否則不會生效 2.DEBUG為False後,會導致靜態資源的路徑(STATIC_URL)失效, 簡單的做法,在開發時: 複雜的方法(django2.2.7,會導致404頁面的靜態資源的圖片無法載入) setting.py urls.py 3. ...
  • tomcat是8.0版本. 在eclipse啟動時,第二行報這個, 同時項目也沒載入(tomcat啟動成功了). 網上搜了半天, 試了半天, 沒搞定. 最後不經意間發現: <Context docBase="xxxx" path="/" reloadable="true"/> 這種不帶</Conte ...
  • 近日開始了移動端自動化測試的學習之路,決定在學習的過程中進行筆記,總結學習,印象或許會深刻一些。 [TOC] Android自動化環境準備 1、 Android SDK: 下載 Android SDK(可以先使用Android Studio輔助安裝),並設置 PATH 變數加入 SDK 的工具目錄; ...
  • Python 中如何實現參數化測試? 之前,我曾轉過一個單元測試框架系列的文章,裡面介紹了 unittest、nose/nose2 與 pytest 這三個最受人歡迎的 Python 測試框架。 本文想針對測試中一種很常見的測試場景,即參數化測試,繼續聊聊關於測試的話題,並嘗試將這幾個測試框架串聯起 ...
  • 新聞 "宣告.NET Core 3.1" "新書:Kevin Avignon的F 提升效率" ".NET Core 2.2將在2019年12月23日迎來終結" "Visual Studio 16.5預覽版1中升級了.NET Core Windows Forms設計器" "用於垃圾回收的運行時配置選項 ...
一周排行
    -Advertisement-
    Play Games
  • 1. 說明 /* Performs operations on System.String instances that contain file or directory path information. These operations are performed in a cross-pla ...
  • 視頻地址:【WebApi+Vue3從0到1搭建《許可權管理系統》系列視頻:搭建JWT系統鑒權-嗶哩嗶哩】 https://b23.tv/R6cOcDO qq群:801913255 一、在appsettings.json中設置鑒權屬性 /*jwt鑒權*/ "JwtSetting": { "Issuer" ...
  • 引言 集成測試可在包含應用支持基礎結構(如資料庫、文件系統和網路)的級別上確保應用組件功能正常。 ASP.NET Core 通過將單元測試框架與測試 Web 主機和記憶體中測試伺服器結合使用來支持集成測試。 簡介 集成測試與單元測試相比,能夠在更廣泛的級別上評估應用的組件,確認多個組件一起工作以生成預 ...
  • 在.NET Emit編程中,我們探討了運算操作指令的重要性和應用。這些指令包括各種數學運算、位操作和比較操作,能夠在動態生成的代碼中實現對數據的處理和操作。通過這些指令,開發人員可以靈活地進行算術運算、邏輯運算和比較操作,從而實現各種複雜的演算法和邏輯......本篇之後,將進入第七部分:實戰項目 ...
  • 前言 多表頭表格是一個常見的業務需求,然而WPF中卻沒有預設實現這個功能,得益於WPF強大的控制項模板設計,我們可以通過修改控制項模板的方式自己實現它。 一、需求分析 下圖為一個典型的統計表格,統計1-12月的數據。 此時我們有一個需求,需要將月份按季度劃分,以便能夠直觀地看到季度統計數據,以下為該需求 ...
  • 如何將 ASP.NET Core MVC 項目的視圖分離到另一個項目 在當下這個年代 SPA 已是主流,人們早已忘記了 MVC 以及 Razor 的故事。但是在某些場景下 SSR 還是有意想不到效果。比如某些靜態頁面,比如追求首屏載入速度的時候。最近在項目中回歸傳統效果還是不錯。 有的時候我們希望將 ...
  • System.AggregateException: 發生一個或多個錯誤。 > Microsoft.WebTools.Shared.Exceptions.WebToolsException: 生成失敗。檢查輸出視窗瞭解更多詳細信息。 內部異常堆棧跟蹤的結尾 > (內部異常 #0) Microsoft ...
  • 引言 在上一章節我們實戰了在Asp.Net Core中的項目實戰,這一章節講解一下如何測試Asp.Net Core的中間件。 TestServer 還記得我們在集成測試中提供的TestServer嗎? TestServer 是由 Microsoft.AspNetCore.TestHost 包提供的。 ...
  • 在發現結果為真的WHEN子句時,CASE表達式的真假值判斷會終止,剩餘的WHEN子句會被忽略: CASE WHEN col_1 IN ('a', 'b') THEN '第一' WHEN col_1 IN ('a') THEN '第二' ELSE '其他' END 註意: 統一各分支返回的數據類型. ...
  • 在C#編程世界中,語法的精妙之處往往體現在那些看似微小卻極具影響力的符號與結構之中。其中,“_ =” 這一組合突然出現還真不知道什麼意思。本文將深入剖析“_ =” 的含義、工作原理及其在實際編程中的廣泛應用,揭示其作為C#語法奇兵的重要角色。 一、下劃線 _:神秘的棄元符號 下劃線 _ 在C#中並非 ...