亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Python操作遠程服務器 paramiko模塊詳細介紹

發布時間:2020-10-15 14:40:21 來源:腳本之家 閱讀:233 作者:BengDou_Do&Think 欄目:開發技術

前言

paramiko模塊是基于Python實現的SSH遠程安全連接,可以提供在遠程服務器上執行命令、上傳文件到服務器或者從指定服務器下載文件的功能。

paramiko模塊安裝方法

paramiko模塊不是python自帶的標準庫,需要自行下載安裝,建議使用pip自動安裝。方法如下:

(1)配置pip命令和鏡像源路徑。如果已配置,跳過。

(2)執行pip install paramiko進行安裝。出現successful字樣表示安裝完成。

paramiko常用函數介紹

SSHclient類

(1)ssh遠程連接服務器,格式為:connect(hostname, port=22, username=None, password=None, pkey=None, key_filename=None, timeout=None, ...)。其中hostname表示主機IP,port表示ssh服務端口號,默認是22,username和password表示登錄用戶名和密碼,timeout表示設置連接超時時長。

(2)遠程主機沒有本地主機密鑰或HostKeys對象時的連接方法。格式為:set_missing_host_key_policy(policy)。其中policy

參數常見取值有3種,分別如下:

  • AutoAddPolicy:自動添加主機名及主機密鑰到本地的known_hosts,不依賴load_system_host_key的配置。即新建立ssh連接時不需要再輸入yes或no進行確認。最為常用。
  • WarningPolicy 用于記錄一個未知的主機密鑰的python警告。并接受,功能上和AutoAddPolicy類似,但是會提示是新連接。
  • RejectPolicy 自動拒絕未知的主機名和密鑰,依賴load_system_host_key的配置。此為默認選項

(3)遠程執行命令,函數格式:exec_command(command, bufsize=-1, timeout=None, get_pty=False, environment=None),該命令的輸入與輸出流為標準輸入、標出輸出、標準錯誤輸出。

(4)在遠程服務器上生成新的交互式shell。函數格式為:invoke_shell(term='vt100', width=80, height=24, width_pixels=0, height_pixels=0, environment=None)。

上述只是介紹了SSHclient類常用的幾個函數。SSHclient類函數詳細介紹參考SSHClient

SFTPClient類

(1)創建一個已連通的SFTP客戶端通道,格式為:from_transport(cls,t)

(2)將本地文件上傳到服務器,格式為:put(localpath, remotepath, callback=None, confirm=True)

(3)從服務器下載文件到本地,格式為:get(remotepath, localpath, callback=None)

(4)在服務器上創建目錄,格式為:mkdir()

(5)在服務器上刪除目錄,格式為:remove()

(6)在服務器上重命名目錄,格式為:rename()

(7) 查看服務器文件狀態,格式為:stat()

(8)列出服務器目錄下的文件,格式為:listdir()

paramiko常用場景

(1)在遠程服務器執行命令,并獲取命執行命令輸出結果

import paramiko
ssh = paramiko.SSHClient()
ssh.set_missing_host_key_policy(paramiko.AutoAddPolicy())
ssh.connect(hostname='192.168.0.1', port=22, username='root', password='Aa12345!')
stdin, stdout, stderr = ssh.exec_command('df -k')
print stdout.read()
ssh.close()

(2)在遠程服務器執行命令,并獲取執行命令的結果碼

import paramiko
ssh = paramiko.SSHClient()
ssh.set_missing_host_key_policy(paramiko.AutoAddPolicy())
ssh.connect(hostname='192.168.0.1', port=22, username='root', password='Aa12345!')
stdin, stdout, stderr = ssh.exec_command('df -k')
channel = stdout.channel
ret = channel.recv_exit_status()
if ret == 0:
  print stdout.read()
else:
  print stderr.read()

(3)在遠程服務器執行命令,需要生成子進程并交互執行命令

import paramiko,time
ssh = paramiko.SSHClient()
ssh.set_missing_host_key_policy(paramiko.AutoAddPolicy())
ssh.connect(hostname='192.168.0.1', port=22, username='root', password='Aa12345!')
interact = conn.invoke_shell()
stdin, stdout, stderr = ssh.exec_command('df -k')
interact = conn.invoke_shell()
interact.send("sed -i '/192.168.0.2/d' /root/.ssh/known_hosts" + '\n')
time.sleep(1)
interact.send('ssh root@172.16.128.2' + '\n')
time.sleep(2)
interact.send('yes' + '\n')
time.sleep(2)
interact.send('Aa12345!' + '\n')
time.sleep(2)
interact.send('df -k!' + '\n')
result = interact.recv(65535)
print result

(4)上傳文件到遠程服務器

import paramiko
scp = paramiko.Transport(('192.168.0.1',22))
scp.connect(username='root',password='Aa12345!')
sftp=paramiko.SFTPClient.from_transport(scp)
local_path = "D:\\temp\\cc.txt"
remote_path = "/tmp/cc.txt"
sftp.put(local_path, remote_path)
scp.close()

(5)從遠程服務器下載文件

import paramiko
scp = paramiko.Transport(('192.168.0.1',22))
scp.connect(username='root',password='Aa12345!')
sftp=paramiko.SFTPClient.from_transport(scp)
remote_path = "/tmp/aaaa.txt"
local_path = "D:\\temp\\aaaa.txt"
sftp.get(remote_path, local_path)
scp.close()

paramiko使用完整實例

import paramiko
def ssh_con(ip, username, password):
  try:
    con = paramiko.SSHClient()
    con.set_missing_host_key_policy(paramiko.AutoAddPolicy())
    con.connect(ip=ip, username=username, password=password, timeout=5)
  except:
    return None
  else:
    return con
def exec_cmd(conn, cmd):
  interact = conn.invoke_shell()
  interact.send(cmd)
  result = interact.recv(65535)
  return result  
def exec_cmd2(conn,cmd):
  stdin, stdout, stderr = conn.exec_command(cmd)
  channel = stdout.channel
  ret = channel.recv_exit_status()
  if ret == 0:
    return (ret, stdout.read())
  else:
    return (ret, stderr.read())
if __name__ == '__main__':
  ip = '192.168.0.1'
  user = 'root'
  passwd = 'root'
  con = ssh_con(ip, user, passwd)
  if not con:
    print "Connect %s fail,please check." % (ip,)
  cmd = 'df -k'
  ret, result = exec_cmd2(con,cmd)
  print result

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持億速云。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

周口市| 渑池县| 修水县| 霍山县| 汶上县| 宁波市| 张掖市| 唐山市| 昆山市| 双柏县| 河北区| 隆尧县| 永清县| 绿春县| 拉萨市| 灵寿县| 融水| 宝山区| 云南省| 鲁山县| 柳河县| 利辛县| 淄博市| 乐陵市| 蒙阴县| 梅河口市| 新郑市| 南丹县| 仁化县| 宿迁市| 抚宁县| 淳化县| 濮阳市| 遵化市| 蓬溪县| 湖口县| 灵丘县| 鹤峰县| 阳曲县| 荥阳市| 南木林县|