Python paramik
本节内容
paramiko模块
1.paramiko模块
Python的paramiko模块,该模块机遇SSH用于连接远程服务器并执行相关操作
Python的paramiko模块,该模块机遇SSH用于连接远程服务器并执行相关操作
1.1 基于用户名密码连接
一下的代码中所有的输出是基于windows来输出的,编码方式为‘gbk’.
- #!/usr/bin/env python
- # -*- coding:utf-8 -*-
- import paramiko
- # 创建ssh对象
- ssh= paramiko.SSHClient()
- # 允许连接不在know_hosts文件中的主机
- ssh.set_missing_host_key_policy(paramiko.AutoAddPolicy())
- # 连接服务器
- ssh.connect(hostname='192.168.111.128',port=22,username='root',password='123456')
- comm = input(":>>")
- while comm != 'q':
- comm = input(":>>")
- # 执行命令
- stdin, stdout, stderr = ssh.exec_command(comm)
- err = stderr.read()
- if err:
- result = err
- else:
- result = stdout.read()
- print(result.decode('gbk'))
- ssh.close()
- #!/usr/bin/env python
- # -*- coding:utf-8 -*-
- import paramiko
- transport = paramiko.Transport(('192.168.111.128',22))
- transport.connect(username='root',password='')
- ssh = paramiko.SSHClient()
- ssh._transport = transport
- comm = input(":>>")
- while comm != 'q':
- stdin,stdout,stderr = ssh.exec_command(comm)
- err = stderr.read()
- if err:
- re_msg = err
- else:
- re_msg = stdout.read()
- print(re_msg.decode('gbk'))
- comm = input(":>>")
基于Transport的连接
1.2 基于秘钥文件连接
- #!/usr/bin/env python
- # -*- coding:utf-8 -*-
- import paramiko
- def para(filepath,hostname,port,username):
- private_key = paramiko.RSAKey.from_private_key_file(filepath)
- ssh = paramiko.SSHClient()
- ssh.set_missing_host_key_policy(paramiko.AutoAddPolicy())
- ssh.connect(hostname=hostname,port=port,username=username,pkey=private_key)
- comm = input(":>>")
- stdin,stdout,stderr = ssh.exec_command(comm)
- err = stderr.read()
- if err:
- re_msg = err
- else:
- re_msg = stdout.read()
- return re_msg
- if __name__ == '__main__':
- filepath = r'id_rsa_2048'
- a = para(filepath,'192.168.111.128',22,'root')
- print(a.decode('gbk'))
- #!/usr/bin/env python
- # -*- coding:utf-8 -*-
- import paramiko
- pkeyfile = paramiko.RSAKey.from_private_key_file(r'id_rsa_2048')
- transport = paramiko.Transport(('192.168.111.128',22))
- transport.connect(username='root',pkey=pkeyfile)
- ssh = paramiko.SSHClient()
- ssh.set_missing_host_key_policy(paramiko.AutoAddPolicy())
- ssh._transport = transport
- comm = input(":>>")
- while comm != 'q':
- stdin,stdout,stderr = ssh.exec_command(comm)
- err = stderr.read()
- if err:
- re_msg = err
- else:
- re_msg = stdout.read()
- print(re_msg.decode('gbk'))
- comm = input(":>>")
基于transport的秘钥文件连接
1.3 基于秘钥字符串的连接
- #!/usr/bin/env python
- # -*- coding:utf-8 -*-
- import paramiko
- from io import StringIO
- # 秘钥以省略
- key_str = '''XXXXXXXXXXXX'''
- pkey_str = paramiko.RSAKey(file_obj=StringIO(key_str))
- ssh = paramiko.SSHClient()
- ssh.set_missing_host_key_policy(paramiko.AutoAddPolicy())
- ssh.connect(hostname='192.168.111.128',port=22,username='root',pkey=pkey_str)
- comm = input(":>>")
- while comm != 'q':
- stdin,stdout,stderr = ssh.exec_command(comm)
- if stderr.read():
- print(stderr.read().decode('gbk'))
- else:
- print(stdout.read().decode('gbk'))
- comm = input(":>>")
- #!/usr/bin/env python
- # -*- coding:utf-8 -*-
- import paramiko
- from io import StringIO
- key_str = '''XXXXXXXXXXXX'''
- pkey_str = paramiko.RSAKey(file_obj=StringIO(key_str))
- transport = paramiko.Transport(('192.168.111.128',22))
- transport.connect(username='root',pkey=pkey_str)
- ssh = paramiko.SSHClient()
- ssh.set_missing_host_key_policy(paramiko.AutoAddPolicy())
- ssh._transport = transport
- comm = input(":>>")
- while comm != 'q':
- stdin,stdout,stderr = ssh.exec_command(comm)
- if stderr.read():
- print(stderr.read().decode('gbk'))
- else:
- print(stdout.read().decode('gbk'))
- comm = input(":>>")
基于transport的秘钥串连接
1.4 文件上传和下载
- #!/usr/bin/env python
- # -*- coding:utf-8 -*-
- # 上传
- import paramiko
- transport = paramiko.Transport(('192.168.111.128',22))
- transport.connect(username='root',password='')
- helei = paramiko.SFTPClient.from_transport(transport)
- localpath = r'C:\Users\user\Desktop\123.txt'
- remotepath = r'/tmp/helei.hahaha'
- helei.put(localpath,remotepath)
- transport.close()
- # 下载
- import paramiko
- transport = paramiko.Transport(('192.168.111.128',22))
- transport.connect(username='root',password='')
- sftp = paramiko.SFTPClient.from_transport(transport)
- localpath = r'C:\Users\user\Desktop\123.txt'
- remotepath = r'/helei.haha'
- sftp.get(localpath,remotepath)
- transport.close()
上传和下载
Python paramik的更多相关文章
- Python的paramiko,实现ssh
最简单的使用paramiko登录远程机器执行一些命令,学习实验楼的paramiko记录下来,第一次使用ConfigParser这个库,对于封装这些还是不太熟悉,只能慢慢来,嘿嘿嘿 这是python脚本 ...
- Python中的多进程与多线程(一)
一.背景 最近在Azkaban的测试工作中,需要在测试环境下模拟线上的调度场景进行稳定性测试.故而重操python旧业,通过python编写脚本来构造类似线上的调度场景.在脚本编写过程中,碰到这样一个 ...
- Python高手之路【六】python基础之字符串格式化
Python的字符串格式化有两种方式: 百分号方式.format方式 百分号的方式相对来说比较老,而format方式则是比较先进的方式,企图替换古老的方式,目前两者并存.[PEP-3101] This ...
- Python 小而美的函数
python提供了一些有趣且实用的函数,如any all zip,这些函数能够大幅简化我们得代码,可以更优雅的处理可迭代的对象,同时使用的时候也得注意一些情况 any any(iterable) ...
- JavaScript之父Brendan Eich,Clojure 创建者Rich Hickey,Python创建者Van Rossum等编程大牛对程序员的职业建议
软件开发是现时很火的职业.据美国劳动局发布的一项统计数据显示,从2014年至2024年,美国就业市场对开发人员的需求量将增长17%,而这个增长率比起所有职业的平均需求量高出了7%.很多人年轻人会选择编 ...
- 可爱的豆子——使用Beans思想让Python代码更易维护
title: 可爱的豆子--使用Beans思想让Python代码更易维护 toc: false comments: true date: 2016-06-19 21:43:33 tags: [Pyth ...
- 使用Python保存屏幕截图(不使用PIL)
起因 在极客学院讲授<使用Python编写远程控制程序>的课程中,涉及到查看被控制电脑屏幕截图的功能. 如果使用PIL,这个需求只需要三行代码: from PIL import Image ...
- Python编码记录
字节流和字符串 当使用Python定义一个字符串时,实际会存储一个字节串: "abc"--[97][98][99] python2.x默认会把所有的字符串当做ASCII码来对待,但 ...
- Apache执行Python脚本
由于经常需要到服务器上执行些命令,有些命令懒得敲,就准备写点脚本直接浏览器调用就好了,比如这样: 因为线上有现成的Apache,就直接放它里面了,当然访问安全要设置,我似乎别的随笔里写了安全问题,这里 ...
随机推荐
- Struts2之Struts2的标签库
前言: Struts2提供了大量的标签 ,用来帮助开发表现层页面,这些表现一方面解决了美观性的需求,因为它们具有html标签一样的外观,另一方面它们解决了功能性的需求, 因为它们具有jsp脚本一样的逻 ...
- bzoj千题计划280:bzoj4592: [Shoi2015]脑洞治疗仪
http://www.lydsy.com/JudgeOnline/problem.php?id=4592 注意操作1 先挖再补,就是补的范围可以包含挖的范围 SHOI2015 的题 略水啊(逃) #i ...
- 使用caffe训练mnist数据集 - caffe教程实战(一)
个人认为学习一个陌生的框架,最好从例子开始,所以我们也从一个例子开始. 学习本教程之前,你需要首先对卷积神经网络算法原理有些了解,而且安装好了caffe 卷积神经网络原理参考:http://cs231 ...
- js判断操作系统windows,ios,android(笔记)
使用JS判断用户使用的系统是利用浏览器的userAgent. navigator.userAgent:userAgent 获取了浏览器用于 HTTP 请求的用户代理头的值. navigator.pla ...
- token 验证
组件: https://jwt.io/#libraries-io
- VMware虚拟机,从厚置备改成精简置备,并减小硬盘的实际占用空间
工作中由于前期规划不足,导致磁盘空间分配较大,而且是厚置备.后期不再需要时,无法把用不到的空间释放出来,造成空间浪费.经过摸索和实验验证,总结出来一套方法. 风险提示:这个方法在我的环境中验证通过了, ...
- "双非"应届生校招如何获得大厂青睐?(内附技术岗超全求职攻略)
写在前面的话 笔者从17年的2月份开始准备春招,其中遇到不少坑,也意识到自己走过的弯路.故写了这篇文章总结一番,本文适合主动学习的,对自己要学的课程不明确的,对面试有恐惧症的...等将来打算从事技术岗 ...
- 以太坊挖矿源码:clique算法
上文我们总结了以太坊最主要的共识算法:ethash算法,本文将重点分析以太坊的另一个共识算法:clique. 关键字:clique,共识算法,puppeth,以太坊地址原理,区块校验,认证结点,POA ...
- OAuth2.0学习(1-12)开源的OAuth2.0项目和比较
OAuth2.0学习(2-1)OAuth的开源项目 1.开源项目列表 http://www.oschina.net/project/tag/307/oauth?lang=19&sort=t ...
- C# Bootstrap table之 分页
效果如图: 一.声明talbe <div class="container"> <table id="table" class="t ...