0

我目前正在使用简单的 tail 命令跟踪 nginx 访问日志。

tail -f access.log

我希望能够显示添加到该日志的条目的当前平均每秒/分钟速度。是否可以通过使用 tail 和管道连接到另一个命令(grep、sed、wc)来简单地做到这一点,还是我需要考虑另一种获取这些数据的方法?谢谢!

4

1 回答 1

2

要获得每秒连续实时更新的行数,请使用该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++ }'
于 2013-11-11T16:01:39.220 回答