目录举一反三
简介
有时,我们须要查看某个文件的下降速率,如日志文件linux 查看日志文件,借此来体会系统的负载情况,由于通常情况下,日志写入越快,说明系统负载越重。
本文就来介绍下Linux中查看日志下降速率的几种方式,如下:
使用dd
首先要介绍的是dd,由于dd命令几乎所有主流发行版都自带,无需额外安装,如下:
$ tail -F app.log | dd of=/dev/null status=progress
3875840 bytes (3.9 MB) copied, 8.228797 s, 471 kB/s
如上,使用tail-F获取新写入的数据,之后用管线将数据交给dd,dd将数据拷贝到/dev/null,其中status=progress是拿来显示拷贝速率的,可见,我们日志的写入速率是471kB/s。
使用pv
pv命令可以看做是带进度的cp,如下:
$ yum install -y pv
$ tail -F app.log | pv >/dev/null
2.05MiB 0:00:03 [ 330kiB/s] [ ]
原理与dd类似,不过命令换成了pv。
使用cv命令
因为日志数据都是程序(如java)写入的,而在如下的伪文件中,储存着程序打开的文件信息,如下:
于是定期的读取这个offset就可以晓得文件的写入速率了,这也是cv命令的实现原理,如下:
$ yum install -y cv
$ cv -mc java
[ 1] java app.log 100.0% (6.1 GiB / 6.1 GiB) 390.2 KiB/s
# 实际上,由于Linux上大多数命令(如cp)没自带进度查看功能,而cv就成了很好的补充
# 比如查看cp复制文件的进度
$ cp app.log app.log.bak & cv -mc cp
新版cv命令早已更名为progress,安装不到cv包时,可试着安装progress包。
编撰小脚本
通过写一个小脚本,定期观察文件大小linux桌面,也可查看文件写入速率,如下:
# 每秒获取文件大小,通过减去上一秒的大小,即可计算出速度
while sleep 1; do
sz=`stat -c %s app.log`;
numfmt --from=auto --to=iec $((sz-psz));
psz=$sz;
done
492K
750K
370K
通过watch再加上观察,也能大致看出速率,如下:
watch -d -t -n1 du app.log
watch_du
举一反三
虽然转念一想,假如我们在某个函数中打上日志linux 查看日志文件,之后通过grep过滤出此日志,之后我们只要估算每秒输出的日志行数,这岂不就是函数执行的QPS了!
# 使用grep过滤出日志,tr删除非换行符,所以dd显示的是换行符的个数!
$ tail -F app.log
| grep --line-buffered '/order/get'
| stdbuf -oL tr -dc 'n'
| dd of=/dev/null bs=1 status=progress
151 bytes (151 B) copied, 15.523018 s, 0.0 kB/s
这儿可以通过151/15估算出QPS是10,因为没有超过1000linux rar,所以看见的是0.0kB/s,假如使用pv命令,会更简单一些,如下:
$ tail -F app.log
| grep --line-buffered '/order/get'
| pv -l >/dev/null
144 0:00:03 [11.5 /s] [
到此这篇关于Linux查看日志文件写入速率的4种方式解读的文章就介绍到这了,更多相关Linux查看日志文件写入速率内容请搜索本站原先的文章或继续浏览下边的相关文章希望你们之后多多支持本站!
美国服务器租用