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。
🏷️
标签
➡️