gevent+paramiko异步操作客户端

先上这段代码

root@HMA-m:~# cat updatewebserver.py 
#!/usr/bin/python
from optparse import OptionParser
import paramiko
#import gevent.monkey
#gevent.monkey.patch_socket()           paramiko是不能使用猴子补丁的,这点作者在github上已经申明了。。。当然,之前我是不知道的。。。
import gevent

parser = OptionParser(usage="%prog",version="version %prog 1.0.0")
parser.add_option("-f", "--files",action="store", type="string", dest="files", help="give the file's name")
(options, args) = parser.parse_args()

def Update(hostname):
    paramiko.util.log_to_file('/tmp/update.log')
    s=paramiko.SSHClient()
    s.load_system_host_keys()
    s.set_missing_host_key_policy(paramiko.AutoAddPolicy())
    try:
        s.connect(hostname=hostname,username='root',password='123456')
        gevent.sleep(0)                           #切换协程
        stdin,stdout,stderr=s.exec_command('python /script/update.py %s' %options.files)
        rr=stdout.read()
#        print '%s\n%s' %(hostname,rr.strip('\n'))
        print '>>>>>>>>>>>>%s update OK,more information in /root/update.log<<<<<<<<<<<<<<' %hostname
    except Exception as e:
        print '%s\n%s' %(hostname,e)
    s.close()

if __name__ == '__main__':
    threads=[]
    ip=['192.168.111.133','192.168.111.134','192.168.111.135','192.168.111.132']
    for i in ip:
        threads.append(gevent.spawn(Update,i))
    gevent.joinall(threads)


root@HMA-m:~# python updatewebserver.py -f System.tar.gz
192.168.111.135
[Errno 113] No route to host
>>>>>>>>>>>>192.168.111.133 update OK,more information in /root/update.log<<<<<<<<<<<<<<
>>>>>>>>>>>>192.168.111.134 update OK,more information in /root/update.log<<<<<<<<<<<<<<
>>>>>>>>>>>>192.168.111.132 update OK,more information in /root/update.log<<<<<<<<<<<<<<

在这里我们使用了gevent来调度和切换上下文,从结果可以很明显的看到,我们的ip列表第一位是192.168.111.133,但是结果中第一个反馈的并不是它,而是192.168.111.135,在for循环里肯定是阻塞的,之所以能起到这样的效果,就是因为gevent中的协程切换,让我们打到的异步的目的。


你可能感兴趣的:(gevent+paramiko异步操作客户端)