快速多线程ping,多线程ping,#!/usr/bin/p
文章由Byrx.net分享于2019-03-23 10:03:54
快速多线程ping,多线程ping,#!/usr/bin/p
#!/usr/bin/python#_*_coding:utf-8_*_#'''名称:快速多线程ping程序开发:gyhong gyh9711日期:20:51 2011-04-25'''import pexpectimport datetimefrom threading import Threadhost=["192.168.1.1","192.168.1.123","192.168.2.1","192.168.1.1","192.168.1.123","192.168.2.1","192.168.1.1","192.168.1.123","192.168.2.1","192.168.1.1","192.168.1.123","192.168.2.1","192.168.1.1"]report_ok=[]report_error=[]class PING(Thread): def __init__(self,ip): Thread.__init__(self) self.ip=ip def run(self): Curtime = datetime.datetime.now() #Scrtime = Curtime + datetime.timedelta(0,minute,0) #print("[%s]主机[%s]" % (Curtime,self.ip)) ping=pexpect.spawn("ping -c1 %s" % (self.ip)) check=ping.expect([pexpect.TIMEOUT,"1 packets transmitted, 1 received, 0% packet loss"],2) if check == 0: print("[%s] 超时 %s" % (Curtime,self.ip)) elif check == 1: print ("[%s] %s 可达" % (Curtime,self.ip)) else: print("[%s] 主机%s 不可达" % (Curtime,self.ip))#多线程同时执行T_thread=[]for i in host: t=PING(i) T_thread.append(t)for i in range(len(T_thread)): T_thread[i].start()##print ("\n=========问题主机情况如下==========\n")#output(report_error)#print ("\n=========正常主机情况如下==========\n")#output(report_ok)执行结果:administrator@nagios:/win/pexpect$ ./ping.py [2011-04-25 21:30:22.126981] 192.168.1.1 可达[2011-04-25 21:30:22.148376] 192.168.1.1 可达[2011-04-25 21:30:22.179846] 192.168.1.1 可达[2011-04-25 21:30:22.203691] 192.168.1.1 可达[2011-04-25 21:30:22.227696] 192.168.2.1 可达[2011-04-25 21:30:22.134049] 超时 192.168.1.123[2011-04-25 21:30:22.145610] 超时 192.168.2.1[2011-04-25 21:30:22.157558] 超时 192.168.1.123[2011-04-25 21:30:22.167898] 超时 192.168.2.1[2011-04-25 21:30:22.197572] 超时 192.168.1.123[2011-04-25 21:30:22.202430] 超时 192.168.2.1[2011-04-25 21:30:22.215561] 超时 192.168.1.123[2011-04-25 21:30:22.229952] 超时 192.168.1.1
相关内容
- python转换字符集,python字符集,def URLtoUTF
- 控制台刷新进度,控制台进度,import sysim
- python分割文件,python分割,#!/usr/bin/e
- Python生成目录树,python生成目录,# encoding:
- 过滤掉文件中的指定邮箱地址,过滤邮箱地址,#coding=
- Python 读取系统环境变量,python环境变量,import osfil
- python读取目录下文件并生成日志,,import os f
- python中map的用法,pythonmap用法,#范例1:>>> pri
- python操作sqlite,pythonsqlite,#!/usr/bin/p
- beautifulsoup 获得节点的下一个元素,beautifulsoup节点,be
评论关闭