我目前正在使用简单的 tail 命令跟踪 nginx 访问日志。
tail -f access.log
我希望能够显示添加到该日志的条目的当前平均每秒/分钟速度。是否可以通过使用 tail 和管道连接到另一个命令(grep、sed、wc)来简单地做到这一点,还是我需要考虑另一种获取这些数据的方法?谢谢!
要获得每秒连续实时更新的行数,请使用该pv
实用程序:
tail -f -n 0 access.log | pv -lr > /dev/null
请注意,pv
不断向终端写入更新,直到输入用完。如果您只想了解添加行的速率,事情会变得更复杂一些。这是我的尝试(采样时间为 5 秒):
tail -f -n 0 access.log 2>/dev/null | perl -e '$SIG{ALRM} = sub { print $x/5.0; exit(0) }; alarm 5.0; while(<>) { $x++ }'