paramiko是一个SSHv2协议的python实现,提供客户端和服务器的功能。paramiko可以通过ssh协议执行远程主机的程序或脚本,获取输出结果和返回值,使用起来简介优雅。
安装方式:pip3 install paramiko
环境:
客户端:win10
服务端:linux服务器,ip:192.168.41.222
paramiko有两个核心模块:SSHClient和SFTPClient
SSHClient:通过ssh协议和linux服务器建立连接执行命令,该类封装了传输(Transport),通道(Channel)及SFTPClient建立的方法(open_sftp)
SFTPClient:作用类似与Linux的sftp命令,是对SFTP客户端的封装,用以实现远程文件操作,如文件上传、下载、修改文件权限等操作。
Channel:是一种类Socket,一种安全的SSH传输通道;
Transport:是一种加密的会话,使用时会同步创建了一个加密的Tunnels(通道),这个Tunnels叫做Channel;
Session:是client与Server保持连接的对象,用connect()
/
start_client()
/
start_server()开始会话。
1. SSHClient方式连接服务器
功能:初始化一个SSHClient类的实例,调用connect连接服务器,调用exec_command方法执行命令:echo `date` && df -hl,关闭连接
代码实现:
import paramiko
# 建立一个sshclient对象
ssh = paramiko.SSHClient()
# 将信任的主机自动加入到host_allow列表,须放在connect方法前面
ssh.set_missing_host_key_policy(paramiko.AutoAddPolicy())
# 调用connect方法连接服务器
ssh.connect(hostname="192.168.41.222", port=22, username="root", password="root")
# 执行命令
stdin, stdout, stderr = ssh.exec_command("echo `date` && df -hl")
# 结果放到stdout中,如果有错误将放到stderr中
print(stdout.read().decode('utf-8'))
# recv_exit_status方法会一直阻塞直到命令执行完成
returncode = stdout.channel.recv_exit_status()
print("returncode:",returncode)
# 关闭连接
ssh.close()
输出:
Thu Apr 29 22:07:24 CST 2021
Filesystem Size Used Avail Use% Mounted on
devtmpfs 1.9G 0 1.9G 0% /dev
tmpfs 1.9G 0 1.9G 0% /dev/shm
tmpfs 1.9G 12M 1.9G 1% /run
tmpfs 1.9G 0 1.9G 0% /sys/fs/cgroup
/dev/mapper/centos-root 20G 13G 7.5G 63% /
/dev/sda1 197M 129M 69M 66% /boot
tmpfs 378M 0 378M 0% /run/user/0
returncode: 0
recv_exit_status()方法说明:用来判断命令是否执行完成,当exec_command命令没有执行完成时,这个方法会一直阻塞。如果exec_command运行结束,则会返回0表示执行成功。-1表示执行失败。
SSHClient 封装 Transport
代码实现:
import paramiko
# 创建一个通道
transport = paramiko.Transport(('196.168.41.222', 22))
transport.connect(username='root', password='root')
ssh = paramiko.SSHClient()
ssh._transport = transport
stdin, stdout, stderr = ssh.exec_command('df -h')
print(stdout.read().decode('utf-8'))
transport.close()
2. SFTPClient方式登录并实现上传与下载
功能描述:从win10主机上传文件01.txt到远程服务器上
代码实现:
import paramiko
trans = paramiko.Transport(('192.168.41.222', 22))
# 建立连接,指定SSHClient的_transport
trans.connect(username='root', password='root')
ssh = paramiko.SSHClient()
ssh._transport = trans
# 执行命令,和传统方法一样
stdin, stdout, stderr = ssh.exec_command('echo `date` && df -hl')
print(stdout.read().decode('utf-8'))
# 实例化一个 sftp对象,指定连接的通道
sftp = paramiko.SFTPClient.from_transport(trans)
#或者调用ope_sftp()方法
#sftp = ssh_client.open_sftp()
# 发送文件
sftp.put(localpath='./01.txt',
remotepath='/tmp/01.txt')
# 下载文件
# sftp.get(localpath='./01.txt',
# remotepath='/tmp/01.txt')
stdin, stdout, stderr = ssh.exec_command('ls -ltr /tmp')
print(stdout.read().decode('utf-8'))
# 关闭连接
trans.close()
输出:
Thu Apr 29 22:13:43 CST 2021
Filesystem Size Used Avail Use% Mounted on
devtmpfs 1.9G 0 1.9G 0% /dev
tmpfs 1.9G 0 1.9G 0% /dev/shm
tmpfs 1.9G 12M 1.9G 1% /run
tmpfs 1.9G 0 1.9G 0% /sys/fs/cgroup
/dev/mapper/centos-root 20G 13G 7.5G 63% /
/dev/sda1 197M 129M 69M 66% /boot
tmpfs 378M 0 378M 0% /run/user/0
total 4
drwx------ 2 root root 6 Apr 21 23:06 vmware-root_1089-4013330115
drwx------ 2 root root 6 Apr 29 21:23 vmware-root_1090-2688554143
-rw-r--r-- 1 root root 3 Apr 29 22:13 01.txt