首页 > 代码库 > python组建之paramiko的简介和简单使用

python组建之paramiko的简介和简单使用

 

参考文献:

 http://www.cnblogs.com/gannan/archive/2012/02/06/2339883.html

 pydoc paramiko

 

paramiko简介

 

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

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

举个常见的例子,现有这样的需求:需要使用windows客户端,远程连接到Linux服务器,查看上面的日志状态,大家通常使用的方法会是:

1:用telnet

2:用PUTTY

3:用WinSCP

4:用XManager等…

那现在如果需求又增加一条,要从服务器上下载文件,该怎么办?那常用的办法可能会是:

1:Linux上安装FTP并配置

2:Linux上安装Sambe并配置…

大家会发现,常见的解决方法都会需要对远程服务器必要的配置,如果远程服务器只有一两台还好说,如果有N台,还需要逐台进行配置,或者需要使用代码进行以上操作时,上面的办法就不太方便了。

使用paramiko可以很好的解决以上问题,比起前面的方法,它仅需要在本地上安装相应的软件(python以及PyCrypto),对远程服务器没有配置要求,对于连接多台服务器,进行复杂的连接操作特别有帮助。

 

paramiko安装

 

本人用的最简单的安装方式:

?
1
$ easy_install paramiko

 

paramiko函数简介

 

目前仅仅用的下面的这两个class,如果以后还使用其他的模块的话,继续添加!

 

transport

简介:

An SSH Transport attaches to a stream (usually a socket), negotiates an encrypted session, authenticates, and then creates stream tunnels, called `channels <.Channel>`, across the session.  Multiple channels can be multiplexed across a single session (and often are, in the case of port forwardings).

channel

简介:

 

?
1
A secure tunnel across an SSH `.Transport`.  A Channel is meant to behave  like a socket, and has an API that should be indistinguishable from the   Python socket API.

 

paramiko简单实例应用

 

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
#/usr/bin/env python
 
import paramiko
import sys
import traceback
import socket
import os
import getpass
 
# setup logging
paramiko.util.log_to_file(‘demo.log‘)
 
hostname = ‘192.168.1.253‘
port = 22
username = ‘apache‘
# now  connect
try:
    sock = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
    sock.connect((hostname, port))
except Exception as e:
    print("****   Connect failed ****")
    traceback.print_exc()
    sys.exit(1)
 
try:
    t = paramiko.Transport(sock)
    try:
        t.start_client()
    except paramiko.SSHException:
        print(‘****  SSH negotiation failed.  ****‘)
        sys.exit(1)
 
    try:
        keys =paramiko.util.load_host_keys(os.path.expanduser(‘~/.ssh/known_hosts‘))
    except IOError:
        try:
            keys = paramiko.util.load_host_keys(os.path.expanduser(‘~/ssh/known_hosts‘))
        except IOError:
            print(‘****  Unable to open host keys file  ****‘)
            keys = {}
 
    # check server‘s host key -- this is important.
    key = t.get_remote_server_key()
    if hostname not in keys:
        print(‘*** WARNING: Unknown host key!‘)
    elif key.get_name() not in keys[hostname]:
        print(‘*** WARNING: Unknown host key!‘)
    elif keys[hostname][key.get_name()] != key:
        print(‘*** WARNING: Host key has changed!!!‘)
        sys.exit(1)
    else:
        print(‘*** Host key OK.‘)
 
    pw = getpass.getpass(‘Password for %s@%s: ‘ % (username, hostname))
    t.auth_password(username, pw)
 
    chan = t.open_session()
    chan.get_pty()
    chan.invoke_shell()
    print(‘**** Here we go! \n‘)
    chan.send(‘pwd‘)
    print chan.recv(9999)
    chan.close()
    t.close()
 
except Exception as e:
    print(‘*** Caught exception: ‘ + str(e.__class__) + ‘: ‘ + str(e))
    traceback.print_exc()
    try:
        t.close()
    except:
        pass
    sys.exit(1)