Spring Boot 项目如何做性能监控?

碎形独白
• 阅读 1408
作者:zhaoyh
http://zhaoyh.com.cn/

Spring Boot特别适合团队构建各种可快速迭代的微服务,同时为了减少程序本身监控系统的开发量,Spring Boot 提供了 actuator 模块,可以很方便的对你的 Spring Boot 程序做监控。

1. actuator接口说明

Spring Boot 应用中加入监控很简单,只需要在pom.xml文件中加入以下依赖:

<dependency>  
    <groupId>org.springframework.boot</groupId>  
    <artifactId>spring-boot-starter-actuator</artifactId>  
</dependency>   

为了保证actuator接口的敏感性,在配置文件中,开放安全属性配置:

management.security.enabled=false   

这样就能允许你查看 Spring Boot 进程的actuator信息了。

启动Spring Boot程序,在启动日志里看到可访问的actuator接口:

Spring Boot 项目如何做性能监控?

通过这些,我们可以实时的获取应用的各项监控指标。另外,关注微信公众号:Java技术栈,在后台回复:boot,可以获取我整理的 N 篇 Spring Boot 教程,都是干货。

actuator的接口分为原生接口和用户自定义接口。
原生接口主要有如下几个:

Spring Boot 项目如何做性能监控?

如果你想关闭某个接口,比如关闭health接口,可以直接设置:

endpoints.health.enabled=false   

2. 监控展示

2.1 JConsole

JConsole是一个内置Java性能分析器,如果你本机已经配置了jdk的话,可直接命令行输入jconsole,打开后的页面如下图所示:

Spring Boot 项目如何做性能监控?

选择你要监控的进程,点击连接即可进入该Java进程的监控首页,如下图所示:

Spring Boot 项目如何做性能监控?

可以很详细地展示进程的内存、CPU、类信息。

2.2 Spring Boot Admin

Spring Boot Admin是一款监控和管理 Spring Boot 应用程序的开源软件。Spring Boot Admin读取actuator的接口数据,并通过 Spring Boot Admin UI 将实时数据展示在前端。

创建一个Spring Boot Admin Server,首先需要创建一个基本的 Spring Boot 应用程序,这个就不做赘述了,并加入以下依赖:

<dependency>  
    <groupId>de.codecentric</groupId>  
    <artifactId>spring-boot-admin-server</artifactId>  
    <version>1.5.7</version>  
</dependency>  
<dependency>  
    <groupId>de.codecentric</groupId>  
    <artifactId>spring-boot-admin-server-ui</artifactId>  
    <version>1.5.7</version>  
</dependency>   

server.port端口设置为8090,并注册到你的eureka服务上。

启动类中使用注解开启服务:

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

浏览器访问:http://localhost:8090 即可看到如下Spring Boot Admin Server的页面:

Spring Boot 项目如何做性能监控?

在任意需要被监控的Spring Boot应用程序上,添加依赖:

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

启动客户端后,稍等片刻,Spring Boot Admin Server从Eureka上拿到注册信息后,即可在 http://localhost:8090 上看到应用程序的监控信息了:

Spring Boot 项目如何做性能监控?

3. FAQ

  • Spring Boot Admin Server上可以配置邮件告警信息,添加自己的Email即可收到告警信息。
  • Spring Boot Admin Server监控的应用程序服务,需要和Spring Boot Admin Server都注册到Eureka上。

关注公众号Java技术栈回复"面试"获取我整理的2020最全面试题及答案。

推荐去我的博客阅读更多:

1.Java JVM、集合、多线程、新特性系列教程

2.Spring MVC、Spring Boot、Spring Cloud 系列教程

3.Maven、Git、Eclipse、Intellij IDEA 系列工具教程

4.Java、后端、架构、阿里巴巴等大厂最新面试题

觉得不错,别忘了点赞+转发哦!

点赞
收藏
评论区
推荐文章
blmius blmius
4年前
MySQL:[Err] 1292 - Incorrect datetime value: ‘0000-00-00 00:00:00‘ for column ‘CREATE_TIME‘ at row 1
文章目录问题用navicat导入数据时,报错:原因这是因为当前的MySQL不支持datetime为0的情况。解决修改sql\mode:sql\mode:SQLMode定义了MySQL应支持的SQL语法、数据校验等,这样可以更容易地在不同的环境中使用MySQL。全局s
Wesley13 Wesley13
3年前
MySQL部分从库上面因为大量的临时表tmp_table造成慢查询
背景描述Time:20190124T00:08:14.70572408:00User@Host:@Id:Schema:sentrymetaLast_errno:0Killed:0Query_time:0.315758Lock_
美凌格栋栋酱 美凌格栋栋酱
7个月前
Oracle 分组与拼接字符串同时使用
SELECTT.,ROWNUMIDFROM(SELECTT.EMPLID,T.NAME,T.BU,T.REALDEPART,T.FORMATDATE,SUM(T.S0)S0,MAX(UPDATETIME)CREATETIME,LISTAGG(TOCHAR(
Stella981 Stella981
3年前
React Hooks实现异步请求实例—useReducer、useContext和useEffect代替Redux方案
<blockquote本文是学习了2018年新鲜出炉的ReactHooks提案之后,针对<strong异步请求数据</strong写的一个案例。注意,本文假设了:<br1.你已经初步了解<codehooks</code的含义了,如果不了解还请移步<ahref"https://reactjs.org/docs/hooksintro.html
Wesley13 Wesley13
3年前
FLV文件格式
1.        FLV文件对齐方式FLV文件以大端对齐方式存放多字节整型。如存放数字无符号16位的数字300(0x012C),那么在FLV文件中存放的顺序是:|0x01|0x2C|。如果是无符号32位数字300(0x0000012C),那么在FLV文件中的存放顺序是:|0x00|0x00|0x00|0x01|0x2C。2.  
Stella981 Stella981
3年前
SpringBoot整合Redis乱码原因及解决方案
问题描述:springboot使用springdataredis存储数据时乱码rediskey/value出现\\xAC\\xED\\x00\\x05t\\x00\\x05问题分析:查看RedisTemplate类!(https://oscimg.oschina.net/oscnet/0a85565fa
Wesley13 Wesley13
3年前
mysql设置时区
mysql设置时区mysql\_query("SETtime\_zone'8:00'")ordie('时区设置失败,请联系管理员!');中国在东8区所以加8方法二:selectcount(user\_id)asdevice,CONVERT\_TZ(FROM\_UNIXTIME(reg\_time),'08:00','0
Wesley13 Wesley13
3年前
PHP创建多级树型结构
<!lang:php<?php$areaarray(array('id'1,'pid'0,'name''中国'),array('id'5,'pid'0,'name''美国'),array('id'2,'pid'1,'name''吉林'),array('id'4,'pid'2,'n
Easter79 Easter79
3年前
SpringBoot整合Redis乱码原因及解决方案
问题描述:springboot使用springdataredis存储数据时乱码rediskey/value出现\\xAC\\xED\\x00\\x05t\\x00\\x05问题分析:查看RedisTemplate类!(https://oscimg.oschina.net/oscnet/0a85565fa
Wesley13 Wesley13
3年前
Java日期时间API系列36
  十二时辰,古代劳动人民把一昼夜划分成十二个时段,每一个时段叫一个时辰。二十四小时和十二时辰对照表:时辰时间24时制子时深夜11:00凌晨01:0023:0001:00丑时上午01:00上午03:0001:0003:00寅时上午03:00上午0
Stella981 Stella981
3年前
Spring Boot 项目如何做性能监控?
作者:zhaoyhhttp://zhaoyh.com.cn/(https://www.oschina.net/action/GoToLink?urlhttp%3A%2F%2Fzhaoyh.com.cn%2F)SpringBoot特别适合团队构建各种可快速迭代的微服务,同时为了减少程序本身监控系统的开发量,SpringBoot(http