原创:扣钉日记(微信公众号ID:codelogs),欢送分享,转载请保留出处。
简介
有时,咱们须要查看某个文件的增长速度,如日志文件,以此来感触零碎的负载状况,因为个别状况下,日志写入越快,阐明零碎负载越重。
本文就来介绍下Linux中查看日志增长速度的几种办法,如下:
应用dd
首先要介绍的是dd,因为dd命令简直所有支流发行版都自带,无需额定装置,如下:
$ tail -F app.log | dd of=/dev/null status=progress3875840 bytes (3.9 MB) copied, 8.228797 s, 471 kB/s
如上,应用tail -F
获取新写入的数据,而后用管道将数据交给dd,dd将数据拷贝到/dev/null
,其中status=progress
是用来显示拷贝速度的,可见,咱们日志的写入速度是471 kB/s
。
应用pv
pv命令能够看做是带进度的cp,如下:
$ yum install -y pv$ tail -F app.log | pv >/dev/null2.05MiB 0:00:03 [ 330kiB/s] [ <=> ]
原理与dd相似,不过命令换成了pv。
应用cv命令
因为日志数据都是程序(如java)写入的,而在如下的伪文件中,寄存着程序关上的文件信息,如下:
/proc/<pid>/fd
:寄存着关上的文件描述符/proc/<pid>/fdinfo
:寄存着文件描述符写入到的offset
于是定期的读取这个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包。
编写小脚本
通过写一个小脚本,定期察看文件大小,也可查看文件写入速度,如下:
# 每秒获取文件大小,通过减去上一秒的大小,即可计算出速度while sleep 1; do \ sz=`stat -c %s app.log`; \ numfmt --from=auto --to=iec $((sz-psz)); \ psz=$sz; \done492K750K370K
通过watch再加上察看,也能大抵看出速度,如下:
watch -d -t -n1 du app.log
触类旁通
其实转念一想,如果咱们在某个函数中打上日志,而后通过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=progress151 bytes (151 B) copied, 15.523018 s, 0.0 kB/s
这里能够通过151/15
计算出QPS是10,因为没有超过1000,所以看到的是0.0kB/s,如果应用pv命令,会更简略一些,如下:
$ tail -F app.log \ | grep --line-buffered '/order/get' \ | pv -l >/dev/null 144 0:00:03 [11.5 /s] [ <=> ]
往期内容
密码学入门
q命令-用SQL剖析文本文件
神秘的backlog参数与TCP连贯队列
mysql的timestamp会存在时区问题?
真正了解可反复读事务隔离级别
字符编码解惑