34 lines
1.6 KiB
Python
34 lines
1.6 KiB
Python
#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"
|