如何判断linux磁盘IO是否导致过多(> 1秒)的应用程序停顿

如何判断linux磁盘IO是否导致过多(> 1秒)的应用程序停顿,第1张

概述我有一个 Java应用程序执行大容量(数百MB)的连续输出(流纯文本)到大约12个文件ext3 SAN文件系统.有时,此应用程序一次暂停几秒钟.我怀疑与ext3 vsfs(Veritas Filesystem)功能相关的东西(和/或它与 *** 作系统的交互方式)是罪魁祸首. 我可以采取哪些步骤来证实或反驳这一理论?我知道iostat和/ proc / diskstats作为起点. 修改标题不再强调日记并 我有一个 Java应用程序执行大容量(数百MB)的连续输出(流纯文本)到大约12个文件ext3 SAN文件系统.有时,此应用程序一次暂停几秒钟.我怀疑与ext3 vsfs(Veritas filesystem)功能相关的东西(和/或它与 *** 作系统的交互方式)是罪魁祸首.

我可以采取哪些步骤来证实或反驳这一理论?我知道iostat和/ proc / diskstats作为起点.

修改标题不再强调日记并强调“摊位”

我做了一些谷歌搜索,发现至少有一篇文章似乎描述了我正在观察的行为:Solving the ext3 latency problem

附加信息

>红帽企业linux服务器版本5.3(Tikanga)
>内核:2.6.18-194.32.1.el5
>主应用程序磁盘是光纤通道SAN:lspci | grep -i fiber>> 14:00.0光纤通道:Emulex Corporation Saturn-X:lightpulse光纤通道主机适配器(rev 03)
>装载信息:输入vxfs(rw,tmplog,largefiles,mincache = tmpcache,ioerror = mwdisable)0 0
> cat / sys / block / VxVM123456 / queue / scheduler>> noop expectedatory [截止日期] cfq

解决方法 我的猜测是,还有一些其他进程会占用磁盘I / O容量一段时间.如果你有一个足够的内核,iotop可以帮助你找到它.

如果是这种情况,则不是关于文件系统,更不用说日志了.负责在冲突的应用程序之间进行仲裁的是I / O调度程序.一个简单的测试:检查当前的调度程序并尝试不同的调度程序.它可以在运行中完成,无需重新启动.例如,在我的桌面上检查第一个磁盘(/ dev / sda):

cat /sys/block/sda/queue/scheduler=>  noop deadline [cfq]

表明它使用的是CFQ,这对于台式机来说是一个不错的选择,但对服务器来说并不是很好.更好地设定’截止日期’:

echo 'deadline' > /sys/block/sda/queue/schedulercat /sys/block/sda/queue/scheduler=>  noop [deadline] cfq

并等待几个小时,看看它是否有所改善.如果是这样,请在启动脚本中永久设置(取决于分发)

总结

以上是内存溢出为你收集整理的如何判断linux磁盘IO是否导致过多(> 1秒)的应用程序停顿全部内容,希望文章能够帮你解决如何判断linux磁盘IO是否导致过多(> 1秒)的应用程序停顿所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/yw/1040216.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-05-24
下一篇 2022-05-24

发表评论

登录后才能评论

评论列表(0条)

保存