Spring Boot 微服务之程序性能监控

点击上方“ 库技术团队 ”关注,选择“ 设为星标

回复“ 面试题 ”领 《96份:3265页面试题》

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 微服务之程序性能监控

通过这些,我们可以实时的获取应用的各项监控指标。

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

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

如果你想关闭某个接口,比如关闭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上。

作者:zhaoyh

http://zhaoyh.com.cn

《第2版:互联网大厂面试题》

最近又赶上跳槽的高峰期,好多粉丝,都问我要有没有最新面试题,索性,我就把我看过的和我面试中的真题,及答案都整理好, 整理了 《第2版:互联网大厂面试题》 分类  92  PDF 累计 3625页! 我会持续更新中,马上就出第三版,涵盖大厂算法会更多!

Spring Boot 微服务之程序性能监控

第2版:题库非常全面

包括 Java 集合、JVM、多线程并发编程设计模式、Spring全家桶、Java、MyBatis、ZooKeeper、Dubbo、Elasticsearch、Memcached、MongoDB、Redis、MySQL、RabbitMQ、Kafka、Linux、Netty、Tomcat、Python、HTMLCSS、Vue、React、JavaScriptAndroid 大数据阿里巴巴等大厂面试题等、等技术栈!

第2版:面试题,怎么领取?

扫码关注, 我另一个公众号 架构师专栏

(对,就是我小号)

没错,扫码关注,即可下载

(这是神奇的二维码,你不用回复关键字)

原文 

http://mp.weixin.qq.com/s?__biz=MzA3MTUzOTcxOQ==&mid=2452972630&idx=2&sn=6f9be1794d1174418fa58007c55cb193

本站部分文章源于互联网,本着传播知识、有益学习和研究的目的进行的转载,为网友免费提供。如有著作权人或出版方提出异议,本站将立即删除。如果您对文章转载有任何疑问请告之我们,以便我们及时纠正。

PS:推荐一个微信公众号: askHarries 或者qq群:474807195,里面会分享一些资深架构师录制的视频录像:有Spring,MyBatis,Netty源码分析,高并发、高性能、分布式、微服务架构的原理,JVM性能优化这些成为架构师必备的知识体系。还能领取免费的学习资源,目前受益良多

转载请注明原文出处:Harries Blog™ » Spring Boot 微服务之程序性能监控

赞 (0)
分享到:更多 ()

评论 0

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址