Spring Boot如何实现分布式追踪和监控

news2025/1/11 12:42:39

Spring Boot如何实现分布式追踪和监控

在分布式系统中,由于服务数量的增加和服务之间的相互调用,会出现跨服务的请求链路较长,难以追踪问题和定位性能瓶颈等问题。因此,分布式追踪和监控变得越来越重要。本文将介绍如何使用 Spring Boot 实现分布式追踪和监控。

在这里插入图片描述

1. 分布式追踪

分布式追踪是指跨服务的请求链路追踪,可以追踪一次请求经过的所有服务和组件,包括请求的耗时、请求的参数、请求的返回值等信息。常用的分布式追踪工具有 Zipkin、SkyWalking 等。下面是使用 Zipkin 实现分布式追踪的示例代码。

1.1 Zipkin Server

首先,需要搭建 Zipkin Server。Zipkin Server 是 Zipkin 的服务端,用于接收跨服务的请求链路数据,并将数据存储到数据库中,同时提供查询服务,用于查询请求链路和性能数据。

可以通过在 pom.xml 文件中添加如下依赖来引入 Zipkin Server:

<dependency>
    <groupId>io.zipkin.java</groupId>
    <artifactId>zipkin-server</artifactId>
    <version>2.23.2</version>
</dependency>

然后,在 Spring Boot 应用程序中添加如下配置:

spring.zipkin.base-url=http://localhost:9411

其中,spring.zipkin.base-url 指定了 Zipkin Server 的地址。

1.2 Zipkin Client

使用 Zipkin 进行分布式追踪需要在每个服务中添加 Zipkin Client。Zipkin Client 是 Zipkin 的客户端,用于将跨服务的请求链路数据发送到 Zipkin Server。

可以通过在 pom.xml 文件中添加如下依赖来引入 Zipkin Client:

<dependency>
    <groupId>org.springframework.cloud</groupId>
    <artifactId>spring-cloud-starter-zipkin</artifactId>
    <version>2.2.7.RELEASE</version>
</dependency>

然后,在 Spring Boot 应用程序中添加如下配置:

spring.zipkin.base-url=http://localhost:9411
spring.sleuth.sampler.probability=1.0

其中,spring.zipkin.base-url 指定了 Zipkin Server 的地址,spring.sleuth.sampler.probability 指定了采样率,即将多少比例的请求链路数据发送到 Zipkin Server。

1.3 分布式追踪示例代码

下面是一个使用 Zipkin 实现分布式追踪的示例代码:

@RestController
public class UserController {
    @Autowired
    private RestTemplate restTemplate;

    @GetMapping("/user/{id}")
    public User getUserById(@PathVariable Long id) {
        Span newSpan = Tracing.currentTracer().nextSpan().name("getUserById").start();
        try (Tracer.SpanInScope ws = tracer.withSpanInScope(newSpan)) {
            User user = restTemplate.getForObject("http://localhost:8080/user/" + id, User.class);
            return user;
        } finally {
            newSpan.finish();
        }
    }
}

在上述代码中,使用了 Spring Cloud Sleuth 的 API 创建了一个新的 Span,然后将 Span 绑定到当前线程中,发送 HTTP 请求时会自动将 Span 的信息添加到请求头中,从而实现跨服务的请求链路追踪。在请求处理完成后,需要手动结束 Span。

2. 分布式监控

除了分布式追踪外,分布式监控也是分布式系统中非常重要的一部分。分布式监控可以监控服务的性能、健康状态、异常情况等,帮助开发人员快速发现和解决问题。常用的分布式监控工具有 Prometheus、Grafana 等。下面是使用 Prometheus 和 Grafana 实现分布式监控的示例代码。

2.1 Prometheus

Prometheus 是一个开源的时间序列数据库,用于存储和查询系统的性能数据。Prometheus 可以通过 HTTP 接口获取监控数据,并提供多种内置的可视化工具,例如 Grafana。

可以通过在 pom.xml 文件中添加如下依赖来引入 Prometheus:

<dependency>
    <groupId>io.micrometer</groupId>
    <artifactId>micrometer-registry-prometheus</artifactId>
    <version>1.7.0</version>
</dependency>

然后,在 Spring Boot 应用程序中添加如下配置:

management.endpoints.web.exposure.include=prometheus
management.metrics.export.prometheus.enabled=true

其中,management.endpoints.web.exposure.include 指定了 Spring Boot Actuator 暴露的端点,management.metrics.export.prometheus.enabled 指定了是否启用 Prometheus 监控。

2.2 Grafana

Grafana 是一个开源的可视化监控工具,可以将 Prometheus 中的监控数据可视化展示,提供多种图表和面板。

可以通过在 Docker 中运行 Grafana 来启动 Grafana 服务:

docker run -d --name=grafana -p 3000:3000 grafana/grafana

然后,在 Grafana 中添加 Prometheus 数据源,并创建 Dashboard,即可将监控数据可视化展示。

2.3 分布式监控示例代码

下面是一个使用 Prometheus 和 Grafana 实现分布式监控的示例代码:

@RestController
public class UserController {
    private static final Counter requestCounter = Metrics.counter("user_request_count");

    @GetMapping("/user/{id}")
    public User getUserById(@PathVariable Long id) {
        requestCounter.increment();
        // ...
    }
}

在上述代码中,使用了 Micrometer 库来定义了一个 Counter,每次请求时增加计数器的值。然后,可以通过 Prometheus 获取该计数器的监控数据,再通过 Grafana 可视化展示。

3. 总结

在分布式系统中,分布式追踪和监控是非常重要的一部分,可以帮助开发人员快速发现和解决问题。本文介绍了使用 Zipkin、Prometheus 和 Grafana 实现分布式追踪和监控的示例代码。在实际使用中,需要根据具体场景选择合适的工具和方案,并注意监控数据的采集和可视化展示,确保系统的性能和可靠性。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/598944.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

怎样一元钱部署自己的AI网站

前段时间我开发了一个简洁的AI问答网站&#xff0c;好多朋友感兴趣&#xff0c;因此我将网站代码在github上开源&#xff0c;并编写此教程&#xff0c;帮助大家快速部署自己的AI网站&#xff0c;会编程的朋友们也可在此基础上定制开发。 前提条件&#xff1a;有自己的ChatGPT账…

AI实战营:开源计算机视觉神器OpenMMLab

目录 OpenMMLab概述 OpenMMLab各开源算法库详细介绍 OpenMMLab开源生态 OpenMMLab概述 部署框架&#xff1a;MMdeploy 算法框架&#xff1a;MMPretrain预训练多模态、MMDetection目标检测、MMDetection3D目标检测、MMRotate旋转目标检测、MMSegmentation语义分割、MMPose姿…

操作系统_进程

操作系统_进程 1 冯•诺依曼体系结构2 操作系统&#xff08;Operator System&#xff09;2.1 设计OS的目的2.2 OS的定位 3 进程3.1 什么是进程&#xff1f;3.2 查看进程3.3 通过fork创建进程使用 if 进行分流如何杀死一个进程 3.4 进程状态R - 运行状态S - 浅睡眠状态D - 磁盘休…

Java中关于ConditionObject的signal()方法的分析

代码块的展示 isHeldExclusively()这个仅持有锁资源的方法&#xff0c;在ReentrantLock中重写进行判断&#xff0c;要是没有持有锁资源那么会返回false&#xff0c;就会出现直接抛异常IllegalMonitorStateException&#xff08;非法监视器状态异常&#xff09;获取排在Conditi…

zookeeper相关,安装,认识......

目录 Zookeeper 1 第一章 Zookeeper简介... 1 1.1 Zookeeper概述和功能... 1 1.2 Zookeper安装... 1 1.3 Zookeper数据模型... 3 第二章 Zookeeper命令操作... 4 1.1 Zookeeper Client 4 1.2 Zookeeper JavaClient 6 第三章 集群角色... 28 Zookeeper 第一章 Zookeepe…

详解Servlet API

目录 前言 HttpServlet HttpServletRequest 代码实例 打印请求信息 通过URL中的queryString进行传递。 通过post请求的body&#xff0c;使用form表单传递 通过POST 请求中的 body 按照 JSON 的格式进行传递 HttpServletResponse 核心方法代码实例 设置状态码 自动刷…

【C++初阶】string 类的认识与学习

在学习string类之前&#xff0c;先在这里推荐2个好用的网站&#xff0c;可以用来查阅C的相关知识 https://cplusplus.com https://en.cppreference.com/w/ 上面的是非官方的&#xff0c;下面的官方的&#xff0c;但是个人感觉还是上面的好用。 一.string 类是什么 简单来说&…

State of GPT (ChatGPT 原理及现状介绍)

State of GPT 演讲信息&#xff1a; 演讲人&#xff1a;Andrej Karpathy (现在OpenAI任职)&#xff0c;之前是特斯拉视觉研发负责人&#xff0c;斯坦福深度学习入门课程 CS231N 讲师演讲主题&#xff1a;受到微软 BUILD2023 邀请&#xff0c;介绍 GPT 的原理及研发现状&#x…

VMware虚拟机安装Ubuntu 22.04详细教程(2023年新版教程)

VMware虚拟机安装Ubuntu 22.04详细教程&#xff08;保姆级教程&#xff09; 大家好&#xff0c;我是洲洲&#xff0c;欢迎关注&#xff0c;一个爱听周杰伦的程序员。关注公众号【程序员洲洲】即可获得10G学习资料、面试笔记、大厂独家学习体系路线等…还可以加入技术交流群欢…

代码创作世界——pytorch深度学习框架数据类型

代码创作世界——pytorch深度学习框架数据类型 torch中的数据类型张量&#xff08;tensor&#xff09; pytorch中的 在数学中&#xff0c;一个单独的数可以成为标量&#xff0c;一行或者一列数组可以称为向量&#xff0c;一个二维数组称为一个矩阵&#xff0c;矩阵中的每一个元…

编译安装nginx服务

目录 编译安装nginx服务 1.关闭防火墙&#xff0c;将安装nginx所需软件包传到/opt目录下 2.安装依赖包 3.创建运行用户、组&#xff08;Nginx服务程序默认以nobody身份运行&#xff0c;建议为其创建专门的用户账号&#xff0c;以便更准确的控制访问权限&#xff09; 4.编译…

11.PasswordEncoder详解与实战

security/day07 这节课我们开始讲PasswordEncoder&#xff0c;如果大家还有印象的话&#xff0c;我们前面有提到过PasswordEncoder: 为什么密码使用{noop}开头呢&#xff1f;我们也做出了相应的解释&#xff0c;这节课开始带大家真正的了解PasswordEncoder, PassworderEncoder…

Android以aar包形式引入hunter-timing,Java(4)

Android以aar包形式引入hunter-timing&#xff0c;Java&#xff08;4&#xff09; &#xff08;1&#xff09;参照这篇文章&#xff1a; https://zhangphil.blog.csdn.net/article/details/130603231https://zhangphil.blog.csdn.net/article/details/130603231 生成.aar文件…

路径规划算法:基于象群优化的路径规划算法- 附代码

路径规划算法&#xff1a;基于象群优化的路径规划算法- 附代码 文章目录 路径规划算法&#xff1a;基于象群优化的路径规划算法- 附代码1.算法原理1.1 环境设定1.2 约束条件1.3 适应度函数 2.算法结果3.MATLAB代码4.参考文献 摘要&#xff1a;本文主要介绍利用智能优化算法象群…

python基础知识(六):列表

目录 1. 列表及其创建2. 列表的特点3. 获取指定元素的索引4. 获取列表中指定索引的元素5. 列表的切片操作6. 列表元素的判断及遍历7. 列表元素的添加操作8. 列表的删除9. 列表元素的修改10. 列表元素的排序11. 列表生成式 1. 列表及其创建 列表由一系列按特定顺序排列的元素组…

如何设计一份优秀的 PPT 文档?

设计一份优秀的 PPT 需要考虑以下几个方面&#xff1a; 目标和受众&#xff1a;明确你的 PPT 的目标是什么&#xff0c;以及你的受众是谁。这将帮助你确定内容的重点和风格。结构和流程&#xff1a;确定清晰的结构和流程&#xff0c;使你的 PPT 有逻辑性。使用标题、副标题和分…

算法与数据结构(三)——排序算法大总结

六大排序算法&#xff1a;插入排序、希尔排序、选择排序、冒泡排序、堆排序、快速排序 一、插入排序二、选择排序三、冒泡排序四、归并排序 一、插入排序 1.从第一个元素开始&#xff0c;该元素可以认为已经被排序 2.取下一个元素tem&#xff0c;从已排序的元素序列从后往前扫…

三、DMSP/OLS、NPP/VIIRS等夜间灯光数据能源碳排放空间化——灯光指数计算(二)

一、前言 续上一节,建成区提取方式有很多种,本文主要介绍一种区别于参考比较法、突变检测法等的领域分析提取建成区范围。 本文以广州市为例,基于领域分析提取2020年广州市建成区范围。 二、具体步骤 (1)加载数据并将广州市夜间灯光数据提取出来 (2)搜索"邻域…

【前端】Vue项目中 JSON 编辑器的使用

Vue项目中 JSON 编辑器的使用 一、背景描述二、vue-json-edit2.1 依赖安装2.2 示例代码2.3 效果图 三、vue-json-pretty3.1 依赖安装3.2 示例代码3.3 效果图 四、bin-code-editor4.1 依赖安装4.2 示例代码4.3 效果图 五、vue-json-views5.1 依赖安装5.2 示例代码5.3 效果图5.4 …

json库——jsoncpp

一、jsoncpp简介 JsonCpp是一个开源的C库&#xff0c;用于解析和生成JSON&#xff08;JavaScript Object Notation&#xff09;数据格式。JSON是一种轻量级的数据交换格式&#xff0c;广泛用于各种应用程序和网络服务中。 JsonCpp提供了简单和易用的API&#xff0c;可以方便地解…