npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2024 – Pkg Stats / Ryan Hefner

@zijin-m/egg-jaeger

v1.0.7

Published

jaeger client for egg

Downloads

4

Readme

egg-jaeger

Jaeger 链路追踪插件。支持功能:

  1. Http 调用链路。
  2. SequelizeSQL语句跟踪。
  3. RedisCommand命令跟踪。

效果图

重要说明

对于 SequelizeRedis 的跟踪依赖了 Async Hooks 特性,该特性在目前版本(12.10.0)的 Node 中依然是实验性的,请慎重在生产环境中使用。

HTTP上下游打通

通过 FORMAT_HTTP_HEADERS 进行上下游链路打通,上游在 HTTP HEADER 中携带 uber-trace-id 时可以注入当前 tracer

进行下游 HTTP 调用时可以使用 ctx.curl , 会自动注入当前 tracerHEADER ,详见下文。

统一 TraceId 返回

默认会在 ctx.body 中返回 traceId 字段。

{
  ok: true, // 原本的返回结果
  traceId: "a3c92d1c813533d5" // 附加 traceId
}

安装

$ npm i @zijin-m/egg-jaeger --save

使用

// {app_root}/config/plugin.js
exports.jaeger = {
  enable: true,
  package: '@zijin-m/egg-jaeger'
};

配置

// {app_root}/config/config.default.js
exports.jaeger = {
  serviceName: 'your-awesome-service',
  sampler: {
    type: 'const',
    param: 1
  },
  reporter: {
    // Provide the traces endpoint; this forces the client to connect directly to the Collector and send
    // spans over HTTP
    collectorEndpoint: 'http://jaeger-collector:14268/api/traces'
    // Provide username and password if authentication is enabled in the Collector
    // username: '',
    // password: '',
  },
  sequelize: false, // 默认不开启sequelize记录
  redis: false, //默认不开启redis记录
  middlewareIndex: 1 // 默认插入的中间件位置
};

备注

middlewareIndex 是将 jaeger 中间件插入的位置,默认放在错误捕捉中间件(类似error_handler_middleware)后面,其他中间件前面,所以默认为 1,这样的目的是在错误被被捕获前由jaeger中间件能捕获到错误,设置错误 Tag 后再抛出错误,如果你没有错误捕捉中间件,应该设置为 0,即第一个中间件。

see config/config.default.js for more detail.

示例

HTTP 链路

  1. 通过 egg 自带的 HttpClient 进行 http 调用,注意要使用 ctx.curl 而不要用 app.curl ,因为 ctx.curl 才能正确的传递 ctx上下文信息 用来链路追踪。
ctx.curl('http://www.google.com');
  1. 通过 npm 包 request-promise-jaeger 进行 http 调用,这种方式需要手动传入 ctx.tracerctx.rootSpan 作为请求参数。
const rp = require('request-promise-jaeger');

rp('http://www.google.com', {
  tracer: ctx.tracer,
  rootSpan: ctx.rootSpan
  // ... other options
});

Sequelize 跟踪

通过配置 sequelize: true 开启,开启后会为每个 SQL 操作创建 Span

Redis 跟踪

通过配置 redis: true 开启,开启后会为每个 Command 操作创建 Span

Questions & Suggestions

Please open an issue here.

License

MIT