Python测试远程端口连接时间
最近自己服务器访问别人的服务器,有时候会报超时错误,有时候又能够正常访问别人服务器。
思路
最开始猜测是网络不稳定造成的,但是自己没有收集什么时候超时,什么时候能正常访问别人服务器的日志,搞网络运维的同学根本不鸟我(其实,这活本来就是运维的事,有点小心塞,不过想起蜘蛛侠的名言)。
能力越大,责任就越大
写个python脚本,然后,在python脚本里面使用telnet去连接别人服务器对应的端口,然后,计算连接前后的时间长短。
解决
importos
importcsv
importtime
importargparse
importtelnetlib
fromdatetimeimportdatetime
#测试远程服务端口连接耗时
#python3windows_telnet.py192.168.10.2180
parser=argparse.ArgumentParser()
parser.add_argument("ip",type=str,help="ip")
parser.add_argument("port",type=str,help="port")
args=parser.parse_args()
timeFormat="%Y-%m-%d%H:%M:%S.%f"
starTimeTitle="开始连接时间"
endTimeTitle="结束连接时间"
differenceTimeTitle="连接总耗时"
whileTrue:
starTime=datetime.now()
starTimeView=starTime.strftime(timeFormat)
print("开始连接:{0}".format(starTimeView))
tn=telnetlib.Telnet(args.ip,args.port)
endTime=datetime.now()
endTimeView=endTime.strftime(timeFormat)
print("连接完成:{0}".format(endTimeView))
tn.close()
print("连接结束")
differenceTime=endTime-starTime
print("连接消耗:{0}".format(differenceTime))
nowTime=datetime.now()
csvFileName="{0}.csv".format(nowTime.strftime("%Y-%m-%d"))
ifos.path.exists(csvFileName)isnotTrue:
withopen(csvFileName,"w",newline="")ascsvfile:
fieldnames=[starTimeTitle,endTimeTitle,differenceTimeTitle]
writer=csv.DictWriter(csvfile,fieldnames=fieldnames)
writer.writeheader()
withopen(csvFileName,"a",newline="")ascsvfile:
fieldnames=[starTimeTitle,endTimeTitle,differenceTimeTitle]
writer=csv.DictWriter(csvfile,fieldnames=fieldnames)
writer.writerow({starTimeTitle:starTimeView,endTimeTitle:endTimeView,differenceTimeTitle:differenceTime})
time.sleep(0.2)
这里涉及到几个Python的知识点:
●获取当前时间,计算时间差以及时间格式化
●telnetlib的使用
●生成csv文件以及对文件读写
●在whileTrue这个死循环里面需要避免cpu飙到100%问题,则需要在最后一行添加time.sleep(0.2)
接下来一个一个谈这些点:
Python3获取当前时间
fromdatetimeimportdatetime
starTime=datetime.now()
endTime=datetime.now()
这样获取出来的时间,我们一般需要在进行格式化处理才能够展现给用户看。
Python3时间格式化
在上面的基础上,我们可以,这样做
timeFormat="%Y-%m-%d%H:%M:%S.%f"
starTimeView=starTime.strftime(timeFormat)
使用strftime方法处理,具体可以查看Python3文档的date.strftime(format)部分。
Python3计算时间差
differenceTime=endTime-starTime
对,就这样相减,就完事了。
telnetlib的使用
importtelnetlib
tn=telnetlib.Telnet("192.168.10.21","80")
csv文件创建
importos
importcsv
csvFileName="{0}.csv".format(nowTime.strftime("%Y-%m-%d"))
ifos.path.exists(csvFileName)isnotTrue:
withopen(csvFileName,"w",newline="")ascsvfile:
fieldnames=[starTimeTitle,endTimeTitle,differenceTimeTitle]
writer=csv.DictWriter(csvfile,fieldnames=fieldnames)
writer.writeheader()
这里是先判断文件是否存在,如果不存在,就创建一个csv文件,并且写好表头。
csv文件追加
withopen(csvFileName,"a",newline="")ascsvfile:
fieldnames=[starTimeTitle,endTimeTitle,differenceTimeTitle]
writer=csv.DictWriter(csvfile,fieldnames=fieldnames)
writer.writerow({starTimeTitle:starTimeView,endTimeTitle:endTimeView,differenceTimeTitle:differenceTime})
死循环避免CPU飚高
循环里面最后添加一行:
importtime
time.sleep(0.2)
让线程休眠一段时间,这样就避免死循环占用cpu太高。
使用脚本
python3windows_telnet.py192.168.10.2180
以后就可以通过这个脚本监测远程端口连接问题,并每天生成一个日志文件。
以上内容为大家介绍了python中的反斜杠,希望对大家有所帮助,如果想要了解更多Python相关知识,请关注IT培训机构:千锋教育。http://www.mobiletrain.org/
相关推荐HOT
更多>>pythonprint函数如何不换行
python3.0的print函数有如下的形式:print([object,...][,seq=''][,end='\n'][,file=sys.stdout])我们在...详情>>
2023-11-09 19:52:59转java还是python?
从目前IT行业的人才需求上来看,如果是应用级开发,那么掌握Java语言会更容易实现就业,因为在目前的生产环境下,Java语言凭借其健全的语言生态...详情>>
2023-11-09 18:02:00python中怎么对一个数进行因式分解?
1、Python因式分解代码:importtime#对一个数进行因式分解deffactorization(num):factor=[]whilenum>1:foriinrange(num-1):k=i...详情>>
2023-11-09 12:01:26python如何让程序暂停执行和继续执行?
python让程序继续执行的方法:一、使用到的函数或库1.cv2.imshow()2.cv2.waitKey()3.time.sleep()4.cv2.putText()5.np.zeros()二、程详情>>
2023-11-09 11:03:08