SpringCloud Admin实战之健康检查与全链路告警深度解读

 更新时间:2025年05月22日 09:12:53   作者:小马不敲代码  
这篇文章主要介绍了SpringCloud Admin实战之健康检查与全链路告警,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教

一、引言

在 微服务架构中,服务健康监控与 故障告警是保障系统稳定运行的关键。

Spring Cloud Admin作为 Spring Cloud 生态中的核心监控工具,提供 开箱即用的 健康检查与 告警功能,帮助开发者更方便地监控和管理服务。

实时告警 - 集成邮件、Slack等告警渠道,构建高效告警体系。

集中化管理 - 深入解析 Spring Cloud Admin的 核心优势和应用场景。

二、Spring Cloud 链路监控(Admin)核心组件

2.1 Spring Boot Actuator:健康检查与性能监控

Spring Boot Actuator 是 Spring Cloud Admin的核心依赖,提供了丰富的监控端点,帮助开发者实时监控服务的健康状态和性能指标。

1. 原理

  • 健康检查:

通过 /actuator/health端点,Actuator 可实时监控服务的健康状态,包括数据库连接、磁盘空间、外部服务依赖等。

  • 性能监控:

通过 /actuator/metrics端点,Actuator 提供CPU、内存、线程、HTTP 请求等性能指标。

  • 自定义健康检查:

开发者可通过实现 HealthIndicator接口,自定义健康检查逻辑。

2. 示例

默认健康检查

访问 /actuator/health,返回示例:

{
  "status": "UP",
  "components": {
    "db": { "status": "UP" },
    "diskSpace": { "status": "UP" }
  }
}

自定义健康检查

实现 HealthIndicator接口,检查数据库连接状态:

@Component
public class DatabaseHealthIndicator implements HealthIndicator {
    @Override
    public Health health() {
        if (checkDatabaseConnection()) {
            return Health.up().build();
        } else {
            return Health.down().withDetail("Error", "Database connection failed").build();
        }
    }
}

访问 /actuator/health,返回示例:

{
  "status": "DOWN",
  "components": {
    "db": { "status": "DOWN", "details": { "Error": "Database connection failed" } },
    "diskSpace": { "status": "UP" }
  }
}

2.2 Admin Server:集中化监控与管理

Admin Server 是 Spring Cloud Admin的核心组件,负责集中化管理所有注册服务的监控数据。

1. 原理

  • 服务发现:Admin Server 可自动发现注册到 Eureka或 Consul的服务,并展示其健康状态和性能指标。
  • 统一监控面板:提供可视化界面,实时查看所有服务的运行状态。
  • 日志管理:支持动态调整日志级别,便于问题排查。

2. 示例

示例 1:直接通过 spring.boot.admin.client.url 注册到 Admin Server。

项目结构

spring-cloud-admin-example1/
├── admin-server/                # 管理服务模块
│   ├── src/main/java/com/example/AdminServerApplication.java
│   ├── src/main/resources/application.yml
│   ├── pom.xml
├── user-service/                # 用户服务模块
│   ├── src/main/java/com/example/UserServiceApplication.java
│   ├── src/main/resources/application.yml
│   ├── pom.xml
├── order-service/               # 订单服务模块
│   ├── src/main/java/com/example/OrderServiceApplication.java
│   ├── src/main/resources/application.yml
│   ├── pom.xml

步骤 1:启动 Admin Server

在AdminServerApplication.java 中 ,添加 @EnableAdminServer 注解。

@SpringBootApplication
@EnableAdminServer
public class AdminServerApplication {
    public static void main(String[] args) {
        SpringApplication.run(AdminServerApplication.class, args);
    }
}

配置 Admin Server(application.yml)

server:
  port: 8080  # Admin Server 端口

启动 Admin Server

运行 AdminServerApplication,访问 http://localhost:8080,查看 Admin Server 控制面板。

步骤 2:客户端服务注册到 Admin Server

user-service和 order-service是两个独立的 Spring Boot 项目。

添加 Spring Cloud Admin 客户端依赖 (pom.yml)

<dependency>
    <groupId>de.codecentric</groupId>
    <artifactId>spring-boot-admin-starter-client</artifactId>
</dependency>

在application.yml 中配置客户端

spring:
  boot:
    admin:
      client:
        url: http://localhost:8080  # Admin Server 的地址
server:
  port: 8081  # user-service 端口

启动客户端服务

分别运行 UserServiceApplication和 OrderServiceApplication。

访问 http://localhost:8080,查看 user-service和 order-service是否成功注册。

示例 2:通过 Eureka 作为服务注册与发现中心

项目结构

spring-cloud-admin-example2/
├── eureka-server/               # Eureka 服务注册中心模块
│   ├── src/main/java/com/example/EurekaServerApplication.java
│   ├── src/main/resources/application.yml
│   ├── pom.xml
├── admin-server/                # 管理服务模块
│   ├── src/main/java/com/example/AdminServerApplication.java
│   ├── src/main/resources/application.yml
│   ├── pom.xml
├── user-service/                # 用户服务模块
│   ├── src/main/java/com/example/UserServiceApplication.java
│   ├── src/main/resources/application.yml
│   ├── pom.xml
├── order-service/               # 订单服务模块
│   ├── src/main/java/com/example/OrderServiceApplication.java
│   ├── src/main/resources/application.yml
│   ├── pom.xml

步骤 1:启动 Eureka Server

在 EurekaServerApplication.java 中添加 @EnableEurekaServer 注解。

@SpringBootApplication
@EnableEurekaServer
public class EurekaServerApplication {
    public static void main(String[] args) {
        SpringApplication.run(EurekaServerApplication.class, args);
    }
}

在 application.yml 中配置 Eureka Server

server:
  port: 8761  # Eureka Server 端口
eureka:
  instance:
    hostname: localhost
  client:
    register-with-eureka: false  # Eureka Server 不注册自己
    fetch-registry: false

启动 Eureka Server

运行 EurekaServerApplication,访问 http://localhost:8761,查看 Eureka 控制面板。

步骤 2:启动 Admin Server

在 AdminServerApplication.java 中添加 @EnableAdminServer 注解。

@SpringBootApplication
@EnableAdminServer
public class AdminServerApplication {
    public static void main(String[] args) {
        SpringApplication.run(AdminServerApplication.class, args);
    }
}

在 application.yml 中配置 Admin Server,使其从 Eureka 发现服务

spring:
  application:
    name: admin-server  # Admin Server 名称
  cloud:
    discovery:
      enabled: true  # 启用服务发现
eureka:
  client:
    service-url:
      defaultZone: http://localhost:8761/eureka  # Eureka Server 地址

启动 Admin Server

运行 AdminServerApplication,访问 http://localhost:8080,查看 Admin Server 控制面板。

步骤 3:客户端服务注册到 Eureka

user-service和 order-service是两个独立的 Spring Boot 项目。

在 pom.xml 中添加 Spring Cloud Admin 客户端和 Eureka 客户端依赖

<dependency>
    <groupId>de.codecentric</groupId>
    <artifactId>spring-boot-admin-starter-client</artifactId>
</dependency>
<dependency>
    <groupId>org.springframework.cloud</groupId>
    <artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
</dependency>

在 application.yml 中配置客户端

spring:
  application:
    name: user-service  # 服务名称
  cloud:
    discovery:
      enabled: true  # 启用服务发现
  boot:
    admin:
      client:
        enabled: true  # 启用 Admin Client
eureka:
  client:
    service-url:
      defaultZone: http://localhost:8761/eureka  # Eureka Server 地址
server:
  port: 8081  # user-service 端口

启动客户端服务

  • 分别运行 UserServiceApplication和 OrderServiceApplication。
  • 访问 http://localhost:8761,查看服务是否注册到 Eureka。
  • 访问 http://localhost:8080,查看服务是否注册到 Admin Server。

3.总结

  • 直接注册到 Admin Server:适合小型项目或测试环境。
  • 通过 Eureka 注册:适合生产环境,支持大规模微服务架构。

2.3 告警通知模块:实时告警与通知

Spring Cloud Admin 支持多种告警渠道,帮助开发者在服务异常时及时收到通知。

1. 原理

  • 邮件告警:通过 SMTP 配置,将告警信息发送到指定邮箱。
  • Slack 告警:通过 Webhook 集成 Slack,将告警信息推送到指定频道。
  • 多通道告警:支持同时配置多种告警渠道,实现分级告警。

2. 示例

示例1:邮件告警配置

在 Admin Server的 application.yml文件中

spring:
  mail:
    host: smtp.example.com  # SMTP 服务器地址
    port: 587               # SMTP 端口
    username: user@example.com  # 发件邮箱
    password: yourpassword  # 发件邮箱密码
  cloud:
    admin:
      notify:
        mail:
          enabled: true    # 启用邮件告警
          to: admin@example.com  # 收件邮箱

验证邮件告警

  • 1.启动 admin-server。
  • 2.模拟服务故障(如关闭 user-service)。
  • 3.检查收件邮箱,观察是否收到告警邮件。

示例2:Slack 告警配置

在 Admin Server的 application.yml文件中

spring:
  cloud:
    admin:
      notify:
        slack:
          enabled: true  # 启用 Slack 告警
          webhook-url: https://hooks.slack.com/services/your/webhook  # Slack Webhook URL

验证 Slack 告警

  • 1.启动 admin-server。
  • 2.模拟服务故障(如关闭 order-service)。
  • 3.检查 Slack 频道,观察是否收到告警消息。

示例3:多通道告警配置

同时配置 邮件和 Slack告警,可以在 application.yml中同时添加邮件和 Slack 的配置:

spring:
  mail:
    host: smtp.example.com
    port: 587
    username: user@example.com
    password: yourpassword
  cloud:
    admin:
      notify:
        mail:
          enabled: true
          to: admin@example.com
        slack:
          enabled: true
          webhook-url: https://hooks.slack.com/services/your/webhook

验证告警

模拟服务故障

  • 关闭 user-service或 order-service。
  • 观察 Admin Server控制面板中服务的健康状态变化。

检查告警通知

  • 邮件告警:检查收件邮箱,确认是否收到告警邮件。
  • Slack 告警:检查 Slack 频道,确认是否收到告警消息。

3. 总结

  • 邮件告警:在 application.yml中配置 SMTP 信息,启用 邮件告警。
  • Slack 告警:在 application.yml中配置 Slack Webhook URL,启用 Slack 告警。
  • 多通道告警:可以同时配置 邮件和 Slack 告警,实现 分级通知。

通过以上配置示例,读者可以轻松实现 Spring Cloud Admin的告警通知功能,确保在服务异常时及时收到通知。

2.4 日志与追踪集成:问题排查与链路追踪

Spring Cloud Admin 支持日志管理与链路追踪,帮助开发者快速定位问题。

1. 原理

日志管理

Spring Cloud Admin 本身不直接管理日志,但可通过集成 Spring Boot Actuator提供的 /actuator/loggers端点,实现 动态调整微服务的日志级别,无需重启服务。

链路追踪

在 Spring Cloud 微服务架构中,链路追踪是常见需求,通常通过以下组件实现:

主要组件

Spring Cloud Sleuth:

  • 自动为每个请求添加唯一追踪标识(Trace ID、Span ID)。
  • 记录请求在微服务间的调用链路,便于故障排查。

Zipkin:

  • 分布式追踪系统,用于 收集并可视化Sleuth生成的链路数据。

Spring Cloud Admin :

不直接参与链路追踪数据的生成或存储,但它能提供 以下能力:

  • 集中化入口:支持快速跳转至 Zipkin 控制台,无需逐个访问微服务的追踪页面。
  • 问题定位:结合 健康状态与日志信息,辅助故障分析,提高排查效率。

2. 示例

示例 1:动态调整日志级别

通过 Admin Server动态调整服务的日志级别,无需重启服务即可生效。

步骤1:日志配置

# user-service/application.yml
spring:
  application:
    name: user-service
  server:
    port: 8081  # 服务端口

# 初始日志级别配置
logging:
  level:
    com.example: INFO  # 设置 com.example 包的日志级别为 INFO

# 启用日志管理端点
management:
  endpoint:
    loggers:
      enabled: true  # 启用日志管理端点

步骤2:动态调整日志级别

通过 Admin Server动态调整 user-service的日志级别。

获取服务实例 ID:

  • 1.访问 Admin Server控制面板(http://localhost:8080)。
  • 2.找到 user-service的实例 ID(例如:user-service-8081)。

使用 curl 命令动态调整日志级别:

将 com.example包的日志级别从 INFO调整为 DEBUG:

curl -X POST http://localhost:8080/instances/user-service-8081/actuator/loggers/com.example \
     -H "Content-Type: application/json" \
     -d '{"configuredLevel": "DEBUG"}'

参数说明

  •  {instanceId}:服务的实例 ID,可以在 Admin Server控制面板中查看。
  •  com.example:需要调整日志级别的包名。

步骤3:验证日志级别调整

查看 user-service的日志输出,确认日志级别已调整为 DEBUG。

例如, user-service中有以下日志代码:

import org.slf4j.Logger;
import org.slf4j.LoggerFactory;

@RestController
public class UserController {
    private static final Logger logger = LoggerFactory.getLogger(UserController.class);

    @GetMapping("/users")
    public String getUsers() {
        logger.debug("Debug log message");  // 调试日志
        logger.info("Info log message");   // 信息日志
        return "User list";
    }
}

调整日志级别后,Debug log message将会输出到日志中。

示例 2:链路追踪集成

目标

通过 Sleuth + Zipkin实现 全链路追踪,并结合 Spring Cloud Admin快速定位问题。

步骤 1:添加 Sleuth 和 Zipkin 依赖

在 user-service和 order-service的 pom.xml文件中,添加如下依赖:

<!-- Sleuth 依赖 -->
<dependency>gt;  
    <groupId>org.springframework.cloud</groupId>  
    <artifactId>spring-cloud-starter-sleuth</artifactId>  
</dependency>  

<!-- Zipkin 客户端依赖 -->
<dependency>  
    <groupId>org.springframework.cloud</groupId>  
    <artifactId>spring-cloud-sleuth-zipkin</artifactId>  
</dependency>  

步骤 2:配置 Zipkin 服务地址

在 user-service和 order-service的 application.yml中,指定 Zipkin 服务器地址:

spring:  
  zipkin:  
    base-url: http://localhost:9411  # Zipkin Server 地址  
  sleuth:  
    sampler:  
      probability: 1.0  # 采样率(1.0 表示 100% 采集)  

步骤 3:启动 Zipkin Server

通过 Docker 快速启动 Zipkin:

docker run -d -p 9411:9411 openzipkin/zipkin  

步骤 4:验证链路追踪

发起请求

在 order-service调用 user-service的接口(如 /users)。

查看链路数据

  • 访问 Zipkin 控制台:http://localhost:9411
  • 搜索 Trace ID,查看完整的调用链路。

示例:

  • order-service ➝ user-service
  • Trace ID: abc123xyz456

步骤 5:结合 Spring Cloud Admin 定位问题

状态监控

  • 在 Admin Server控制面板,发现 user-service状态异常(如 DOWN)。

日志辅助

  • 通过 Admin Server动态调整 user-service的 日志级别为 DEBUG,查看详细错误日志。

跳转 Zipkin

  • 在 Admin Server的 服务详情页,直接跳转到 Zipkin 控制台,分析异常请求的完整链路。

3. 关键问题解答

Q1:链路追踪是 Spring Cloud Admin 的功能吗?

否。链路追踪由 Sleuth + Zipkin实现,是 Spring Cloud 微服务的通用能力。

Admin Server 的作用:

  • 提供集中化入口,关联服务健康状态、日志与链路追踪数据。
  • 辅助开发者快速定位问题(如:服务异常时,直接跳转至 Zipkin分析链路)。

Q2:Admin Server 是否需要额外配置以支持链路追踪?

否。Admin Server 无需特殊配置,只需确保微服务正确集成 Sleuth + Zipkin。

Admin Server 仅作为监控入口,不存储或处理链路数据。

三、Spring Cloud 链路监控(Admin)集成示例

1. 场景

构建一个包含 user-service和 order-service的微服务系统,通过 Spring Cloud Admin实现以下目标:

  • 集中化监控服务的健康状态与性能指标。
  • 集成邮件告警,实时接收服务异常通知。

2. 配置步骤与验证

本示例基于 第二部分的示例 1(直接注册到 Admin Server),仅补充关键集成步骤:

步骤1: Admin Server 配置

  • 创建 Admin Server应用(参考 2.2 节示例 1代码)。
  • 启动后访问 http://localhost:8080进入控制面板。

步骤2:客户端服务注册

  • 在 user-service和 order-service中添加 Admin Client依赖(见 2.2 节示例 1)。
  • 配置 spring.boot.admin.client.url指向 Admin Server(代码与配置参考 2.2 节)。

步骤3:邮件告警集成

  • 在 Admin Server的 application.yml中配置 SMTP 和邮件接收地址(配置代码直接复用 2.3 节示例 1)。

步骤4:全链路验证

  • 健康检查:访问 Admin控制面板,确认服务状态为 UP。
  • 告警触发:手动关闭 user-service,观察控制面板状态变更为 DOWN,并检查收件箱是否收到告警邮件。

本示例展示了如何快速构建一个包含 健康监控、集中化管理和实时告警的完整链路监控体系,适用于 中小型项目快速落地。

四、Spring Cloud 链路监控(Admin)最佳实践

4.1 分级告警策略

1. 低优先级告警(非紧急问题)

  • 通知方式:通过 Slack 通知(配置参考 2.3 节示例 2)。
  • 适用场景:适用于服务降级、非核心服务异常、临时性能波动等情况。

2. 高优先级告警(关键故障)

  • 通知方式:通过 邮件 + 短信双通道,确保核心服务问题 及时响应。

配置示例:

Admin Server 的 application.yml

spring:  
  cloud:  
    admin:  
      notify:  
        mail:  
          enabled: true  # 邮件配置参考 2.3 节示例1  
        sms:  
          enabled: true  
          phone-numbers: +1234567890  # 接收短信的手机号 

AWS SNS 短信服务配置

aws:  
  sns:  
    topic-arn: arn:aws:sns:us-east-1:1234567890:alert-topic  # SNS 主题 ARN  
    region: us-east-1  # AWS 区域  
    access-key: ${AWS_ACCESS_KEY}  # 从环境变量注入访问密钥  
    secret-key: ${AWS_SECRET_KEY}  # 从环境变量注入密钥  

依赖项

在 Admin Server 的 pom.xml 中添加 AWS SNS 依赖

<dependency>  
  <groupId>com.amazonaws</groupId>  
  <artifactId>aws-java-sdk-sns</artifactId>  
  <version>1.12.500</version>  
</dependency>  

验证步骤:

模拟服务宕机

  • 关闭核心服务(如 user-service)。
  • 观察 Admin Server控制面板,确认服务状态变为 DOWN。

检查告警通知

  • 邮件:登录 admin@example.com邮箱,确认收到 标题为 [紧急告警]
  • 服务异常:user-service的邮件。
  • 短信:检查手机 +1234567890是否收到 包含 [CRITICAL] user-service 已宕机的短信。

3. 注意事项

敏感信息保护:

  • access-key和 secret-key应通过环境变量或配置中心管理,禁止硬编码。

失败回退:

  • 建议配置重试机制,避免短信服务不可用时告警丢失。

4.2 扩展监控能力

1. 自定义健康检查

  • 通过实现 HealthIndicator 接口(实现逻辑参考 2.1 节示例),扩展健康检查逻辑,例如:
  • 监控依赖的第三方 API 状态。
  • 检测数据库连接、缓存可用性。

2. 日志动态调整

  • Admin Server支持 实时调整服务日志级别,无需重启服务。
  • 操作命令参考 2.4 节示例 1。

4.3 高可用部署方案

1.Admin Server 集群化

部署多个 Admin Server 实例,通过 Redis 共享监控数据,提高系统可用性。

配置示例(Admin Server 连接 Redis)

spring:  
  redis:  
    host: redis-host  
    port: 6379  
  boot:  
    admin:  
      redis:  
        enabled: true  

2.客户端重试机制

配置客户端在 Admin Server 短暂不可用时自动重试,提高稳定性。

配置示例(客户端重试)

spring:  
  boot:  
    admin:  
      client:  
        url: http://admin-server:8080  
        retry:  
          max-attempts: 3  
      initial-interval: 1000  

验证步骤

查看客户端日志,确认重试行为,例如:

Retrying to connect to Admin Server...

4.4 生产环境建议

1. 资源隔离

  • Admin Server部署在 独立集群,避免与业务服务争抢资源。

2.安全加固

  • 为 Actuator 端点添加认证(集成 Spring Security)。
  • 限制 /actuator 端点的公网暴露,避免安全风险。

3.监控数据归档

  • 定期导出健康检查记录到 Elasticsearch,便于 历史追溯与分析。

总结

核心总结

Spring Cloud Admin的核心价值与功能:

1. 开箱即用的监控方案

  • 基于 Spring Boot Actuator提供 健康检查(如 数据库、磁盘空间)、性能指标(CPU、内存)等核心功能。
  • 支持 自定义健康检查逻辑(通过 HealthIndicator接口)。

2. 多通道实时告警

  • 集成邮件、Slack等通知渠道,支持分级告警策略(如 、非紧急问题推送 Slack,关键故障触发邮件 + 短信)。

3. 集中化管控优势

  • 统一 监控面板展示所有服务状态,支持 动态调整日志级别,并可集成 Sleuth/Zipkin实现 链路追踪。

4. 高可用与扩展性

  • 支持 Admin Server 集群部署,结合客户端重试机制保障监控稳定性。

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • Java 生成图片验证码3种方法(字母、加减乘除、中文)

    Java 生成图片验证码3种方法(字母、加减乘除、中文)

    这篇文章主要介绍了Java 生成图片验证码3种方法(字母、加减乘除、中文),文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-01-01
  • 解决Error:(1, 1) java: 非法字符: '\ufeff'问题

    解决Error:(1, 1) java: 非法字符: '\ufeff'问题

    这篇文章主要介绍了解决Error:(1, 1) java: 非法字符: '\ufeff'问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2023-11-11
  • 使用JVMTI实现SpringBoot的jar加密,防止反编译

    使用JVMTI实现SpringBoot的jar加密,防止反编译

    这篇文章主要介绍了使用JVMTI实现SpringBoot的jar加密,防止反编译问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2023-08-08
  • Mybatis多参数及实体对象传递实例讲解

    Mybatis多参数及实体对象传递实例讲解

    在使用Mybatis的时候,经常会有各种各样的参数传递,不同类型,不同个数的参数,下面小编通过例子给大家讲解下Mybatis多参数及实体对象传递,一起看看吧
    2016-12-12
  • IDEA安装Leetcode插件的教程

    IDEA安装Leetcode插件的教程

    这篇文章主要介绍了IDEA安装Leetcode插件的教程,本文通过图文并茂的形式给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2020-11-11
  • springboot 如何禁用某项健康检查

    springboot 如何禁用某项健康检查

    这篇文章主要介绍了springboot 如何禁用某项健康检查的操作,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2021-07-07
  • 浅谈JAVA Actor模型的一致性与隔离性

    浅谈JAVA Actor模型的一致性与隔离性

    这篇文章主要介绍了JAVA Actor模型的的相关资料,文中讲解非常细致,帮助大家更好的学习JAVA,感兴趣的朋友可以了解下
    2020-06-06
  • Java中instanceOf关键字的用法及特性详解

    Java中instanceOf关键字的用法及特性详解

    当我们在进行向下转型时,如果两个对象之间没有直接或间接的继承关系,在转换时有可能会产生强制类型转换异常,我们可以使用java中自带的instanceOf关键字来解决这个问题,所以本篇文章,会带大家学习instanceOf的用法及特性,需要的朋友可以参考下
    2023-05-05
  • 8种常见的Java不规范代码

    8种常见的Java不规范代码

    本文主要介绍了8种常见的Java不规范代码。具有很好的参考价值,下面跟着小编一起来看下吧
    2017-01-01
  • Java虚拟机常见内存溢出错误汇总

    Java虚拟机常见内存溢出错误汇总

    这篇文章主要汇总了Java虚拟机常见的内存溢出错误,警示大家,避免出错,感兴趣的朋友可以了解下
    2020-09-09

最新评论