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

如果现在需要在 Linux 服务器上执行一系列命令(比如搭建 LNMP 环境)我应该会第一时间想到想办法写个 Shell 脚本,然后扔上去执行以下看看结果。 2020-05-18 09:21:50 Linux脚本命令 为什么中国开发不出流行的操作系统和编程语言? 知乎有两个帖子很有意思,中国能不能写出操作系统?中国为什么没有自己的编程语言? 2020-05-18 09:07:30 编程语言开发操作系统 2020统信UOS新产品线上发布会成功召开 个人版争“鲜”体验 5月15日,统信软件成功举办了“同心·同行 2020统信UOS新产品线上发布会”。会上,统信UOS产品体系正式发布,包括:统信桌面操作系统,统信服务器操作系统,统信专用设备操作系统。 2020-05-17 22:27:52 统信UOS统信软件 如何在Linux中安装多个终端以及更改默认终端 虽说现在的Linux发行版,比如Ubuntu,CentOS等已经基本上可以采用GUI来完成绝大部分一般性的任务。但是,终端程序对于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. importparamiko
  3. client=paramiko.SSHClient()#实例化SSHClient
  4. client.set_missing_host_key_policy(paramiko.AutoAddPolicy())#自动添加策略,保存服务器的主机名和密钥信息,如果不添加,那么不再本地know_hosts文件中记录的主机将无法连接
  5. client.connect(hostname='192.168.23.134',port=22,username='ftoz',password='123456')#连接SSH服务端,以用户名和密码进行认证
  6. #打开一个Channel并执行命令
  7. stdin,stdout,stderr=client.exec_command('ls')#stdout为正确输出,stderr为错误输出,同时是有1个变量有值
  8. #打印执行结果
  9. print(stdout.read().decode('utf-8'))
  10. #关闭SSHClient
  11. 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=22,username='ftoz',password='123456')这里就是你的linux变量依次为地址、端口(总共65535个端口,不过ssh默认是22端口)、登录名、密码。
  4. stdin,stdout,stderr=client.exec_command('df-h')这里就是核心你需要做的shell命令,这三个变量不用按照这种姿势,你可以随意,不过按照顺序你知道里面装的什么数据就行(重点在输出和错误)。
  5. connect():这个是实现远程服务器连接和认证的,参数有:
  6. hostname连接的目标主机
  7. port=SSH_PORT指定端口
  8. username=None验证的用户名
  9. password=None验证的用户密码
  10. pkey=None私钥方式用于身份验证
  11. key_filename=None一个文件名或文件列表,指定私钥文件
  12. timeout=None可选的tcp连接超时时间
  13. allow_agent=True,是否允许连接到ssh代理,默认为True允许
  14. look_for_keys=True是否在~/.ssh中搜索私钥文件,默认为True允许
  15. compress=False,是否打开压缩。
  16. set_missing_host_key_policy():这个是设置远程服务器没有在know_hosts文件中记录时的应对策略。(可以理解为避免报错),参数有:
  17. AutoAddPolicy自动添加主机名及主机密钥到本地HostKeys对象,不依赖load_system_host_key的配置。即新建立ssh连接时不需要再输入yes或no进行确认
  18. WarningPolicy用于记录一个未知的主机密钥的python警告。并接受,功能上和AutoAddPolicy类似,但是会提示是新连接
  19. RejectPolicy自动拒绝未知的主机名和密钥,依赖load_system_host_key的配置。此为默认选项
  20. 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=None,confirm=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干货,欢迎关注!

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

©本文为清一色官方代发,观点仅代表作者本人,与清一色无关。清一色对文中陈述、观点判断保持中立,不对所包含内容的准确性、可靠性或完整性提供任何明示或暗示的保证。本文不作为投资理财建议,请读者仅作参考,并请自行承担全部责任。文中部分文字/图片/视频/音频等来源于网络,如侵犯到著作权人的权利,请与我们联系(微信/QQ:1074760229)。转载请注明出处:清一色财经

(0)
打赏 微信扫码打赏 微信扫码打赏 支付宝扫码打赏 支付宝扫码打赏
清一色的头像清一色管理团队
上一篇 2023年5月7日 23:25
下一篇 2023年5月7日 23:25

相关推荐

发表评论

登录后才能评论

联系我们

在线咨询:1643011589-QQbutton

手机:13798586780

QQ/微信:1074760229

QQ群:551893940

工作时间:工作日9:00-18:00,节假日休息

关注微信