zoukankan      html  css  js  c++  java
  • springboot admin 监控

    Spring Boot Admin 简介

    使用 Spring Boot Admin 可以管理和监控你的 Spring Boot 项目。

    它分为客户端服务端两部分,客户端添加到你的 Spring Boot 应用增加暴漏相关信息的 HTTP 接口,然后注册到 Spring Boot Admin 服务端,这一步骤可以直接向服务端注册,也可以通过 Eureka 或者 Consul 进行注册。

    Spring Boot Admin Server 通过 Vue.js 程序监控信息进行可视化呈现。支持多种事件通知操作。

    Service 端

    引入依赖:

            <dependency>
                <groupId>de.codecentric</groupId>
                <artifactId>spring-boot-admin-starter-server</artifactId>
                <version>2.1.0</version>
            </dependency>
            <dependency>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-starter-security</artifactId>
            </dependency>

    编写 application.yml 配置:

    spring:
      security:
        user:
          # 登录账号
          name: user
          # 登录密码
          password: 123456
    server:
      port: 8081

    添加 @EnableAdminServer 注解:

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

    添加安全认证

    因为是部署在公网中,所以增加权限账号登录验证。账号密码已经在 application.yml 中配置好了。还需要实现如下权限拦截。

    @Configuration
    public class SecurityConfig extends WebSecurityConfigurerAdapter {
        @Override
        protected void configure(HttpSecurity http) throws Exception {
            // 跨域设置,SpringBootAdmin客户端通过instances注册
            http.csrf().csrfTokenRepository(CookieCsrfTokenRepository.withHttpOnlyFalse())
                    .ignoringAntMatchers("/instances");
            // 静态资源
            http.authorizeRequests().antMatchers("/assets/**").permitAll();
            // 所有请求必须通过认证
            http.authorizeRequests().anyRequest().authenticated();
            // 整合spring-boot-admin-server-ui
            http.formLogin().loginPage("/login").permitAll();
            http.logout().logoutUrl("/logout").logoutSuccessUrl("/login");
            // 启用basic认证
            http.httpBasic();
        }
    }

    至此,Service 端 已完成配置,对应的访问地址:http://localhost:8081

    配置 Client 端

    引入依赖:

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

    编写 application.yml 配置:

    spring:
      application:
        name: springbootadminclient
      boot:
        admin:
          client:
            # Spring Boot Admin 服务端地址
            url: http://localhost:8081
            username: user
            password: 123456
            instance:
              prefer-ip: true
    management:
      endpoint:
        health:
          # 端点健康情况,默认值 "never",设置为 "always" 可以显示硬盘使用情况和线程情况
          show-details: always
      endpoints:
        web:
          exposure:
            # 设置端点暴露的哪些内容,默认 ["health","info"],设置 "*" 代表暴露所有可访问的端点
            include: "*"
  • 相关阅读:
    LNMP状态管理命令
    Gogs基本使用介绍
    初探Asp.net请求机制原理 1
    关于css定位
    JS不同浏览器图片载入处理
    js之队列01
    javascript 快速排序
    JavaScript prototype背后的工作原理
    关于javascrpt if快速判断说明
    js动态加载图片核心代码
  • 原文地址:https://www.cnblogs.com/ooo0/p/14434948.html
Copyright © 2011-2022 走看看