分布式系统日志收集与追踪

日志收集

分布式系统的日志收集通常采用ELK实现,但是Logstash一般不支持高并发,所以通过kafka来削峰,通过filebeat或者flume收集日志到kafka。

很明显分布式系统每个服务的日志都会传输到Elasticsearch上,怎么获取一次请求链路所有服务的日志呢?需要用到全局log_id,最简单的方案是在网关层设置每次请求的log_id,后续所有服务都获取这个log_id打印到日志里面去。

日志追踪

分布式系统一次请求链路涉及多个服务,怎么统计每个服务调用的耗时等信息呢?这是日志追踪组件要解决的问题。

日志追踪组件更多的是请求链路的监控,不涉及日志,但是和日志收集有一个共同点,都需要给每次请求分配一个全局id,所以一般配合着使用。如果不需要日志追踪,只需要在网关层拦截每次请求,分配全局id,后面的每个服务打印日志的时候带上这个全局id即可。

关系

日志追踪目的是监控每次请求链路的各个服务调用耗时等信息,如果发现一个服务调用特别慢,就可以全局id去kibana搜索这次请求链路的所有链路查找问题所在,前提是ELK的日志id和日志追踪组件的全局id是一致的。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值