NestJS + Opentelemetry(Loki)

💡 原文韩文,约4200字,阅读约需10分钟。
📝

内容提要

本文介绍了在NestJS应用中使用Opentelemetry和Winston记录日志的方法,包括安装Opentelemetry Collector和Grafana,配置LoggerProvider和Winston Logger,以及将日志传输到Opentelemetry的OTLP exporter并存储到Loki。可以在Grafana中查看日志。

🎯

关键要点

  • 需要准备Opentelemetry Collector和Grafana。
  • 自动日志记录存在问题,需手动配置以确保日志正确发送到Loki。
  • 必须安装winston-transport,因为它不是instrumentation-winston的依赖项。
  • 选择Winston作为日志记录器,Pino也可以使用相同的方法。
  • 创建logger.ts文件以设置LoggerProvider和Exporter。
  • 在logger.ts中创建Winston Logger并注册OpenTelemetryTransportV3。
  • 在main.ts中导入logger并在创建NestApp时传递logger。
  • 在AppModule中提供Winston Logger作为Provider。
  • 最终,Winston日志将通过LoggerProvider的Exporter发送到OLTP端点,并由Collector收集到Loki中。
  • 可以通过Grafana查看日志,路径为Explore -> Data source: Loki -> Label browser -> Select Service -> Show logs。
➡️

继续阅读