一、Spring cloud应用改动
    (1)、加入依赖

    1. <dependency>
    2. <groupId>org.springframework.boot</groupId>
    3. <artifactId>spring-boot-starter-actuator</artifactId>
    4. </dependency>
    5. <dependency>
    6. <groupId>io.prometheus</groupId>
    7. <artifactId>simpleclient_spring_boot</artifactId>
    8. <version>0.0.26</version>
    9. </dependency>

    (2)、修改Application类:加入@EnablePrometheusEndpoint@EnableSpringBootMetricsCollector注解

    1. @SpringBootApplication
    2. @EnableDiscoveryClient
    3. @EnablePrometheusEndpoint
    4. @EnableSpringBootMetricsCollector
    5. public class AuthApplication {
    6. public static void main(String[] args) {
    7. SpringApplication.run(AuthApplication.class, args);
    8. }
    9. }
    • 修改application.yml:
    1. security:
    2. basic:
    3. enabled: false
    4. management:
    5. security:
    6. enabled: false

    我这是为了方便,禁用了相关安全认证选项,你可不要把这个配置应用到生产环境,不然你就要背锅咯
    接着启动你的应用,打开浏览器输入http://localhost:2222/auth/prometheus,正常情况下你就可以在页面上看到很多键值对:
    5.9、Prometheus实现Spring cloud应用监控 - 图1
    key value.png
    就像这样。
    Prometheus:

    • 安装:
      官网下载,根据你自己的操作系统选择版本,我这本地测试玩,就弄了个windows版本下的。下载完,解压,找到prometheus.yml改配置:
    1. # my global config
    2. global:
    3. scrape_interval: 15s # Set the scrape interval to every 15 seconds. Default is every 1 minute.
    4. evaluation_interval: 15s # Evaluate rules every 15 seconds. The default is every 1 minute.
    5. # scrape_timeout is set to the global default (10s).
    6. # Attach these labels to any time series or alerts when communicating with
    7. # external systems (federation, remote storage, Alertmanager).
    8. external_labels:
    9. monitor: 'codelab-monitor'
    10. # Load rules once and periodically evaluate them according to the global 'evaluation_interval'.
    11. rule_files:
    12. # - "first.rules"
    13. # - "second.rules"
    14. # A scrape configuration containing exactly one endpoint to scrape:
    15. # Here it's Prometheus itself.
    16. scrape_configs:
    17. - job_name: auth-service
    18. scrape_interval: 5s
    19. scrape_timeout: 5s
    20. metrics_path: /auth/prometheus
    21. scheme: http
    22. static_configs:
    23. - targets:
    24. - 127.0.0.1:2222

    这个是我自己的配置,你根据需要更改为你的应用合适的配置,主要更改在scrape_configs节点下。

    • 启动Prometheus:
      windows下,进入命令行模式,进入到Prometheus的目录中,运行prometheus -config.file=prometheus.yml,启动成功后,在http://localhost:9090/targets你会看到你所监控的目标,但在这里,你会发现居然有错:

    5.9、Prometheus实现Spring cloud应用监控 - 图2
    error.png
    然后Google一下,发现了这个https://github.com/prometheus/client_java/issues/130简直一模一样啊,莫非有救了,淡定,实际上并没有救,你会见证Prometheus client_java项目组和spring boot以及spring cloud项目组之间的互相扯皮踢皮球,最后我只好用了个暂且有用的办法,就是去掉那些产生问题的指标,在你的Spring boot应用配置文件中加上:

    1. spring:
    2. application:
    3. name: auth
    4. ##去除有问题的指标,因为指标名重复产生bug
    5. metrics:
    6. servo:
    7. enabled: false
    8. server:
    9. port: 2222
    10. context-path: /auth
    11. eureka:
    12. client:
    13. serviceUrl:
    14. defaultZone: http://localhost:1111/eureka/
    15. instance:
    16. prefer-ip-address: true
    17. security:
    18. basic:
    19. enabled: false
    20. management:
    21. security:
    22. enabled: false
    23. endpoints:
    24. actuator:
    25. enabled: true

    好啦,我们改好重新启动应用,重新刷新Prometheus的页面http://localhost:9090/targets,就会很欣喜的看到没错了,正常了。
    5.9、Prometheus实现Spring cloud应用监控 - 图3
    normal.png
    要看有哪些指标可以现成使用的,可以在Graph菜单下,那个下拉列表中查找:
    5.9、Prometheus实现Spring cloud应用监控 - 图4
    1508582902911.png
    你可以选中一个指标,然后execute,就可以看到一个简陋的图表,显示指标的数据:

    5.9、Prometheus实现Spring cloud应用监控 - 图5
    当然这个Prometheus自带的图表肯定不给力,这时就要请出Grafana了。
    Grafana:

    • 安装:
      同样的进入官网http://docs.grafana.org/installation/windows/下载,请根据你的操作系统下载。解压进入bin目录,然后启动,访问http://localhost:3000你就会看到登录界面,默认的账户和密码都是admin
    • 配置:
      add datasource ,加上Prometheus的数据源配置。
      5.9、Prometheus实现Spring cloud应用监控 - 图6
      1508583706422.png

    接着我们新加入一个Dashboards:

    5.9、Prometheus实现Spring cloud应用监控 - 图7
    1508583782500.png
    新增一个Graph:
    5.9、Prometheus实现Spring cloud应用监控 - 图8
    1508583850530.png
    接着选择edit:

    5.9、Prometheus实现Spring cloud应用监控 - 图9

    然后在metric中编辑数据源和指标,比如我们新增一个threads(线程数)的指标,完成后就可以看到美丽的图表了:

    5.9、Prometheus实现Spring cloud应用监控 - 图10

    作者:FakeCoooode
    链接:https://www.jianshu.com/p/9ec4f5f63932
    来源:简书
    著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。