springboot2.x中的服务监控-阿里云开发者社区

开发者社区> 小尘哥> 正文

springboot2.x中的服务监控

简介: 想给服务添加一个监控,看看网上各位前辈的,基本都是基于springboot1.x的,springboot升级到2.0以后和1.x还是有很多不一样的,那么2.0以后怎么使用admin监控呢? 先看下图的managment.security.enable,现在已经是过时API了,那么我们必须要更新知识库了。
+关注继续查看

想给服务添加一个监控,看看网上各位前辈的,基本都是基于springboot1.x的,springboot升级到2.0以后和1.x还是有很多不一样的,那么2.0以后怎么使用admin监控呢?

先看下图的managment.security.enable,现在已经是过时API了,那么我们必须要更新知识库了。


img_1de7db532e37a5176f88d94b73384404.png
security.png

总体思路

和之前的思路一样,分为服务端和客户端。
服务端配置pom
客户端添加监控url配置

server端

1、创建项目,引入依赖,我的完整pom如下
 <dependencies>
        <!--表示为web工程-->
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>

        <!--暴露各种指标-->
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-actuator</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-netflix-eureka-server</artifactId>
        </dependency>
        <dependency>
            <groupId>de.codecentric</groupId>
            <artifactId>spring-boot-admin-server</artifactId>
        </dependency>
        <dependency>
            <groupId>de.codecentric</groupId>
            <artifactId>spring-boot-admin-server-ui</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-webflux</artifactId>
        </dependency>
        <dependency>
            <groupId>org.jolokia</groupId>
            <artifactId>jolokia-core</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-actuator</artifactId>
        </dependency>
        <dependency>
            <groupId>junit</groupId>
            <artifactId>junit</artifactId>
            <version>4.11</version>
            <scope>test</scope>
        </dependency>
    </dependencies>
2、配置yml
server:
  port: 8888
eureka:
  instance:
    hostname: localhost
    prefer-ip-address: true
    lease-renewal-interval-in-seconds: 10
  client:
    registry-fetch-interval-seconds: 5
    registerWithEureka: false
    fetchRegistry: false
    serviceUrl:
      defaultZone: http://localhost:8761/eureka/
management:
  endpoints:
    web:
      exposure:
        include: "*"
  endpoint:
    health:
      show-details: always
spring:
  application:
    name: spring-boot-admin-server
3、启用服务监控
@Configuration
@EnableAutoConfiguration
@EnableAdminServer
public class ActuatorApplication {
    public static void main(String[] args) {
        SpringApplication.run(ActuatorApplication.class, args);
    }
}

client端

在需要监控的项目中添加以下配置

1、添加pom依赖
        <dependency>
            <groupId>de.codecentric</groupId>
            <artifactId>spring-boot-admin-starter-client</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-actuator</artifactId>
        </dependency>
        <dependency>
            <groupId>org.jolokia</groupId>
            <artifactId>jolokia-core</artifactId>
        </dependency>
2、添加yml配置
spring:
  application:
      name: boot-service
  boot:
    admin:
      client:
        url: http://localhost:8888

查看监控

先启动刚才创建的服务监控项目,然后再分别启动需要监控的项目,然后访问http://localhost:8888(根据你的实际情况),访问结果如下

img_363bf39c0f63a8267e42f0981f85e0cc.png
飘红.png

一眼就看到一个不正常的服务,我们点进去看一下出了什么问题,因为我的服务确实在正常运行,可以正常访问
img_663033cac5ae6b8862819b93e0fbec59.png
5.png

结果就很明显了,一看network error,明显是网络不通,可是服务在正常运行,那么基本就是权限的问题了,因为我的eboot-admin添加了shiro的权限拦截,因此上面的/actuator/**都被拦截了,我们在shiro中将该路径放行

filterChainDefinitionMap.put("/actuator/**", "anon");

再次访问,结果如下


img_d9c802dbda178f05ee3b14f1e4334542.png
不再红.png

img_7b2ef5c2acc63a081379bfe32788bda7.png
applications.png

img_0859b790b5b794887fc9c968fbbdb9b6.png
journal.png

服务出现问题,applications会有如下提示,一看offline就······


img_5325eb908512a326fa7b9e1380e8baf4.png
挂掉挂掉.png

至此,springboot2.0的服务监控已经搞定。同时actuator也可以配合security做权限控制,但是我们监控的这些服务大部分可能都是在内网环境使用,后期我会加上带权限的监控,所有源码已上传到gitee,【戳我获取源码】,后期新增功能和代码会随时上传,需要的小伙伴随时获取哦
当然,如果能帮我点个star就更好了^_^

版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。

相关文章
SpringBoot实战(三)之使用RestFul Web服务
一、导入maven依赖 4.0.0 org.springframework gs-consuming-rest 0.1.0 org.springframework.
1773 0
Spring Cloud(三)服务提供者 Eureka + 服务消费者(rest + Ribbon)
Spring Cloud Ribbon是基于Netflix Ribbon实现的一套客户端负载均衡的工具。它是一个基于HTTP和TCP的客户端负载均衡器。它可以通过在客户端中配置ribbonServerList来设置服务端列表去轮询访问以达到均衡负载的作用。
1970 0
Spring Cloud配置服务器
Spring Cloud配置服务器 分布式配置 分布式配置架构 Spring Cloud配置服务器 服务端Environment仓储 Spring Cloud配置客户端 传统架构 Spring Cloud Config架构 Spring Cloud Config Server Spring C.
1550 0
Spring Cloud服务发现/注册(二)
Eureka Server即是注册服务器,也是客户端,默认情况,也需要配置注册中心地区。所以要添加配置 spring.application.name=spring-cloud-eureka-server ##服务器端口 server.
1366 0
Spring Cloud服务网关整合
网关 网管是程序或者系统之间的连接节点,扮演者程序或系统之间的门户,允许它们之前通过通讯协议交换信息,它们可能是同构或异构系统例如 REST API网关 WebServices网关 使用场景 监控(Monitoring) 测试 (Testing) 动态路由(Dynamic Routing) ...
1535 0
+关注
小尘哥
bug创造者
39
文章
0
问答
文章排行榜
最热
最新
相关电子书
更多
《2021云上架构与运维峰会演讲合集》
立即下载
《零基础CSS入门教程》
立即下载
《零基础HTML入门教程》
立即下载