SpringBoot:Actuator监控中心+AdminUI界面管理

梦里梦外; 2022-04-01 11:27 818阅读 0赞

一,Actuator + AdminUI服务监控中心介绍

  1. 1,什么是SpringBoot监控中心
  2. 针对微服务器监控、服务器内存变化(堆内存,线程,日志管理等)、检测服务配置连接池是否可用(模拟访问、懒加载)、统计现有Bean(通过Spring容器)、Http接口(@RequestMapping)的一系列数据管理。Actuator监控应用只通过JSON形式返回数据统计结果,没有UI界面处理;AdminUI则内置Actuator服务监控,并对返回JSON数据进行图形化处理展示。
  3. 2,为什么要用SpringBoot监控中心
  4. ActuatorSpringBoot的一个附加功能,可以帮助应用程序在生产环境运行时的监控和管理。可以使用HTTP的各个请求路径来监管、审计、收集引用的运行情况,特别对于微服务管理十分有意义;
  5. AdminUI内置了Actuator服务,是对监控服务的图形化界面补充;

二,SpringBoot整合Actuator服务监控

  1. 1maven依赖引入
  2. <!-- actuator监控 -->
  3. <dependency>
  4. <groupId>org.springframework.boot</groupId>
  5. <artifactId>spring-boot-starter-actuator</artifactId>
  6. </dependency>
  7. 2application.properties:配置可进行监控的接口,此处配置为全部启动,默认只启用三个接口
  8. ### 监控中心配置, 允许监控所欲接口
  9. management.endpoints.web.exposure.include=*
  10. 3,启动服务,从打印日志中查看启用结果;如下图,说明启用成功,此处应该为15endPoints,因为我已经引入了AdminUI依赖,默认添加了该部分一个配置点;如果不配置第二步启用全部,则此处显示为2endPoints

20181230170211200.png

  1. 4,页面访问服务监控,返回结果均为JSON;如下,每一个链接均表示一个功能统计。比如mappings表示全部HTTP接口统计,beans表示Spring容器中的所有注册BeanthreadDump表示系统中的所有线程,health对所有懒加载的服务连接进行虚拟连接测试等等;

watermark_type_ZmFuZ3poZW5naGVpdGk_shadow_10_text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L3UwMTE5NzYzODg_size_16_color_FFFFFF_t_70

20181230170640895.png

20181230170654630.png

20181230170710438.png

2018123017072532.png

三,SpringBoot整合AdminUI界面管理

  1. 1,启动AdminUI界面,需要单独定义AdminUI-Server服务,独立于功能服务之外。所有功能服务作为AdminUI-Client服务连接到Server服务,Server服务检测到连接后对进行监控处理
  2. 2AdminUI-Server服务
  3. \* 创建一个Maven服务,引入maven依赖
  4. <?xml version="1.0" encoding="UTF-8"?>
  5. <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
  6. xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
  7. <modelVersion>4.0.0</modelVersion>
  8. <groupId>springboot_actuator_server</groupId>
  9. <artifactId>springboot.actuator.server</artifactId>
  10. <version>1.0-SNAPSHOT</version>
  11. <parent>
  12. <groupId>org.springframework.boot</groupId>
  13. <artifactId>spring-boot-starter-parent</artifactId>
  14. <version>2.1.1.RELEASE</version>
  15. <relativePath/> <!-- lookup parent from repository -->
  16. </parent>
  17. <name>springboot.actuator.server</name>
  18. <!-- FIXME change it to the project's website -->
  19. <url>http://www.example.com</url>
  20. <properties>
  21. <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
  22. <maven.compiler.source>1.7</maven.compiler.source>
  23. <maven.compiler.target>1.7</maven.compiler.target>
  24. </properties>
  25. <dependencies>
  26. <!-- AdminUI服务端依赖 -->
  27. <dependency>
  28. <groupId>de.codecentric</groupId>
  29. <artifactId>spring-boot-admin-starter-server</artifactId>
  30. <version>2.1.1</version>
  31. </dependency>
  32. <dependency>
  33. <groupId>org.springframework.boot</groupId>
  34. <artifactId>spring-boot-starter-webflux</artifactId>
  35. </dependency>
  36. <!-- Spring Boot Actuator对外暴露引用的监控信息, Jolokia提供使用HTTP接口获取json -->
  37. <dependency>
  38. <groupId>org.jolokia</groupId>
  39. <artifactId>jolokia-core</artifactId>
  40. </dependency>
  41. <!-- Spring Boot Actuator依赖 -->
  42. <dependency>
  43. <groupId>org.springframework.boot</groupId>
  44. <artifactId>spring-boot-starter-actuator</artifactId>
  45. </dependency>
  46. <!-- 服务包引用1.1.1版本, maven仓库已经不支持下载, 手动引入1.1版本 -->
  47. <dependency>
  48. <groupId>com.googlecode.json-simple</groupId>
  49. <artifactId>json-simple</artifactId>
  50. <version>1.1</version>
  51. </dependency>
  52. </dependencies>
  53. <build>
  54. <pluginManagement><!-- lock down plugins versions to avoid using Maven defaults (may be moved to parent pom) -->
  55. <plugins>
  56. <!-- clean lifecycle, see https://maven.apache.org/ref/current/maven-core/lifecycles.html#clean_Lifecycle -->
  57. <plugin>
  58. <artifactId>maven-clean-plugin</artifactId>
  59. <version>3.1.0</version>
  60. </plugin>
  61. <!-- default lifecycle, jar packaging: see https://maven.apache.org/ref/current/maven-core/default-bindings.html#Plugin_bindings_for_jar_packaging -->
  62. <plugin>
  63. <artifactId>maven-resources-plugin</artifactId>
  64. <version>3.0.2</version>
  65. </plugin>
  66. <plugin>
  67. <artifactId>maven-compiler-plugin</artifactId>
  68. <version>3.8.0</version>
  69. </plugin>
  70. <plugin>
  71. <artifactId>maven-surefire-plugin</artifactId>
  72. <version>2.22.1</version>
  73. </plugin>
  74. <plugin>
  75. <artifactId>maven-jar-plugin</artifactId>
  76. <version>3.0.2</version>
  77. </plugin>
  78. <plugin>
  79. <artifactId>maven-install-plugin</artifactId>
  80. <version>2.5.2</version>
  81. </plugin>
  82. <plugin>
  83. <artifactId>maven-deploy-plugin</artifactId>
  84. <version>2.8.2</version>
  85. </plugin>
  86. <!-- site lifecycle, see https://maven.apache.org/ref/current/maven-core/lifecycles.html#site_Lifecycle -->
  87. <plugin>
  88. <artifactId>maven-site-plugin</artifactId>
  89. <version>3.7.1</version>
  90. </plugin>
  91. <plugin>
  92. <artifactId>maven-project-info-reports-plugin</artifactId>
  93. <version>3.0.0</version>
  94. </plugin>
  95. </plugins>
  96. </pluginManagement>
  97. <plugins>
  98. <plugin>
  99. <groupId>org.springframework.boot</groupId>
  100. <artifactId>spring-boot-maven-plugin</artifactId>
  101. </plugin>
  102. </plugins>
  103. </build>
  104. </project>
  105. \* application.properties配置文件添加配置信息,此处主要对端口号进行修改,不与其他进程冲突
  106. server.port=8081
  107. \* 启动类:此处启动类不同于标准的SpringBoot启动类
  108. package com.actuator.server;
  109. import de.codecentric.boot.admin.server.config.EnableAdminServer;
  110. import org.springframework.boot.SpringApplication;
  111. import org.springframework.boot.autoconfigure.EnableAutoConfiguration;
  112. import org.springframework.context.annotation.Configuration;
  113. /**
  114. * @author pj_zhang
  115. * @create 2018-12-30 16:24
  116. **/
  117. @Configuration
  118. @EnableAutoConfiguration
  119. @EnableAdminServer
  120. public class AppApplication {
  121. public static void main(String[] args) {
  122. SpringApplication.run(AppApplication.class, args);
  123. }
  124. }
  125. \* 启动服务后进行页面访问,出现UI界面说明配置成功

20181230171443983.png

watermark_type_ZmFuZ3poZW5naGVpdGk_shadow_10_text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L3UwMTE5NzYzODg_size_16_color_FFFFFF_t_70 1

  1. 3AdminUI-Client
  2. \* maven依赖,注意已经引入的依赖不要二次引入
  3. <!-- AdminUI客户端依赖 -->
  4. <dependency>
  5. <groupId>de.codecentric</groupId>
  6. <artifactId>spring-boot-admin-starter-client</artifactId>
  7. <version>2.1.1</version>
  8. </dependency>
  9. <!-- Spring Boot Actuator对外暴露引用的监控信息, Jolokia提供使用HTTP接口获取json -->
  10. <dependency>
  11. <groupId>org.jolokia</groupId>
  12. <artifactId>jolokia-core</artifactId>
  13. </dependency>
  14. <!-- Spring Boot Actuator依赖 -->
  15. <dependency>
  16. <groupId>org.springframework.boot</groupId>
  17. <artifactId>spring-boot-starter-actuator</artifactId>
  18. </dependency>
  19. <!-- 服务包引用1.1.1版本, maven仓库已经不支持下载, 手动引入1.1版本 -->
  20. <dependency>
  21. <groupId>com.googlecode.json-simple</groupId>
  22. <artifactId>json-simple</artifactId>
  23. <version>1.1</version>
  24. </dependency>
  25. \* application.properties配置服务监控信息指向AdminUI-Server
  26. ### 注册当前服务到AdminUI-Server服务中
  27. spring.boot.admin.client.url=http://127.0.0.1:8081
  28. \* 启动服务后,查看UI界面已经已经监控到注册服务,注意此处当前服务的注册ID

20181230171824697.png

watermark_type_ZmFuZ3poZW5naGVpdGk_shadow_10_text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L3UwMTE5NzYzODg_size_16_color_FFFFFF_t_70 2

  1. \* 通过点击上面服务连接,默认classpath:index.html文件,static目录为静态资源存放目录,访问会自动解析

watermark_type_ZmFuZ3poZW5naGVpdGk_shadow_10_text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L3UwMTE5NzYzODg_size_16_color_FFFFFF_t_70 3

20181230172900235.png

  1. 4AdminUI界面演示
  2. \* 进入界面入口,点击中心实例进入主控制界面

watermark_type_ZmFuZ3poZW5naGVpdGk_shadow_10_text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L3UwMTE5NzYzODg_size_16_color_FFFFFF_t_70 4

  1. \* 主控制界面。包括刚才通过Actuator演示的所有功能,此处功能已经全部通过UI界面勾画,方便服务监控信息查看;左侧为Actuator功能列表,右侧为具体服务信息

watermark_type_ZmFuZ3poZW5naGVpdGk_shadow_10_text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L3UwMTE5NzYzODg_size_16_color_FFFFFF_t_70 5

  1. \* Beans功能为例,展示所有Spring容器中的Bean,大致跟踪服务展示流程;点击Beans按钮后,服务会通过实例注册ID路由到目标服务进行调用,具体信息获取方式依旧是依靠Actuator提供的服务监控接口进行服务统计

watermark_type_ZmFuZ3poZW5naGVpdGk_shadow_10_text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L3UwMTE5NzYzODg_size_16_color_FFFFFF_t_70 6

发表评论

表情:
评论列表 (有 0 条评论,818人围观)

还没有评论,来说两句吧...

相关阅读

    相关 Dubbo监控中心

    1)、dubbo-admin 图形化的服务管理页面;安装时需要指定注册中心地址,即可从注册中心中获取到所有的提供者/消费者进行配置管理   2)、dubbo-mon

    相关 Dubbo 监控中心

    1.Dubbo 监控中心      dubbo管理控制台开源部分主要包含:   提供者  路由规则  动态配置  访问控制  权重调节  负载均衡  负责人,等管理功能。

    相关 Dubbo后台管理监控中心部署

    通过dubbo监控中心和后台管理可以很好的监控dubbo服务,监控服务端服务和客户端调用情况,调用次数,调用日志,方便问题查找。下面我们看看dubbo的管理后台和监控中心怎么部