Paramiko: SSH and SF

发布时间:2019-09-18 07:27:56编辑:auto阅读(1737)

     原文出处:

    1. http://segfault.in/2010/03/paramiko-ssh-and-sftp-with-python/ 

    Paramiko  是一个用于python2.5或更高版本的实现了使用SSH2协议安全(加密与验证)的连接远程计算机的模块 

    重点是使用作为替代SSL的SSH2在python脚本间创建连接。支持所有的主流运算与哈希模块。同样也支持SFTP服务端模式与客户端模式

     

    安装 paramiko

    First, we need to install paramiko, if you don’t have it already.

    On Ubuntu/Debian

     

    1. $ sudo apt-get install python-paramiko 

    Or install from source

    1. $ wget http://www.lag.net/paramiko/download/paramiko-1.7.6.tar.gz 
    2. $ tar xzf paramiko-1.7.6.tar.gz 
    3. $ cd paramiko-1.7.6 
    4. $ python setup.py build 
    5. $ su -c "python setup.py install" 

     

    Working with paramiko

    SSHClient是paramkio模块提供的主要的类。它提供了基础的可以用来实例化服务器连接的接口。下面的代码创建了一个新的SSHClient对象,然后调用“connect()”来连接到我们本地的SSH服务器。

    1. import paramiko 
    2. ssh = paramiko.SSHClient() 
    3. ssh.connect('192.168.1.2', username='vinod', password='screct'

    另一种方法是使用SSH密钥的

    1. import paramiko 
    2.   
    3. ssh = paramiko.SSHClient() 
    4. ssh.set_missing_host_key_policy(paramiko.AutoAddPolicy()) 
    5. ssh.connect('beastie', username='vinod', password='secret'
    6. stdin, stdout, stderr = ssh.exec_command('df -h'
    7. print stdout.readlines() 
    8. ssh.close() 

    “paramiko.AutoAddPolicy()”方法将自动接受未知密钥

    使用sudo命令运行:

    1. import paramiko 
    2.   
    3. cmd    = "sudo /etc/rc.d/apache2 restart" 
    4.   
    5. ssh    = paramiko.SSHClient() 
    6. ssh.set_missing_host_key_policy(paramiko.AutoAddPolicy()) 
    7. ssh.connect('beastie', username='vinod', password='secret'
    8. stdin, stdout, stderr = ssh.exec_command(cmd) 
    9. stdin.write('secret\n'
    10. stdin.flush() 
    11. print stdout.readlines() 
    12. ssh.close() 

     

    使用 SFTPClient 实现文件安全传输

     

    SFTPClient用来打开一个sftp 会话在一个开放的ssh中传输和执行远程文件的操作。

    首先我们创建一个连接:

    1. import paramiko 
    2. import os 
    3. privatekeyfile = os.path.expanduser('~/.ssh/id_rsa'
    4. mykey = paramiko.RSAKey.from_private_key_file(privatekeyfile) 
    5. username = 'vinod' 
    6. transport.connect(username = username, pkey = mykey) 

    上面应该少了一句代码:transport = paramiko.Transport((“主机”,”端口”))

    创建socket对象

    现在我们开始SFTP客户端:

    1. sftp = paramiko.SFTPClient.from_transport(transport) 

    现在推送文件到远程系统:

    1. remotepath='/var/www/p_w_picpaths/file.png' 
    2. localpath='/tmp/file.png' 
    3. sftp.put(remotepath, localpath) 

    最后,关闭SFTP连接:

    1. sftp.close() 
    2. transport.close() 

    创建paramiko.Transport对象可以用socket也可以用IP,port

     

    1. import paramiko 
    2.  
    3. transport = paramiko.Transport(('localhost',22)) 
    4. transport.connect(username='root', password = 'password'
    5. sftp = paramiko.SFTPClient.from_transport(transport) 
    6. sftp.get(remotefile,localfile) 
    7. #如果是上传则用: 
    8. #sftp.put(localfile, remotefile) 
    9. transport.close() 
    10.  
    11. #用socket连接 
    12. tcpsock = socket.socket(socket.AF_INET,socket.SOCK_STREAM) 
    13. tcpsock.settimeout(5
    14. tcpsock.connect((ip,22),) 
    15. ssh = paramiko.Transport(tcpsock) 
    16. ssh.connect(username=user,password=password) 
    17. sftpConnect=paramiko.SFTPClient.from_transport(ssh) 

     

     

关键字