Prometheus实现Spring cloud应用监控

最近项目上使用spring cloud作为微服务分布式架构替代原来的dubbo架构,但随着应用的不断增长,每个服务的具体状态,一些指标就需要进行监控,以便于时刻了解各服务的运行状态,于是便有了搭一个监控系统的想法。查询网上的资料,很多都是用Prometheus配上Grafana作为监控展现(毕竟颜值即正义),我也试着搭了个。闲话少说,进入实际操作。

Spring cloud应用改动

  • 加入依赖 :
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-actuator</artifactId>
        </dependency>
        <dependency>
            <groupId>io.prometheus</groupId>
            <artifactId>simpleclient_spring_boot</artifactId>
            <version>0.0.26</version>
        </dependency>
  • 修改Application类:加入@EnablePrometheusEndpoint@EnableSpringBootMetricsCollector注解
@SpringBootApplication
@EnableDiscoveryClient
@EnablePrometheusEndpoint
@EnableSpringBootMetricsCollector
public class AuthApplication {

    public static void main(String[] args) {
        SpringApplication.run(AuthApplication.class, args);
    }
}

  • 修改application.yml:
security:
  basic:
    enabled: false

management:
  security:
    enabled: false

我这是为了方便,禁用了相关安全认证选项,你可不要把这个配置应用到生产环境,不然你就要背锅咯

背锅.png

接着启动你的应用,打开浏览器输入http://localhost:2222/auth/prometheus,正常情况下你就可以在页面上看到很多键值对:

key value.png

就像这样。

Prometheus:

  • 安装:
    官网下载,根据你自己的操作系统选择版本,我这本地测试玩,就弄了个windows版本下的。下载完,解压,找到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).

  # Attach these labels to any time series or alerts when communicating with
  # external systems (federation, remote storage, Alertmanager).
  external_labels:
      monitor: 'codelab-monitor'

# Load rules once and periodically evaluate them according to the global 'evaluation_interval'.
rule_files:
  # - "first.rules"
  # - "second.rules"

# A scrape configuration containing exactly one endpoint to scrape:
# Here it's Prometheus itself.
scrape_configs:
   - job_name: auth-service
     scrape_interval: 5s
     scrape_timeout: 5s
     metrics_path: /auth/prometheus
     scheme: http
     static_configs:
       - targets:
         - 127.0.0.1:2222

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

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

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

spring:
  application:
    name: auth
##去除有问题的指标,因为指标名重复产生bug    
  metrics:
    servo:
      enabled: false
server:
  port: 2222
  context-path: /auth

eureka:
    client:
      serviceUrl:
        defaultZone: http://localhost:1111/eureka/
    instance:
      prefer-ip-address: true
security:
  basic:
    enabled: false

management:
  security:
    enabled: false
endpoints:
  actuator:
    enabled: true

好啦,我们改好重新启动应用,重新刷新Prometheus的页面http://localhost:9090/targets,就会很欣喜的看到没错了,正常了。

normal.png

要看有哪些指标可以现成使用的,可以在Graph菜单下,那个下拉列表中查找:

1508582902911.png

你可以选中一个指标,然后execute,就可以看到一个简陋的图表,显示指标的数据:


1508582963614.png

当然这个Prometheus自带的图表肯定不给力,这时就要请出Grafana了。

Grafana:

  • 安装:
    同样的进入官网http://docs.grafana.org/installation/windows/下载,请根据你的操作系统下载。解压进入bin目录,然后启动,访问http://localhost:3000你就会看到登录界面,默认的账户和密码都是admin

  • 配置:
    add datasource ,加上Prometheus的数据源配置。

    1508583706422.png

接着我们新加入一个Dashboards:


1508583782500.png

新增一个Graph:

1508583850530.png

接着选择edit:


1508583879453.png

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


1508583977567.png

好了,暂时写到这里了,要去做饭了。

1508584880773.png
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 212,657评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,662评论 3 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,143评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,732评论 1 284
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,837评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,036评论 1 291
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,126评论 3 410
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,868评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,315评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,641评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,773评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,470评论 4 333
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,126评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,859评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,095评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,584评论 2 362
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,676评论 2 351

推荐阅读更多精彩内容