在Python(其实任何语言都是)中操控ssh执行远程命令是一个很麻烦的事情……

首先要突破ssh密码的非交互模式,我之前一直用sshpass拼接各种复杂的字符串。

然后是之后的执行命令只能执行一行,或者是很长的字符串,拼接起来很麻烦。

Python中有一个很活跃的包ssh,它fork自大名鼎鼎的Paramiko,后者是经典的ssh模块,不过作者不再维护了。


1、安装

下载地址:https://pypi.python.org/pypi/ssh

tar -xzvf ssh-1.8.tar.gz
cd ssh-1.8
python setup.py install
上面的安装最好在联网状态下进行,因为它会自动下载依赖包pycrypto。

pycrypto的下载地址:https://pypi.python.org/pypi/pycrypto


2、ssh用法:设置缺失Key、登录、执行命令、获取结果

import ssh
 
# New SSHClient
client = ssh.SSHClient()
 
# Default accept unknown keys
client.set_missing_host_key_policy(ssh.AutoAddPolicy())
 
# Connect
client.connect("xxx.coder4.com", port=22, username="xxxx", password="xxxx")
 
# Execute shell remotely
stdin, stdout, stderr = client.exec_command("ls -alh")
stdout.read()
注意:一定要获取stdout/stderr,然后read,否则远程命令很有可能无法执行完毕。


3、sftp用法

当拿到一个SSHClient后,我们除了执行命令,还可以开启一个sftp的session,用于传输文件、创建文件夹等等。

# Open sftp session
sftp = client.open_sftp()
 
# Make a dir
sftp.mkdir('abc')
 
# Down file from remote to local 这个可能会抛出异常,如果失败的话
sftp.get('firewall.sh', '/tmp/firewall.sh')
 
# Upload file from local to remote 也可能会抛出异常
sftp.put('/tmp/firewall.sh', 'firewall_new.sh')