paramiko介绍
paramiko是一个基于python编写的、使用ssh协议的模块,跟xshell和xftp功能类似,支持加密与认证,可以上传下载和访问服务器的文件。
可以利用paramiko模块写服务器脚本,在本地执行,比如持续更新代码,查看日志,批量配置集群等。
paramiko 主要包含SSHClient和SFTPClient两个组件。
安装
pip install paramiko
SSHClient
ssh服务会话的表示,通常用来执行命令,主要有connect、exec_command、load_system_host_keys和set_missing_host_key_policy方法。
-
connect:建立SSH远程连接并校验。
-
exec_command:执行指令并返回结果。
-
load_system_host_keys:加载本地公钥校验文件。
-
set_missing_host_key_policy:远程主机没有本地主机密钥或HostKeys时的策略。
-
invoke_shell:通过SSHClient的invoke_shell方法,可以创建一个交互会话的对象,和exec_command方法不同的是,这个可以实现命令交互,比如先cd到某个目录下,再执行脚本操作,然后退出,这种需要多个步骤的操作。
import paramiko
server = {}
hostname = server['ip']
port = server['port']
username = server['username']
password = server['password']
print(ip,port,username)
#创建SSH对象
client = paramiko.SSHClient()
#自动添加策略,保存服务器的主机名和密钥信息
client.set_missing_host_key_policy(paramiko.AutoAddPolicy())
#连接服务器
client.connect(hostname, port, username, password, compress=True)
#上传文件
sftp_client = client.open_sftp()
dstpath = "/usr/server"
stdin, stdout, stderr = client.exec_command('mkdir -p ' + dstpath)
print(stdout.readlines())
filepath = "."
filename = "server_monitor.py"
src = filepath = "." + filename
dst = dstpath+ filename
sftp_client.put(src,dst)
# 访问文件
remote_file = sftp_client.open("/home/verified_list.txt") #文件路径
try:
for line in remote_file:
print(line.strip())
finally:
remote_file.close()
# 执行命令
command = "python /usr/TeemoPrograms/CopyrightMonitor/monitors/server_monitor.py"
print(command)
stdin, stdout, stderr = client.exec_command(command)
time.sleep(3)
print(stdout.readlines())
# 通过invoke_shell交互式执行命令
channel = client.invoke_shell() # 在SSH server端创建一个交互式的shell
command = "python /usr/TeemoPrograms/CopyrightMonitor/Monitors/server_monitor.py"
channel.send(command + '\n')
time.sleep(15)
stdout = channel.recv(1024 * 100000)
out_list = stdout.decode().split("\n")
for line in out_list:
print(line)
client.close()
SFTPClient
SFTP客户端对象,实现远程文件操作,主要有from_transport、put、get、Mkdir、remove、rename、stat、listdir等方法。
- from_transport:从已通过验证的传输对象简历连接。
- put:上传本地文件到服务器上。
- get:从服务器下载文件到本地。
- Mkdir、remove、rename、stat、listdir:创建目录、删除目录、重命名文件或目录、获取文件信息、获取指定目录中的列表。
import paramiko
hostname = 192.168.0.1
port = 22
username = "root"
password = "root"
transport = paramiko.Transport((hostname, port))
transport.connect(username = username, password = password)
sftp = paramiko.SFTPClient.from_transport(transport)
# 下载文件
sftp.get("/home/share/video.mp4","./视频文件下载/")
#上传文件
sftp.put("./video.mp4","/home/share/video.mp4")
sftp.close()
相关模块
configparser
setproctitle
ansible
fabric
pexpect
salt-ssh