我们注意到我们的一个应用程序在迁移到 Ubuntu Hardy amd64 时显着放缓。它在 Debian Sarge i386 上运行良好。
对(Apache 1.3)httpd 进程运行“strace -r”显示了以下令人不安的部分:
0.000083 轮询([{fd=8, events=POLLIN|POLLERR, revents=POLLIN}], 1, -1) = 1 0.000026 recvfrom(8, "_323-412D\0\0\0000\0\2\0\0\0\17recueil-cours"..., 32727, 0, NULL, NULL) = 8192 0.000061 轮询([{fd=8, events=POLLIN|POLLERR, revents=POLLIN}], 1, -1) = 1 0.000026 recvfrom(8, "\0\0\0000\0\2\0\0\0\17recueil-courses\0\0\0\23er2"..., 32767, 0, NULL, 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 的手册页,它指出它被用于请求更大的数据段/堆,但我找不到任何需要这么长时间的原因。
有人有什么想法吗?