python paramiko模块:远程连接服务器

1.  SFTP基于 用户名密码 登录服务器,实现上传下载:

import paramiko

transport = paramiko.Transport((‘hostname‘, 22))   # 生成trasport,配置主机名,端口
transport.connect(username=‘root‘,password=‘****‘)  # 登录名、密码

sftp = paramiko.SFTPClient.from_transport(transport)
# 将id_rsa 上传至服务器并重命名 /tmp/test.pysftp.put(‘id_rsa‘, ‘/tmp/ras.py‘) 
# ras.py 下载到本地 ras.pysftp.get(‘/tmp/ras.py‘, ‘ras.py‘) 
# 关闭连接
transport.close()

2. SFTP基于 密钥 登录服务器

import paramiko

private_key = paramiko.RSAKey.from_private_key_file(‘id_rsa‘) # id_rsa是本地的私钥,需要在服务器上配制公钥

transport = paramiko.Transport((‘hostname‘, 22))   # 配置主机名和端口
transport.connect(username=‘root‘, pkey=private_key)  # 连接root用户,使用密钥

sftp = paramiko.SFTPClient.from_transport(transport)
# 将local.py 上传至服务器 /tmp/test.py
sftp.put(‘/tmp/local.py‘, ‘/tmp/test.py‘)
# test.py 下载到本地 local.py
sftp.get(‘test.py‘, ‘local.py‘)

3. SSH基于 密钥 登录服务器

import paramiko

private_key = paramiko.RSAKey.from_private_key_file(‘id_rsa‘)

# 创建SSH对象
ssh = paramiko.SSHClient()
# 允许连接不存在在know_hosts文件里的主机
ssh.set_missing_host_key_policy(paramiko.AutoAddPolicy())
# 连接服务器
ssh.connect(hostname=‘hostname‘, port=22, username=‘root‘,pkey=private_key)

# 执行命令
stdin,stdout,stderr = ssh.exec_command(‘ls‘)
result = stdout.read()
print(result)

# 关闭连接
ssh.close()

4. SSH 封装 Transport 基于 密钥 登录服务器

import paramiko

private_key = paramiko.RSAKey.from_private_key_file(‘id_rsa‘) # id_rsa是本地私钥,需要服务器配置公钥
transport = paramiko.Transport((‘hostname‘, 22))
transport.connect(username=‘root‘,pkey=private_key)
# 创建SSH对象
ssh = paramiko.SSHClient()
ssh._transport = transport
# 执行命令
stdin,stdout,stderr = ssh.exec_command(‘ls‘)
result = stdout.read()
print(result)

# 关闭连接
transport.close()

5. SSH 基于 用户名密码 登录服务器

# SSHClient 基于用户名和密码连接服务器
import paramiko

# 创建SSH对象
ssh = paramiko.SSHClient()
# 允许连接不在know_hosts文件中的主机
ssh.set_missing_host_key_policy(paramiko.AutoAddPolicy())
# 连接服务器
ssh.connect(hostname=‘hostname‘, port=22, username=‘root‘, password=‘****‘)

# 执行命令
stdin, stdout, stderr = ssh.exec_command(‘ls‘)
# 获取命令结果
result1 = stdout.read()
result2 = stderr.read()
print(result1,result2,sep=‘\n‘)
# 关闭连接
ssh.close()

print(f‘{"SSH封装Transport":=^50}‘)

# SSHClient 封装 Transport,基于用户名和密码连接服务器

import paramiko

transport = paramiko.Transport((‘hostname‘, 22))
transport.connect(username=‘root‘, password=‘****‘)

ssh = paramiko.SSHClient()
ssh._transport = transport

stdin, stdout, stderr = ssh.exec_command(‘ls‘)
print (stdout.read())

transport.close()

原文地址:https://www.cnblogs.com/wztshine/p/11964321.html

时间: 2024-10-08 00:02:24

python paramiko模块:远程连接服务器的相关文章

python paramiko模块远程执行多条命令

最近一直在用python的paramiko执行远程命令,发现如果直接写的话在每条命令后加分号执行时会报错,如果不加分号,分一条命令一条命令地执行,起不到作用,如切换路径等,后面在网上找到了相关的方法,只要在exec_command(cmd,get_pty=True)在命令语句后加get_pty=True即可.代码如下: def exec_command(self,cmd): client = paramiko.SSHClient() try: client.set_missing_host_ke

python Paramiko模块远程推送文件

#!/usr/bin/python import paramiko def push_file(file):     f = open(file,'r')     running = 1     while running:         line = f.readline()         if line != '':             line = line.strip('\n')             list = line.split(' ')             ip 

paramiko 模块远程管理 liunx 服务器

paramiko是用python语言写的一个模块,遵循SSH2协议,支持以加密和认证的方式,进行远程服务器的连接. 由于使用的是python这样的能够跨平台运行的语言,所以所有python支持的平台,如Linux, Solaris, BSD, MacOS X, Windows等,paramiko都可以支持,因此,如果需要使用SSH从一个平台连接到另外一个平台,进行一系列的操作时,paramiko是最佳工具之一. 一.远程连接服务器 方式1 import  paramiko #实例化客户端 ssh

python paramiko模块简介

一:简介 paramiko是用python语言写的一个模块,遵循SSH2协议,支持以加密和认证的方式,进行远程服务器的连接. 由于使用的是python这样的能够跨平台运行的语言,所以所有python支持的平台,如Linux, Solaris, BSD, MacOS X, Windows等,paramiko都可以支持,因此,如果需要使用SSH从一个平台连接到另外一个平台,进行一系列的操作时,paramiko是最佳工具之一. 举个常见的例子,现有这样的需求:需要使用windows客户端,远程连接到L

Python Paramiko模块安装和使用

1.简介 大家会发现,常见的解决方法都会需要对远程服务器必要的配置,如果远程服务器只有一两台还好说,如果有N台,还需要逐台进行配置,或者需要使用代码进行以上操作时,上面的办法就不太方便了. 使用paramiko可以很好的解决以上问题,比起前面的方法,它仅需要在本地上安装相应的软件(python以及PyCrypto),对远程服务器没有配置要求,对于连接多台服务器,进行复杂的连接操作特别有帮助. 2.安装 安装paramiko有两个先决条件,python和另外一个名为PyCrypto的模块. 通常安

fb远程连接服务器调试,碉堡了

开发中经常碰到本地代码没问题,上传到服务器上就有有问题, 这个时候调试变的很麻烦,放个textField自己保存日志这种方式调试的都是. 今天刚学了远程连接服务器,adobe真是牛逼坏了啊. 新增一个web应用程序,使用默认值对勾取消,输入http:// f11调试,跟本地调试一样,日志也会打印到fb的控制台上.

远程连接服务器---SSH详解

对于系统管理员来说,远程连接服务器是一个很有用的操作,它使得服务器管理变得更加方便. 下面我就来科普一下有关远程连接服务器的知识: 目前,远程连接服务器的类型有以下几种: ① 文字接口的明文传输:Telnet.RSH为主,很少用到. ② 文字接口的加密传输:以SSH为主,已经取代了上面的明文传输方式. ③ 图形接口:XDMCP.VNC.XRDP等较为常见. 这篇文章只为实战,不为普及概念性知识.所以我只讲解在工作中最常用到的技术SSH.关于SFTP技术和VNC技术,请查阅我的其他博客. 好,先来

Atom远程连接服务器报错服务器版本和客户端版本不一致

Atom远程连接服务器 报错信息: Server version is different than client version Original error message: Version mismatch. Client at 139 while server at 141. 在setting里check for update 一下,然后重启编辑器!!!重启

CRT远程连接服务器字符输出乱码解决一例

环境: 服务器:Centos 6.2 远端:win 7 CRT版本:7.1.1 现象回顾: 1.服务器端:中文字符显示正常,如下: 2.CRT连接,出现乱码,如下图所示: 3.对CRT设置调整,如下: Options -> Session Options -> Appearance -> Font -> 新宋体 ->  字符集:中文GB2312 -> Character encoding:UTF-8 4.修改后重新执行操作,如下图所示: ****************

12.11-xshell远程连接服务器以及故障排查

12.11 xshell远程连接服务器以及故障排查 内容: 1)centos 网络配置(setup) 2)Xshell的优化 3)Xshell远程连接服务器 (1)Windows中关于vmware  相关服务要运行(共5个服务) (2)Vmware 网络配置 子网IP 10.0.0.0 4)xshell远程连接排错 5)VMware三种网络模式 1.Centos网络配置 1. 临时 Setup------network configuration ------device configurati