跳转至

Profiling NodeJS

Version-1.9.0

目前 DataKit 支持 1 种方式来采集 NodeJS profiling 数据,即 Pyroscope

Pyroscope

Pyroscope 是一款开源的持续 profiling 平台,DataKit 已经支持将其上报的 profiling 数据展示在观测云

Pyroscope 采用 C/S 架构,运行模式分为 Pyroscope AgentPyroscope Server,这两个模式均集成在一个二进制文件中,通过不同的命令行命令来展现。

这里需要的是 Pyroscope Agent 模式。DataKit 已经集成了 Pyroscope Server 功能,通过对外暴露 HTTP 接口的方式,可以接收 Pyroscope Agent 上报的 profiling 数据。

Profiling 数据流向:「Pyroscope Agent 采集 Profiling 数据 -> Datakit -> 观测云」。

在这里,你的 NodeJS 程序就相当于是一个 Pyroscope Agent。

前置条件

  • 根据 Pyroscope 官方文档 NodeJS, 支持以下平台:
Linux macOS Windows Docker
✅ ✅ ❌ ✅
  • Profiling NodeJS 程序

Profiling NodeJS 程序需要把 npm 模块引入到程序中:

npm install @pyroscope/nodejs

# or
yarn add @pyroscope/nodejs

把以下代码加入到你的 NodeJS 程序代码中:

const Pyroscope = require('@pyroscope/nodejs');

Pyroscope.init({
  serverAddress: 'http://pyroscope:4040',
  appName: 'myNodeService',
  tags: {
    region: 'cn'
  }
});

Pyroscope.start()
  • 已安装 DataKit 并且已开启 profile 采集器,配置参考如下:
[[inputs.profile]]
  ## profile Agent endpoints register by version respectively.
  ## Endpoints can be skipped listen by remove them from the list.
  ## Default value set as below. DO NOT MODIFY THESE ENDPOINTS if not necessary.
  endpoints = ["/profiling/v1/input"]

  #  config
  [[inputs.profile.pyroscope]]
    # listen url
    url = "0.0.0.0:4040"

    # service name
    service = "pyroscope-demo"

    # app env
    env = "dev"

    # app version
    version = "0.0.0"

  [inputs.profile.pyroscope.tags]
    tag1 = "val1"

启动 DataKit, 然后启动你的 NodeJS 程序。

查看 Profile

执行上述操作后,你的 NodeJS 程序会开始采集 profiling 数据并将数据报给给 Datakit,Datakit 会将这些数据上报给观测云。稍等几分钟后就可以在观测云空间应用性能监测 -> Profile 查看相应数据。

Pull 模式 (可选)

集成 NodeJS 程序的方式也支持 Pull 模式。你必须确保你的 NodeJS 程序有 profiling 路由 (/debug/pprof/profile/debug/pprof/heap) 且是启用状态。为此你可以使用 expressMiddleware 模块或者自己创建路由接入点:

const Pyroscope, { expressMiddleware } = require('@pyroscope/nodejs');

Pyroscope.init({...})

app.use(expressMiddleware())

注意:你不必再使用 .start() 但必须使用 .init()

FAQ

如何排查 Pyroscope 问题

可以设置环境变量 DEBUGpyroscope, 然后查看调试信息:

DEBUG=pyroscope node index.js

文档评价

文档内容是否对您有帮助? ×