os_kernel_lab/related_info/lab7/semaphore_condition/thr-ex3.py

34 lines
1.6 KiB
Python
Raw Normal View History

#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"