- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
这是我的情况的简短版本。我当前的 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/
我在使用以下代码时遇到问题: function http_file_exists($url){ $f=fopen($url,"r"); if($f){ fclose($f); retu
我已经通过 Git 部署到 Azure 几个月了,没有出现重大问题,但现在我似乎遇到了一个无法克服的错误。 我创建了一个新的 Azure 网站,为正在开发的项目创建单独的预览链接。我在新站点上设置了
我已经通过flutter创建了一个App并完成了它,我想在flutter文档中阅读时进行部署。 我收到此错误: FAILURE: Build failed with an exception. * W
我在Windows 10中使用一些简单的Powershell代码遇到了这个奇怪的问题,我认为这可能是我做错了,但我不是Powershell的天才。 我有这个: $ix = [System.Net.Dn
我正在尝试使用 RapidJSON 解析从服务器接收到的数据。以下是收到的确切字符串: [ { "Node": "9478149a08f9", "Address": "172.17
我尝试为 ios 编译 OpenCV。我总是收到这些错误。我用不同版本的opencv试了一下,结果都是一样的。 我运行这个:python 平台/ios/build_framework.py ios_o
我在一台机器上做基本的发布/订阅,我的客户端是 StackExchange-Redis 的 C# 客户端,我在同一台机器上运行基于 Windows 的 Redis 服务器(服务器版本 2.8.4) 当
我有这段代码,但无法执行,请帮我解决这个问题 连接 connect_error) { die ("connection failed: " . $terhubung->connect_erro
我在 tomcat 上运行并由 maven 编译的 Web 应用程序给出了以下警告和错误。我可以在本地存储库中看到所有 JAR,但有人可以帮忙吗。 WARNING: Failed to scan JA
我正在 Windows 8 上使用 Android Studio 开发一个 android 应用程序,我正在使用一些 native 代码。突然间我无法编译我的 C 文件。当我运行 ndk-build
下面的代码对类和结构的成员进行序列化和反序列化。序列化工作正常,但我在尝试使用 oarch >> BOOST_SERIALIZATION_NVP(outObj); 反序列化时遇到了以下错误; 代码中是
如果我运行此命令“rspec ./spec/requests/api/v1/password_reset_request_spec.rb”,此文件中的所有测试都会通过。 但是,当我运行“rspec”时
我在尝试执行测试以使用 Protractor 上传文件时出错,我的代码是这个 it('it should be possible to upload a file', function() {
System.loadLibrary("nativefaceswap"); 当我运行我的应用程序时,我在 Android Studio 中发现了此类错误。在logcat中显示: java.lang.U
我希望有人能帮助我!使用任何方法或命令行的任何 SSL/HTTPS 调用均无效。 我在 Windows 10 中使用 Ubuntu Server 18.04 作为子系统。我的问题是昨天才开始出现的,因
通过删除这两个值将日期字段从 null=True 和 Blank=True 更改为 required 时,使用 db.alter 命令时遇到问题。 当以下行被注释掉时,迁移运行不会出现问题。
我第一次使用 Heroku 尝试创建应用程序(使用 SendGrid 的 Inbound Parse Webhook"和 Twilio SMS 通过电子邮件发送和接收 SMS 消息)。通过 Virtu
我正在将我的 swift 项目更新到 Xcode 7 上的 Swift 2.0。xcode 在构建项目时报告了以下错误: 命令/Applications/Xcode.app/Contents/Deve
在我的代码中,SSL 库函数 SSL_library_init() 没有按预期返回 1。我如何才能看到它返回了什么错误? 我在 SSL_library_init() 之后调用了 SSL_load_er
我正在尝试运行在以下链接中找到的答案: Asynchronously Load the Contents of a Div 但是当我这样做时,我会遇到我不太理解的错误。 我的代码: $(documen
我是一名优秀的程序员,十分优秀!