SpringBoot2+prometheus+ Grafana搭建监控系统是目前Java后台服务的一个大方向,微博、美团都大厂也都在用,相比其他监控体系,该方案更加完善和强大,同时还非常灵活。本章我们就来介绍一下如何在mac搭建一套系统来玩玩。因为要用三个组件,所以主要工作也分为三个部分:

1.快速建立一个新的SpringBoot2工程,并添加prometheus坐标。

2.下载安装、配置并启动prometheus。

3.下载安装并启动Grafana,同时在Grafana做一些设置,让我们可以看到监控数据。

接下来我们就从0开始完整实现该过程。

1.新建的SpringBoot2工程

使用idea新建一个pom工程,这个应该不用多说了,完成之后配置一下pom.xml文件;

<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"
         xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
         xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
    <modelVersion>4.0.0</modelVersion>
    <parent>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-parent</artifactId>
        <version>2.1.3.RELEASE</version>
        <relativePath/> <!-- lookup parent from repository -->
    </parent>
    <groupId>com.lqc</groupId>
    <artifactId>monitor_test</artifactId>
    <version>1.0-SNAPSHOT</version>
    <name>springboot2_prometheus</name>
    <description>springboot2_prometheus</description>
    <properties>
        <java.version>1.8</java.version>
    </properties>
    <dependencies>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-actuator</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-test</artifactId>
            <scope>test</scope>
        </dependency>
        <dependency>
            <groupId>io.micrometer</groupId>
            <artifactId>micrometer-registry-prometheus</artifactId>
            <version>1.1.3</version>
        </dependency>
    </dependencies>


    <build>
        <plugins>
            <plugin>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-maven-plugin</artifactId>
            </plugin>
        </plugins>
    </build>


</project>

这几个配置文件就够了。

然后在resource下新建一个配置文件:application.properties,内容为;

spring.application.name=springboot_prometheus
management.endpoints.web.exposure.include=*
management.metrics.tags.application=${spring.application.name}
server.port=2022

这里的name非常重要,我们后面还会使用该名字,因此不用乱写。

然后建立一个Java类,Springboot2PrometheusApplication.java,并创建Main方法,完整代码如下:

package com.lqc;

import io.micrometer.core.instrument.MeterRegistry;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.actuate.autoconfigure.metrics.MeterRegistryCustomizer;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.context.annotation.Bean;

@SpringBootApplication
public class Springboot2PrometheusApplication {

	public static void main(String[] args) {
		SpringApplication.run(Springboot2PrometheusApplication.class, args);
	}
	@Bean
	MeterRegistryCustomizer<MeterRegistry> configurer(
			@Value("${spring.application.name}") String applicationName) {
		return (registry) -> registry.config().commonTags("application", applicationName);
	}
}

然后启动一下,启动成功后,输入地址:http://localhost:2022/actuator/prometheus

此时会展示出很多信息,这就是SpringBoot2的actuator将很多基础的数据推送出来了。

springboot 监控地址 springboot 监控grafana_springboot 监控地址

到此,我们将服务放着就行了。

2.下载安装、配置并启动prometheus

首先下载并安装prometheus,下载地址是Download | Prometheus

 这里只有最新版的,我们直接下载下来就行,我下载的是prometheus-2.36.0.darwin-amd64.tar.gz。然后将其解压,接下来要修改配置文件prometheus.yml,完整内容如下:

# my global config
global:
  scrape_interval:     15s # Set the scrape interval to every 15 seconds. Default is every 1 minute.
  evaluation_interval: 15s # Evaluate rules every 15 seconds. The default is every 1 minute.
  # scrape_timeout is set to the global default (10s).
 
# Alertmanager configuration
alerting:
  alertmanagers:
  - static_configs:
    - targets:
      # - alertmanager:9093
 
# Load rules once and periodically evaluate them according to the global 'evaluation_interval'.
rule_files:
  # - "first_rules.yml"
  # - "second_rules.yml"
 
# A scrape configuration containing exactly one endpoint to scrape:
# Here it's Prometheus itself.
scrape_configs:
  - job_name: 'prometheus'
    static_configs:
    - targets: ['127.0.0.1:9090']
###以下内容为SpringBoot应用配置
  - job_name: 'springboot_prometheus'
    scrape_interval: 5s
    metrics_path: '/actuator/prometheus'
    static_configs:
      - targets: ['127.0.0.1:2022']

注意这里的最后一个job_name要和我们的java服务的对应起来。之后就可以执行了,命令是;

./prometheus --config.file=prometheus.yml

在mac下初次执行可能会被“安全与隐私”功能拦截,我们将其设置为允许就行了。

之后输入http://localhost:9090/

就可以查看是否启动成功。之后选择Status下的Targets如下位置:

springboot 监控地址 springboot 监控grafana_spring_02

 之后如果正常看到的是如下内容:

springboot 监控地址 springboot 监控grafana_intellij-idea_03

这里的的两个就是我们配置的两个job,一个是prometheus自己,一个是我们的SpringBoot服务。

至此,第二步完成。

3.下载安装Grafana,并检查监控数据

我们继续下载Grafana,Download Grafana | Grafana Labs

完成之后,直接执行bin目录下的./grafana-server 即可,此时仍然可能被mac的安全系统拦截,选择允许即可。

启动成功之后,在浏览器输入:

http://localhost:3000/

即可,默认的用户名和密码是admin,此时可以看到如下的界面:

springboot 监控地址 springboot 监控grafana_springboot 监控地址_04

之后要为其配置数据源 ,设置这几个位置就行了:

springboot 监控地址 springboot 监控grafana_intellij-idea_05

 这里会自动执行一次测试,如果测试通过就ok了,

之后就是根据需要添加dashbaord了,操作如下:

springboot 监控地址 springboot 监控grafana_spring_06

此时会进入如下界面:

springboot 监控地址 springboot 监控grafana_intellij idea_07

 

我们选择“Add a new panel”,然后可以看到下面图示:

springboot 监控地址 springboot 监控grafana_java_08

 要生成指标图非常简单,我们只要在“metrics browser”输入我们需要的监控的指标名字就可以展示出来,然后选择“query”,这时候就给我们生成了一个实时监控图。

然后就可以一直添加需要的指标,就逐步将大盘给建立起来了。

springboot 监控地址 springboot 监控grafana_intellij idea_09

 这些指标都是actutor推送出来的,prometheus是个实时数据库,将这些信息给缓存下来了,最后Grafana就执行各种展示了。

到这里我们就将整个流程走通了,如果要实际用还有很多不足,例如Grafana已关闭就将所有信息都丢了等等,。