python如何實現自動化運維

王林
發布: 2023-05-17 12:22:13
轉載
2214 人瀏覽過

1、安裝

pip install paramiko

2、導入模組

import paramiko

3、使用

#def initSshClinet (): ''' 初始化,SSH連線帳號密碼登入伺服器:return: sshClinet ''' ip = ""#伺服器ip位址sshClinet = paramiko.SSHClient() sshClinet.set_missing_host_key_policy(paramiko.AutoAddPolicy()) sshy()) sconnlinet. ip, 22, userName, pw, timeout=360) return sshClinet

def exeCommond(commond): ''' 執行shell指令''' stdin, stdout, stderr = sshClient.exec_command(command) outStr = stdout .readlines() print("\n".join(outStr))

def sftpUploadFile(localPath, remotePath): #取得SFTP實例sftp = sshClinet.open_sftp() #執行上傳動作sftp.put(localPath , remotePath)

def sftpDownloadFile(localPath, remotePath): #取得SFTP實例sftp = sshClinet.open_sftp() #執行下載動作sftp.get(localPath, remotePath)

記得關閉動作sftp.get(localPath, remotePath)

」記得關閉動作sftp.連線

sshClient.close()

也可以使用私密金鑰登入:

# 設定私人金鑰檔案位置private = paramiko.RSAKey.from_private_key_file('/Users/ ch/.ssh/id_rsa')#實例化SSHClientclient = paramiko.SSHClient()#自動添加策略,保存伺服器的主機名稱和密鑰信息,如果不添加,那麼不再本地know_hosts檔案中記錄的主機將無法連接client .set_missing_host_key_policy(paramiko.AutoAddPolicy())#連接SSH服務端,以使用者名稱和密碼進行認證client.connect(hostname='10.0.0.1',port=22,username='root',pkey=private)##學習

paramiko包含兩個核心元件:SSHClient和SFTPClient。

SSHClient的作用類似Linux的ssh指令,是對SSH會話的封裝,該類別封裝了傳輸(Transport),通道(Channel)及SFTPClient建立的方法(open_sftp),通常用於執行遠端命令。 SFTPClient的作用類似與Linux的sftp指令,是對SFTP客戶端的封裝,用以實現遠端檔案操作,如檔案上傳、下載、修改檔案權限等操作。

Channel是一種類別Socket,一種安全的SSH傳輸通道Transport是一種加密的會話,使用時會同步創建了一個加密的Tunnels(通道),這個Tunnels叫做ChannelSession是client與Server保持連接的對象,用connect()/start_client()/start_server()開始會話

SSHClient常用的方法介紹

connect() :實作遠端伺服器的連接與認證,對於該方法只有hostname是必傳參數。

hostname連線的目標主機port=SSH_PORT指定連接埠username=None驗證的使用者名稱password=None驗證的使用者密碼pkey=None私鑰方式用於驗證key_filename=None一個檔案名稱或檔案列表,指定私鑰檔案timeout=None可選的tcp連線逾時時間allow_agent=True是否允許連線到ssh代理,預設為True 允許look_for_keys=True是否在~/.ssh中搜尋私鑰文件,預設為True 允許compress=False是否開啟壓縮

set_missing_host_key_policy() :設定遠端伺服器沒有在know_hosts檔案中記錄時的應對策略。傳入MissingHostKeyPolicy的子類,目前支援三種策略:

設定連接的遠端主機沒有本地主機金鑰或HostKeys物件時的策略,目前支援三種:

AutoAddPolicy自動添加主機名稱及主機金鑰到本機HostKeys對象,不依賴load_system_host_key的配置。即新建立ssh連線時不需要再輸入yes或no進行確認WarningPolicy用於記錄一個未知的主機金鑰的python警告。並接受,功能上和AutoAddPolicy類似,但會提示是新連線RejectPolicy自動拒絕未知的主機名稱和金鑰,依賴load_system_host_key的設定。此為預設選項

exec_command() :在遠端伺服器執行Linux命令的方法。

open_sftp() :在目前ssh會話的基礎上建立一個sftp會話。該方法會傳回一個SFTPClient物件。

SFTPClient常用方法介紹

from_transport(cls,t) :建立一個已連結的SFTP客戶端通道put(localpath, remotepath, callback=None, confirm= True) :將本機檔案上傳到伺服器參數confirm:是否呼叫stat()方法檢查檔案狀態,傳回ls -l的結果get(remotepath, localpath, callback=None) :從伺服器下載檔案到本機mkdir() :在伺服器上建立目錄remove() : 在伺服器上刪除目錄rename() :在伺服器上重新命名目錄stat() :查看伺服器檔案狀態 listdir():列出伺服器目錄下的檔案###

以上是python如何實現自動化運維的詳細內容。更多資訊請關注PHP中文網其他相關文章!

相關標籤:
來源:yisu.com
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板
關於我們 免責聲明 Sitemap
PHP中文網:公益線上PHP培訓,幫助PHP學習者快速成長!