#coding=utf-8 #!/usr/bin/env python import subprocess from threading import Thread from Queue import Queue num_thread=3 #定义线程的数量 queue=Queue() #创建队列实例 ips=['192.168.1.100','192.168.1.110','192.168.1.120','192.168.1.130','192.168.1.200'] def pinger(i,q): while True: ip=q.get() #获取Queue队列传过来的ip,队列使用队列实例queue.put(ip)传入ip,通过q.get() 获得 print "Thread %s:Pinging %s" %(i,ip) ret=subprocess.call("ping -c 1 %s" % ip,shell=True,stdout=open('/dev/null','w'),stderr=subprocess.STDOUT) #调用子进程执行命令,获取退出状态。不能使用subprocess.Popen也可以 if ret==0: print "%s:is alive" % ip else: print "%s:did not respond" % ip q.task_done() #告诉queue.join()已完成队列中提取元组的工作 for i in range(num_thread):#各线程开始工作 worker=Thread(target=pinger,args=(i,queue)) #创建一个threading.Thread()的实例,给它一个函数以及函数的参数 worker.setDaemon(True) #在start方法被调用之前如果没有进行设置,程序会不定期挂起。 worker.start() #开始线程的工作,没有设置程序会挂起,不会开始线程的工作,因为pinger程序是while True循环 for ip in ips: queue.put(ip) #将IP放入队列中。函数中使用q.get(ip)获取 print "Main Thread Waiting" queue.join() #防止主线程在其他线程获得机会完成队列中任务之前从程序中退出。 print "Done"