先上这段代码
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中的协程切换,让我们打到的异步的目的。