Python中使用SSH需要用到OpenSSH,而OpenSSH依赖于paramiko模块,而paramiko模块又依赖于pycrypto模块,因此要在Python中使用SSH,则需要先安装模块顺序是: pycrypto -> paramiko
我是直接使用pip安装:
下面是网上的一些栗子:
栗子一:执行远程命令:
import paramiko
#新建一个ssh客户端对象
client = paramiko.SSHClient()
# 设置成默认自动接受密钥
client.set_missing_host_key_policy(paramiko.AutoAddPolicy())
#连接远程主机
client.connect('IP', 22, username='root', password='password', timeout=4)
#在远程主机执行shell命令
stdin, stdout, stderr = client.exec_command('ls -l')
#读取执行结果
for std in stdout.readlines():
print (std,)
client.close()
栗子二:上传本地文件至远程主机
import paramiko
t = paramiko.Transport(("IP",22))
t.connect(username = "username", password = "password")
sftp = paramiko.SFTPClient.from_transport(t)
remotepath='/tmp/test.txt'
localpath='/tmp/test.txt'
sftp.put(localpath,remotepath)
t.close()
栗子三:下载远程主机文件到本地
import paramiko
t = paramiko.Transport(("IP",22))
t.connect(username = "username", password = "password")
sftp = paramiko.SFTPClient.from_transport(t)
remotepath='/tmp/test.txt'
localpath='/tmp/test.txt'
sftp.get(remotepath, localpath)
t.close()
栗子四:
通常需要对多个服务器或者虚拟机进行管理,可以采用批量的方式进行。
import paramiko
import threading
def ssh2(ip,username,passwd,cmd):
try:
ssh = paramiko.SSHClient()
ssh.set_missing_host_key_policy(paramiko.AutoAddPolicy())
ssh.connect(ip,22,username,passwd,timeout=5)
for m in cmd:
stdin, stdout, stderr = ssh.exec_command(m)
out = stdout.readlines()
for o in out:
print (o,) #屏幕输出
print ('%s\tOK\n'%(ip))
ssh.close()
except :
print ('%s\tError\n'%(ip))
if __name__=='__main__':
cmd = ['echo hello!']#需要执行的命令列表
username = "root" #用户名
passwd = "root" #密码
threads = [] #多线程
print ("Begin excute......")
for i in range(1,254):
ip = '192.168.1.'+str(i)
a=threading.Thread(target=ssh2,args=(ip,username,passwd,cmd))
a.start()
最后一个栗子,如果命令较少,pssh更适合。