python使用paramiko 模块建立ssh通讯

一 paramiko简介

下文是我从别人博客那里copy下来的:

paramiko是用python语言写的一个模块,遵循SSH2协议,支持以加密和认证的方式,进行远程服务器的连接。

由于使用的是python这样的能够跨平台运行的语言,所以所有python支持的平台,如Linux, Solaris, BSD, MacOS
X, Windows等,paramiko都可以支持,因此,如果需要使用SSH从一个平台连接到另外一个平台,进行一系列的操作时,paramiko是最佳工具之一。

简单来说,paramiko就是用来建立ssh通讯的。

二 安装paramiko

一开始我使用linuxmint的软件源安装的,之后的程序出现了传参数错误,事实证明这是个大坑,必须要通过编译的方式安装。

1、paramiko的下载地址是https://github.com/paramiko/paramiko/releases,下载最新版本

2、用sudo apt-get –purge remove python-paramiko彻底清除旧版本的paramiko,没安装过旧版的童鞋跳过此步骤

3、进入解压好的paramiko路径并使用sudo python setup.py install来安装paramiko

三 paramiko的使用方法

client = SSHClient() #创建ssh客户端对象
client.load_system_host_keys() #从系统文件里加载密钥
client.set_missing_host_key_policy(paramiko.AutoAddPolicy()) #设置没有密钥
client.connect('ssh.example.com') #连接到指定服务器
stdin, stdout, stderr = client.exec_command('ls -l') #执行命令

四 简单的ssh通讯脚本

#!/usr/bin/env python

import paramiko
import sys,os

host = sys.argv[1]
user = 'root'
password = 'XXXXXX'

cmd=sys.argv[2]

s=paramiko.SSHClient()
s.load_system_host_keys()
s.set_missing_host_key_policy(paramiko.AutoAddPolicy())

s.connect(host,22,user,password,timeout=5)
stdin,stdout,stderr = s.exec_command(cmd)

cmd_result = stdout.read(),stderr.read()

for line in cmd_result:
    print line

s.close()

五 执行脚本

$ python ssh.py 172.18.55.2 df
Filesystem     1K-blocks      Used Available Use% Mounted on
udev             1956012         0   1956012   0% /dev
tmpfs             395484      6612    388872   2% /run
/dev/sda2       19091584  10027836   8070880  56% /
tmpfs            1977412     42968   1934444   3% /dev/shm
tmpfs               5120         4      5116   1% /run/lock
tmpfs            1977412         0   1977412   0% /sys/fs/cgroup
tmpfs             262144     16240    245904   7% /tmp
/dev/sda1       94371836  46849248  47522588  50% /media/sda1
/dev/sdb1      976759804 837472068 139287736  86% /media/STORE
cgmfs                100         0       100   0% /run/cgmanager/fs
tmpfs             395484        56    395428   1% /run/user/1000
tmpfs             395484         4    395480   1% /run/user/0


原创文章,作者:realmaster,如若转载,请注明出处:http://www.178linux.com/70658

(0)
realmasterrealmaster
上一篇 2017-03-06 23:20
下一篇 2017-03-07 11:08

相关推荐

  • 配置Nginx作为反向代理服务器

    配置Nginx作为反向代理服务器      一、nginx作为反向代理的工作模型: 1、nginx作为反向代理的工作模型       nginx工作在应用层,其能理解并可以提取出http请求报文中的首部信息中的请求方法、url、http协议版本等信息。   &…

    Linux干货 2016-10-29
  • 程序包管理之制作yum本地源

    Yum(全称为 Yellow dog Updater, Modified)是一个在Fedora和RedHat以及CentOS中的Shell前端软件包管理器。基于RPM包管理,能够从指定的服务器自动下载RPM包并且安装,可以自动处理依赖性关系,并且一次安装所有依赖的软件包,无须繁琐地一次次下载、安装。 使用本地yum源有两种方式:第一直接使用光盘镜像,不过此方…

    Linux干货 2016-08-24
  • 往死里苦练脚本啊啊啊啊啊啊啊~~~~~~~~~~~~~~~~

    1、写一个脚本,判断当前系统上所有用户的shell是否为可登录shell(即用户的shell不是/sbin/nologin);分别这两类用户的个数;通过字符串比较来实现; #脚本内容 [root@centos script]# cat week9_title1.sh  #!/bin/bash #Author …

    Linux干货 2017-02-16
  • 部署LAMP之WordPress, PMA(https), Discuz

    一、环境介绍     系统:CentOS 6.7     软件:httpd-2.2, mysql-5.3, wordpress-4.3, pma4.0     网络:       …

    Linux干货 2016-03-24
  • 重要开源协议解析(BSD,Apache,GPL,LGPL) 整理

    现今存在的开源协议很多,而经过Open Source Initiative组织通过批准的开源协议详见其网站(http://www.opensource.org/licenses/alphabetical)。我们在常见的开源协议如BSD, GPL, LGPL等都是OSI批准的协议。如果要开源自己的代码,最好也是选择这些被批准的开源协议。 这里整理了四种最常用的…

    Linux干货 2016-07-22
  • 高级文件文件系统管理之btrfs系统

    一.概述 btrfs文件系统:     技术预览版     btrfs (B-tree,Butter FS,Better FS),GPL,Oracle,2007,CoW     ext3/ext4,xfs 核心特性:  &nbsp…

    Linux干货 2016-09-11