开发堡垒机以前,先来学习Python的paramiko模块,该模块基于SSH用于链接远程服务器并执行相关操做python
安装paramiko模块bash
pip3 install paramiko
基于用户密码方式服务器
import paramiko # 建立SSH对象 ssh = paramiko.SSHClient() # 容许链接不在know_hosts文件中的主机 ssh.set_missing_host_key_policy(paramiko.AutoAddPolicy()) # 链接服务器 ssh.connect(hostname="10.0.0.200", port=22, username='root', password='1') # 执行命令 # stdin:标准输入(就是你输入的命令);stdout:标准输出(就是命令执行结果);stderr:标准错误(命令执行过程当中若是出错了就把错误打到这里),stdout和stderr仅会输出一个 stdin, stdout, stderr = ssh.exec_command('df') # 获取命令结果 result = (stdout.read().decode('utf-8')) # 这个有问题,若是执行的命令是错误的,会不显示错误,能够修改一下,先判断stdout有没有值,若是输出没有,就显示错误 print(result) # 关闭链接 ssh.close()
基于公钥密钥链接ssh
import paramiko # 指定私钥路径 private_key = paramiko.RSAKey.from_private_key_file('/root/.ssh/id_rsa') # 建立SSH对象 ssh = paramiko.SSHClient() # 容许链接不在know_hosts文件中的主机 ssh.set_missing_host_key_policy(paramiko.AutoAddPolicy()) # 链接服务器 ssh.connect(hostname='10.0.0.171', port=22, username='root', pkey=private_key) # 执行命令 stdin, stdout, stderr = ssh.exec_command('df') # 获取命令结果 result = stdout.read() print(result.decode()) # 关闭链接 ssh.close()