远程快捷键命令 远程控制的快捷键



文章插图
远程快捷键命令 远程控制的快捷键

文章插图
如果现在需要在 Linux 服务器上执行一系列命令(比如搭建 LNMP 环境)我应该会第一时间想到想办法写个 Shell 脚本 , 然后扔上去执行以下看看结果 。
【远程快捷键命令 远程控制的快捷键】然而一贯懒惰的我并不想这么去执行 Shell 和一些重复命令 。所以俺寻思可以有个方法本地直接在服务器端执行脚本 , 寻思生异端 , 这时候有某大技霸告诉我有个叫 paramiko 的 Python 库 , 从此开启我新世界的大门 。
对于 paramiko 安装直接 pip 或者 PyCharm 这里就不多说了 , 如果看到这里你觉得自己不怎么了解python语法的也不必担心 , 你完全可以用 paramiko 单纯的执行 Shell 命令查看结果和上传下载文件 , 省去重复的工作 。
paramiko 实现了 SSHv2 协议(底层使用 cryptography ) , 包含两个核心组件:SSHClient 和 SFTPClient。SSHClient 是对 SSH 会话的封装 , 用于执行远程命令 , SFTPClient 是对 SFTP 客户端的封装 , 用以实现远程文件操作 。
这里先举两个列子你应该就明白怎么用了 , 终于开始正片了 。
SSHClient 的列子:
# -*- coding: utf-8 -*-import paramikoclient = paramiko.SSHClient()# 实例化SSHClientclient.set_missing_host_key_policy(paramiko.AutoAddPolicy())# 自动添加策略 , 保存服务器的主机名和密钥信息 , 如果不添加 , 那么不再本地know_hosts文件中记录的主机将无法连接client.connect(hostname='192.168.23.134', port=22, username='ftoz', password='123456')# 连接SSH服务端 , 以用户名和密码进行认证# 打开一个Channel并执行命令stdin, stdout, stderr = client.exec_command('ls')# stdout 为正确输出 , stderr为错误输出 , 同时是有1个变量有值# 打印执行结果print(stdout.read().decode('utf-8'))# 关闭SSHClientclient.close()输出:
这里说明一下:
client = paramiko.SSHClient() , client.set_missing_host_key_policy(paramiko.AutoAddPolicy())你可以理解为固定姿势 。client.connect(hostname='192.168.1.105', port=22, username='ftoz',password='123456')这里就是你的linux变量依次为地址、端口(总共65535个端口 , 不过ssh默认是22端口)、登录名、密码 。stdin, stdout, stderr = client.exec_command('df -h ')这里就是核心你需要做的shell命令 , 这三个变量不用按照这种姿势 , 你可以随意 , 不过按照顺序你知道里面装的什么数据就行(重点在输出和错误) 。connect():这个是实现远程服务器连接和认证的 , 参数有:hostname 连接的目标主机port=SSH_PORT 指定端口username=None 验证的用户名password=None 验证的用户密码pkey=None 私钥方式用于身份验证key_filename=None 一个文件名或文件列表 , 指定私钥文件timeout=None 可选的tcp连接超时时间allow_agent=True, 是否允许连接到ssh代理 , 默认为True 允许look_for_keys=True 是否在~/.ssh中搜索私钥文件 , 默认为True 允许compress=False, 是否打开压缩 。set_missing_host_key_policy():这个是设置远程服务器没有在know_hosts文件中记录时的应对策略 。(可以理解为避免报错) , 参数有:AutoAddPolicy 自动添加主机名及主机密钥到本地HostKeys对象 , 不依赖load_system_host_key的配置 。即新建立ssh连接时不需要再输入yes或no进行确认WarningPolicy 用于记录一个未知的主机密钥的python警告 。并接受 , 功能上和AutoAddPolicy类似 , 但是会提示是新连接RejectPolicy 自动拒绝未知的主机名和密钥 , 依赖load_system_host_key的配置 。此为默认选项exec_command():这是写你需要执行的命令的接下来你就可以拿出输出做一些该干嘛(ke)干嘛(pa)的事情了 , 这里先举这个简单的列子 。
2020 精选 阿里/腾讯等一线大厂 面试、简历、进阶、电子书 私聊我回复「资料」免费获取
SFTPClient 常用方法:
t = paramiko.Transport(('192.168.23.134', 22))# 获取Transport实例t.connect(username='ftoz', password='123456')# 连接SSH服务端 , 使用passwordsftp = paramiko.SFTPClient.from_transport(t)sftp.put("F:S12312.txt","/home/ftoz/zxc12312.txt")#执行上传动作sftp.get("/home/ftoz/zxc12312.txt", "F:S12312.txt")#执行下载动作t.close()SFTPCLient 作为一个 sftp 的客户端对象 , 根据 ssh 传输协议的 sftp 会话 , 实现远程文件操作 , 如上传、下载、权限、状态
from_transport(cls,t) 创建一个已连通的SFTP客户端通道put(localpath, remotepath, callback=None, confirm=True) 将本地文件上传到服务器 参数confirm:是否调用stat()方法检查文件状态 , 返回ls -l的结果get(remotepath, localpath, callback=None) 从服务器下载文件到本地mkdir() 在服务器上创建目录remove() 在服务器上删除目录rename() 在服务器上重命名目录stat() 查看服务器文件状态listdir() 列出服务器目录下的文件最后养成随关闭的好习惯 client.close() 。