百科狗-知识改变命运!
--

Python测试远程端口连接时间

百变鹏仔1年前 (2023-11-21)阅读数 10#技术干货
文章标签时间

最近自己服务器访问别人的服务器,有时候会报超时错误,有时候又能够正常访问别人服务器。

思路

最开始猜测是网络不稳定造成的,但是自己没有收集什么时候超时,什么时候能正常访问别人服务器的日志,搞网络运维的同学根本不鸟我(其实,这活本来就是运维的事,有点小心塞,不过想起蜘蛛侠的名言)。

能力越大,责任就越大

写个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)

Python测试远程端口连接时间

使用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.baikegou.com/

鹏仔微信 15129739599 鹏仔QQ344225443 鹏仔前端 pjxi.com 共享博客 sharedbk.com

免责声明:我们致力于保护作者版权,注重分享,当前被刊用文章因无法核实真实出处,未能及时与作者取得联系,或有版权异议的,请联系管理员,我们会立即处理! 部分文章是来自自研大数据AI进行生成,内容摘自(百度百科,百度知道,头条百科,中国民法典,刑法,牛津词典,新华词典,汉语词典,国家院校,科普平台)等数据,内容仅供学习参考,不准确地方联系删除处理!邮箱:344225443@qq.com)

图片声明:本站部分配图来自网络。本站只作为美观性配图使用,无任何非法侵犯第三方意图,一切解释权归图片著作权方,本站不承担任何责任。如有恶意碰瓷者,必当奉陪到底严惩不贷!

内容声明:本文中引用的各种信息及资料(包括但不限于文字、数据、图表及超链接等)均来源于该信息及资料的相关主体(包括但不限于公司、媒体、协会等机构)的官方网站或公开发表的信息。部分内容参考包括:(百度百科,百度知道,头条百科,中国民法典,刑法,牛津词典,新华词典,汉语词典,国家院校,科普平台)等数据,内容仅供参考使用,不准确地方联系删除处理!本站为非盈利性质站点,本着为中国教育事业出一份力,发布内容不收取任何费用也不接任何广告!)