远程控制的快捷命令 内网远程桌面控制软件推荐

现在,如果我需要在Linux服务器上执行一系列命令(比如设置一个LNMP环境),我应该立即想到一个方法来编写一个Shell脚本,然后抛出并执行以下命令来查看结果。但是,我总是很懒,所以我

本文最后更新时间:  2023-02-26 20:04:22

现在,如果我需要在Linux服务器上执行一系列命令(比如设置一个LNMP环境),我应该立即想到一个方法来编写一个Shell脚本,然后抛出并执行以下命令来查看结果。

但是,我总是很懒,所以我不想执行Shell和重复一些命令。于是我想到有一种方法可以直接在服务器端本地执行脚本,想到异端。这个时候,一个科技大佬告诉我,有一个叫paramiko的Python库,打开了我新世界的大门。

对于paramiko安装direct pip或者PyCharm,这里就不多说了。如果你在这里看到你对python语法了解不多,你也不用担心。您可以使用paramiko简单地执行Shell命令来查看结果以及上传和下载文件,从而节省重复工作。

Paramiko实现了SSHv2协议(底层使用密码学),包括两个核心组件:SSHClient和SFTPClient。SSHClient是用于执行远程命令的SSH会话的封装,SFTPClient是用于远程文件操作的SFTP客户端的封装。

这里有两个例子,你应该知道如何使用它们。最后,正片开始。

ssh的列:

# -*- 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()

作为sftp的客户端对象,sftpCLient根据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() 列出服务器目录下的文件

最后,养成一个好的习惯,和客户一起收尾. close()。

温馨提示:内容均由网友自行发布提供,仅用于学习交流,如有版权问题,请联系我们。