客户端 Registry 使用指南

编辑
更新时间: 2024-09-18

Registry 的使用

不同的 Registry 的集成提供了不同的访问 Metrics 的方式。

1. LookoutRegistry

提供按照一定时间窗口统计 metrics 的能力。它又分为“主动推”和“被动拉”两种模式,暂时被动拉取模式处于关闭状态。

(1)主动推模式

 可以通过【客户端配置】指定远程 Agent 的IP地址,即开始上报检查,和定时上报数据。

(2)被动拉模式

 可以通过【客户端配置】启动该模式,则在 19399 端口提供 HTTP 服务。更多交互细节请参考(待补充)

2. 对接到 Prometheus

SOFALookout 的数据可以对接到 Prometheus 上面。为了将数据对接到 Prometheus 上面,首先需要在工程中加入依赖:

<dependency>
     <groupId>com.alipay.sofa.lookout</groupId>
     <artifactId>lookout-sofa-boot-starter</artifactId>
</dependency>
<dependency>
     <groupId>com.alipay.sofa.lookout</groupId>
     <artifactId>lookout-reg-prometheus</artifactId>
     <version>${lookout.client.version}</version>
</dependency>

添加好依赖之后,启动应用,既可以访问 http://localhost:9494 来看到数据,其中 9494 为默认的端口,可以通过在 application.properties 里面配置 com.alipay.sofa.lookout.prometheus-exporter-server-port 来改变端口。

有了访问数据的 URL 之后,可以编辑一个 prometheus.yml 来抓取该项目信息,假设本机 IP 地址为 10.15.232.20,那么可以配置如下的 prometheus.yml

scrape_configs:
  - job_name:       'lookout-client'
    scrape_interval: 5s
    static_configs:
      - targets: ['10.15.232.20:9494']

有了上面的配置文件之后,可以再到本地通过 Docker 来启动 Prometheus:

docker run -d -p 9090:9090 -v $PWD/prometheus.yml:/etc/prometheus/prometheus.yml  --name prom prom/prometheus:master

然后通过浏览器访问: http://localhost:9090,再通过 PromQL 查询即可查询到对应的 Metrics。

SOFALookout 中也提供了一个对接 Prometheus 的样例,大家可以前往自行查看。

3. 对接 SpringBoot actuator

除了 Prometheus 之外,SOFALookout 可以与 SpringBoot 1.x 的 Actuator 的相集成,只需依赖:

<dependency>
     <groupId>org.springframework.boot</groupId>
     <artifactId>spring-boot-starter-actuator</artifactId>
</dependency>

然后启动后访问 http://localhost:8080/metrics 既可以看到通过 SOFALookout API 埋点的数据。

SOFALookout 也提供了集成的样例工程,大家可以前往自行查看。