SpringBoot之程序性能监控

经典名言--无监控不调优

  • 要想进行SpringBoot项目调优,首选需要监控项目运行时情况。
    当下SpringBoot项目逐渐替代早期的Spring项目,随着用户量的增加,Spring Boot框架也提供了actuator模块。该模块很方便的对你的Spring Boot程序做监控。在SpringBoot中加入监控的方法只需要把相应的监控依赖actuator引入即可。
  • pom文件中引入actuator依赖
    首先需要在pom.xml文件中引入以下依赖:
<dependency>
  <groupId>org.springframework.boot</groupId>
  <artifactId>spring-boot-starter-actuator</artifactId>
</dependency>
  • 为了保证actuator接口的敏感性,需要在配置文件中开放安全属性配置
    配置参数如下:
management.security.enabled=false

配置后就可以允许你查看Spring Boot进程的actuator信息了

  • 启动日志查看

    • 启动SpringBoot程序,控制台日志里可以看到actuator接口信息



      通过上图打印信息,我们可以实时的获取应用的各项监控指标,用于后期的问题排查和调优。

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

路径 说明
health 展示了进程的健康状态
beans 程序创建的Bean
configprops 配置信息,属性值
env 环境属性
info info开头的程序属性信息
metrics 度量指标,比如JVM和HTTP请求等
trace HTTP的详细请求信息
mappings 所有的URL路径映射关系
dump 线程快照信息
heapdump 内存快照信息

如果你想关闭某个接口,比如关闭health接口,可以通过设置来实现:

endpoints.health.enabled=false
  • 监控展示器-JConsole
    JConsole说明:是一个内置Java性能分析器,如果你本机已经配置了jdk的话,可直接命令行输入jconsole,打开后的页面如下图所示:



    选择你要监控的进程,点击连接即可进入该Java进程的监控首页,如下图所示(类似jdk自带的jvisualvm):



    jvisualvm监控图对比
  • 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);
  }
}

在浏览器输入url:http://localhost:8090
就可以看到Spring Boot Admin Server的页面信息

  • 在任意需要被监控的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上拿到注册信息后完成认证
    在浏览器中输入url:http://localhost:8090 就可以看到应用程序的监控信息了。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,254评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,875评论 3 387
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,682评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,896评论 1 285
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,015评论 6 385
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,152评论 1 291
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,208评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,962评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,388评论 1 304
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,700评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,867评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,551评论 4 335
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,186评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,901评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,142评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,689评论 2 362
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,757评论 2 351

推荐阅读更多精彩内容

  • Q: 什么是spring boot?A: 多年来,随着新功能的增加,spring变得越来越复杂。只需访问页面htt...
    Java高级架构狮阅读 3,805评论 0 8
  • 第 III 部分Spring Boot 系统监控、测试与运维 Spring Boot 应用监控:Actuator与...
    光剑书架上的书阅读 10,263评论 2 17
  • 有一种人西装革履,却道德沦陷,用权利和地位满足私欲;另一种人穷困潦倒,懦弱卑微,只能无助地抱怨着不公。也许也许……...
    拣爱阅读 193评论 0 1
  • 在我的人生字典里,从没有哪一年象今年一样心事重重,郁郁寡欢。多年以后,再回首2018年,不论从哪个角度来看,对我应...
    七味随笔阅读 758评论 2 3
  • Day 4--- 行书营《持续的幸福》20170209 《持续的幸福》作者马丁·塞利格曼是“积极心理学之父”。塞利...
    橙长之路阅读 242评论 1 4