加入收藏 | 设为首页 | 会员中心 | 我要投稿 PHP编程网 - 黄冈站长网 (http://www.0713zz.com/)- 数据应用、建站、人体识别、智能机器人、语音技术!
当前位置: 首页 > 服务器 > 搭建环境 > Linux > 正文

linux – 为什么strace输出中的brk()需要几秒钟?

发布时间:2021-05-24 15:19:03 所属栏目:Linux 来源:网络整理
导读:在迁移到Ubuntu Hardy,amd64时,我们注意到我们的一个应用程序显着减速.它在Debian Sarge i386上运行得非常好. 对(Apache 1.3)httpd进程运行’strace -r’显示了以下令人不安的部分: 0.000083 poll([{fd=8,events=POLLIN|POLLERR,revents=POLLIN}],1,-1) =

在迁移到Ubuntu Hardy,amd64时,我们注意到我们的一个应用程序显着减速.它在Debian Sarge i386上运行得非常好.

对(Apache 1.3)httpd进程运行’strace -r’显示了以下令人不安的部分:

     0.000083 poll([{fd=8,events=POLLIN|POLLERR,revents=POLLIN}],1,-1) = 1
     0.000026 recvfrom(8,"_323-412D000217recueil-cours"...,32727,NULL,NULL) = 8192
     0.000061 poll([{fd=8,"000217recueil-courses23er2"...,32767,NULL) = 2369
     0.117422 brk(0x397a000)            = 0x397a000
     0.140721 brk(0x399b000)            = 0x399b000
     4.457037 brk(0x39bc000)            = 0x39bc000
     0.078792 stat("/opt/semantico/slot/nijhoff/3/sitecode/live/public_home.html",{st_mode=S_IFREG|0644,st_size=2194,...}) = 0

注意最后一行的brk – 暗示brk(0x399b000)花了4.45秒!

我已经查看了brk的手册页,它指出它用于请求更大的数据段/堆,但我找不到任何理由为什么需要这么长时间.

有人有任何想法吗?

解决方法

事实证明,这个问题主要归结于我对strace -r输出的误解.

‘-r’选项给出自上次系统调用以来的时间(以秒为单位),而不是上次系统调用执行的时间.

在这种情况下,CPU正在进行一些计算而不是处理brk().

这里的问题现在已经解决了 – 它是由升级到perl 5.8.9(来自perl 5.8.8)引起的.我们退出了perl升级,并将在稍后调查perl 5.8.9减速的原因.

(编辑:PHP编程网 - 黄冈站长网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    热点阅读