大技霸教你远程执行Linux脚本和命令

系统 Linux
如果现在需要在 Linux 服务器上执行一系列命令(比如搭建 LNMP 环境)我应该会第一时间想到想办法写个 Shell 脚本,然后扔上去执行以下看看结果。

如果现在需要在 Linux 服务器上执行一系列命令(比如搭建 LNMP 环境)我应该会第一时间想到想办法写个 Shell 脚本,然后扔上去执行以下看看结果。

然而一贯懒惰的我并不想这么去执行 Shell 和一些重复命令。所以俺寻思可以有个方法本地直接在服务器端执行脚本,寻思生异端,这时候有某大技霸告诉我有个叫 paramiko 的 Python 库,从此开启我新世界的大门。

[[326410]]

对于 paramiko 安装直接 pip 或者 PyCharm 这里就不多说了,如果看到这里你觉得自己不怎么了解python语法的也不必担心,你完全可以用 paramiko 单纯的执行 Shell 命令查看结果和上传下载文件,省去重复的工作。

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

这里先举两个列子你应该就明白怎么用了,终于开始正片了。

[[326411]]

SSHClient 的列子:

  1. # -*- coding: utf-8 -*- 
  2. import paramiko 
  3. client = paramiko.SSHClient()# 实例化SSHClient 
  4. client.set_missing_host_key_policy(paramiko.AutoAddPolicy())# 自动添加策略,保存服务器的主机名和密钥信息,如果不添加,那么不再本地know_hosts文件中记录的主机将无法连接 
  5.  
  6. client.connect(hostname='192.168.23.134'port=22username='ftoz'password='123456')# 连接SSH服务端,以用户名和密码进行认证 
  7.  
  8. # 打开一个Channel并执行命令 
  9. stdin, stdout, stderr = client.exec_command('ls')  # stdout 为正确输出,stderr为错误输出,同时是有1个变量有值 
  10.  
  11. # 打印执行结果 
  12. print(stdout.read().decode('utf-8')) 
  13.  
  14. # 关闭SSHClient 
  15. client.close() 

输出:

大技霸教你远程执行Linux脚本和命令

这里说明一下:

  1. client = paramiko.SSHClient(), 
  2. client.set_missing_host_key_policy(paramiko.AutoAddPolicy())你可以理解为固定姿势。 
  3. client.connect(hostname='192.168.1.105'port=22username='ftoz',password='123456')这里就是你的linux变量依次为地址、端口(总共65535个端口,不过ssh默认是22端口)、登录名、密码。 
  4. stdin, stdout, stderr = client.exec_command('df -h ') 这里就是核心你需要做的shell命令,这三个变量不用按照这种姿势,你可以随意,不过按照顺序你知道里面装的什么数据就行(重点在输出和错误)。 
  5.  
  6. connect():这个是实现远程服务器连接和认证的,参数有: 
  7. hostname 连接的目标主机 
  8. port=SSH_PORT 指定端口 
  9. username=None 验证的用户名 
  10. password=None 验证的用户密码 
  11. pkey=None 私钥方式用于身份验证 
  12. key_filename=None 一个文件名或文件列表,指定私钥文件 
  13. timeout=None 可选的tcp连接超时时间 
  14. allow_agent=True, 是否允许连接到ssh代理,默认为True 允许 
  15. look_for_keys=True 是否在~/.ssh中搜索私钥文件,默认为True 允许 
  16. compress=False, 是否打开压缩。 
  17.  
  18. set_missing_host_key_policy():这个是设置远程服务器没有在know_hosts文件中记录时的应对策略。(可以理解为避免报错),参数有: 
  19. AutoAddPolicy 自动添加主机名及主机密钥到本地HostKeys对象,不依赖load_system_host_key的配置。即新建立ssh连接时不需要再输入yes或no进行确认 
  20. WarningPolicy 用于记录一个未知的主机密钥的python警告。并接受,功能上和AutoAddPolicy类似,但是会提示是新连接 
  21. RejectPolicy 自动拒绝未知的主机名和密钥,依赖load_system_host_key的配置。此为默认选项 
  22. exec_command():这是写你需要执行的命令的 

接下来你就可以拿出输出做一些该干嘛(ke)干嘛(pa)的事情了,这里先举这个简单的列子。

SFTPClient 常用方法:

  1. t = paramiko.Transport(('192.168.23.134', 22))# 获取Transport实例 
  2. t.connect(username='ftoz'password='123456')# 连接SSH服务端,使用password 
  3. sftp = paramiko.SFTPClient.from_transport(t) 
  4. sftp.put("F:\S12312.txt","/home/ftoz/zxc12312.txt")#执行上传动作 
  5. sftp.get("/home/ftoz/zxc12312.txt", "F:\S12312.txt")#执行下载动作 
  6. t.close() 

SFTPCLient 作为一个 sftp 的客户端对象,根据 ssh 传输协议的 sftp 会话,实现远程文件操作,如上传、下载、权限、状态

  1. from_transport(cls,t) 创建一个已连通的SFTP客户端通道 
  2. put(localpath, remotepath, callback=Noneconfirm=True) 将本地文件上传到服务器 参数confirm:是否调用stat()方法检查文件状态,返回ls -l的结果 
  3. get(remotepath, localpath, callback=None) 从服务器下载文件到本地 
  4. mkdir() 在服务器上创建目录 
  5. remove() 在服务器上删除目录 
  6. rename() 在服务器上重命名目录 
  7. stat() 查看服务器文件状态 
  8. listdir() 列出服务器目录下的文件 

最后养成随关闭的好习惯 client.close()。

本文授权转载自公众号「良许Linux」。良许,世界500强外企Linux开发工程师,公众号里分享大量Linux干货,欢迎关注!

 

责任编辑:赵宁宁 来源: 今日头条
相关推荐

2012-05-08 11:11:43

Linuxcrontab命令

2022-11-18 08:55:33

2024-01-26 07:58:09

2022-08-16 14:47:08

服务器端Web端脚本

2017-12-11 09:34:40

Linux启动或重启命令与脚本

2017-03-10 10:37:16

Linux命令脚本

2017-11-29 18:31:27

Linux命令

2010-07-15 14:54:51

at命令crontab定时执行任务

2021-06-04 13:07:53

LinuxPythonXshell

2014-09-26 15:41:51

2020-11-06 07:42:01

Linux命令脚本

2014-10-30 14:02:26

LinuxFTP漏洞

2014-07-25 14:20:45

Linux脚本

2009-06-24 10:44:08

2021-03-11 14:28:11

bugLinux内核

2021-03-18 09:52:05

bugLinux内核

2013-12-20 10:36:56

2019-07-22 15:35:22

数据平台架构

2011-07-21 13:10:59

2010-02-04 14:42:51

Linux mysql
点赞
收藏

51CTO技术栈公众号