Python-远程SSH执行命令
前言
在自动化运维中经常需要通过ssh批量操作服务器,利用Python的paramiko模块就快速完成工作。
安装
pip install paramiko
使用SSHClient类
SSHClient类是SSH服务会话的高级表示,封装了传输、通道以及SFTPClient的校验、建立方法,通常用于执行命令。
1、connect方法
connect(hostname, port=SSH_PORT, username=None, password=None, pkey=None, key_filename=None, timeout=None, allow_agent=True, look_for_keys=True, compress=False, sock=None, gss_auth=False, gss_kex=False, gss_deleg_creds=True, gss_host=None, banner_timeout=None, auth_timeout=None, gss_trust_dns=True, passphrase=None)
常用参数说明:
hostname:连接目标的主机地址
port:连接目录的端口,默认为22
username:用户名
password:密码
pkey:私钥方式用户验证
key_filename:私钥文件名
timeout:连接超时时间
allow_agent:是否允许使用ssh代理
look_for_keys:是否允许搜索私钥文件
compress:打开时是否压缩
2、load_system_host_keys方法
load_host_keys(filename)
参数说明:
filename:指定远程主机的公钥文件
3、set_missing_host_key_policy
set_missing_host_key_policy(policy)
参数说明:
paramiko.AutoAddPolicy:自动添加主机名及密钥到本地并保存,不依赖load_system_host_keys()配置,即如果known_hosts里没有远程主机的公钥时,默认连接会提示yes/no,自动yes
paramiko.RejectPolicy:自动拒绝未知主机名和密钥,依赖load_system_host_keys()
paramiko.WarnningPlicy:功能与AutoAddPolicy相同,但是未知主机会提示yes/no
4、exec_command方法
exec_command(command,bufsize=-1)
参数说明:
command:执行的的指令
bufsize:文件缓冲区大小,-1不限制
例子
import paramiko
client = paramiko.SSHClient()
client.load_host_keys(filename="/home/opcai/.ssh/known_hosts")
client.set_missing_host_key_policy(paramiko.AutoAddPolicy)
client.connect(hostname='127.0.0.1',port=22,username="opcai",password="opcai123",)
client.exec_command(command="date >> /tmp/aaaaa")
client.close()