文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

Linux如何查看日志文件写入的速度

2023-07-02 08:55

关注

今天小编给大家分享一下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)写入的,而在如下的伪文件中,存放着程序打开的文件信息,如下:

于是定期的读取这个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

Linux如何查看日志文件写入的速度

watch_du

举一反三

其实转念一想,如果我们在某个函数中打上日志,然后通过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] [       <=>

以上就是“Linux如何查看日志文件写入的速度”这篇文章的所有内容,感谢各位的阅读!相信大家阅读完这篇文章都有很大的收获,小编每天都会为大家更新不同的知识,如果还想学习更多的知识,请关注编程网行业资讯频道。

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-人工智能
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯