gpt4 book ai didi

node.js - 如何找出Node.js服务器CPU 100%的原因?

转载 作者:搜寻专家 更新时间:2023-11-01 00:08:12 25 4
gpt4 key购买 nike

我正在使用 socket.io 运行 Node.js 服务器。这是简单的聊天服务器。已经两年了,所以软件版本很旧,所以我最近更新了它们。更新后,服务器频繁消耗CPU 100%。它已经运行了 2 年,所以我认为原因不是应用程序代码,但我找不到问题所在。

更新之前:

  • Node.js 0.8.14
  • socket.io 0.9.16
  • 表达 2.5.2

现在我正在使用:

  • Node.js 0.10.28 ~ 0.11.13(都试过了)
  • socket.io 1.0.1
  • 表达 4.1.1

我试过基准测试,但无法重现。我发现模板呈现速度很慢,但我的聊天服务器是用于移动应用程序的,因此它不会经常使用 html 页面。只有管​​理页面使用模板引擎,但当我没有看到管理页面时,CPU 100% 发生了。

使用 strace,我得到了这个:

strace -r -p 32224 -c
% time seconds usecs/call calls errors syscall
------ ----------- ----------- --------- --------- ----------------
16.91 0.003417 35 97 futex
14.47 0.002923 8 347 72 epoll_ctl
14.10 0.002848 20 144 write
11.32 0.002286 15 152 read
6.27 0.001266 18 70 close
5.77 0.001165 19 61 61 connect
5.53 0.001117 6 183 clock_gettime
5.20 0.001051 117 9 munmap
4.65 0.000940 5 173 gettimeofday
4.19 0.000846 14 61 socket
3.72 0.000752 6 122 ioctl
3.36 0.000679 12 58 epoll_wait
2.34 0.000473 7 72 getsockopt
1.95 0.000394 56 7 mmap
0.22 0.000045 23 2 open
------ ----------- ----------- --------- --------- ----------------
100.00 0.020202 1558 133 total

但是,我不知道如何分析这份报告。 epoll_ctl好像是event loop用的,epoll_ctl报错可能是connect报错导致的吧?我发现 syscall connect 用于套接字连接,但我不能更进一步。

这个 strace 报告有 2 分钟长。没有那么多用户。当时只有 2~5 个用户。

我可以通过报告找出原因吗?或者我必须找到其他调试方法吗?

最佳答案

V8 Profiler可以输出可以在 Chrome Profiling 选项卡中读取的报告。如果你使用 PM2 和 Keymetrics,那真的很容易。只需安装 v8-profiler 和 pmx 模块。确保在脚本中需要 pmx 模块,然后通过 Keymetrics 站点开始分析。您始终可以单独使用 V8 Profiler 来获得相同的报告。不过还需要做一些工作。

关于node.js - 如何找出Node.js服务器CPU 100%的原因?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/24242613/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com