gpt4 book ai didi

python - 在 Linux 中记录 ping 成功和失败

转载 作者:塔克拉玛干 更新时间:2023-11-03 01:02:11 24 4
gpt4 key购买 nike

这是我的情况的简短版本。我当前的 ISP 无法正常工作,因此,我想记录 ping 成功和失败作为它无法正常工作的证据。我将使用 Linux,但 Windows 也可以。我一直在阅读,据我所知,shell 脚本或 Python 代码效果最好。

所以,更详细一点:我想每 5 秒在网站上执行一次 ping。如果 ping 成功,它应该将 ping 的正常结果输出到文件中。但是,Ping 失败的超时时间很长,所以我想编写程序,以便如果 ping 在 4 秒左右没有成功,它会停止 ping 尝试,但仍会输出带有“1 数据包”的完整 ping 数据传输,0 接收”等等,就像它用完时间一样。

这是我目前所拥有的:

while true
do
ping -c1 -w4 www.example.com >> log.txt
sleep 5
done

不幸的是,有两个问题。首先,“-w4”并没有像我想象的那样在 4 秒后超时。其次,“ sleep ”增加了已经花费的时间。因此,如果 ping 需要 3 秒,则循环将需要 8 秒。由于我将编写另一个程序来计算成功、失败并输出停机时间百分比,因此让循环在失败时花费大量额外时间是 Not Acceptable 。

那么,鉴于我的需要,最好的方法是什么?我可以改进什么来满足需求吗?感谢您的帮助!

PS:我对编写 shell 脚本几乎一无所知(尽管我可以使用终端),而我对 Python 的了解更少(尽管我了解 C++)。提前致歉!

最佳答案

如果你真的想让整个循环花费不超过 5 秒,你必须知道 ping 花费了多长时间,然后从 5 中减去它,并休眠差异。

您可以从 bash 执行此操作,方法是记录 ping 前后的时间并减去,或者使用 time -p 命令运行 ping(第二个第一个非空行的列将作为 float 的挂钟时间,如 0.01)。

但我认为使用 Python 会更容易:

import datetime
import subprocess
import time

while True:
start = datetime.datetime.now()
with open('log.txt', 'a+b') as logfile:
subprocess.call(['ping', '-c1', '-w4', 'www.example.com'], stdout=logfile)
delta = datetime.datetime.now() - start
time.sleep(delta.total_seconds())

当然,如果 ping 在最多 5 秒内没有完成,这当然不会起作用,因为你不能在负时间里 sleep 。您可以通过使用显式Popen 并对其调用wait(5) 来解决该问题,如果失败则终止...

但是无论它是否需要那么多时间,总是给它 5 秒要简单得多:

while True:
with open('log.txt', 'a+b') as logfile:
ping = subprocess.Popen(['ping', '-c1', '-w4', 'www.example.com'],
stdout=logfile)
time.sleep(5)
# Not strictly necessary, but it avoids signaling for no reason
if ping.poll() is None:
ping.kill()
ping.wait()

关于python - 在 Linux 中记录 ping 成功和失败,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/18860271/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com