在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')