Skip to content

观测器

观测器是一个用来观测服务内部状态的组件,包括服务状态的变化,连接和流量统计信息,观测器通过事件的方式上报这些信息。

动态配置

观测器支持通过Web API进行动态配置。

使用限制

观测器目前仅能以插件的方式来使用。

插件

观测器可以配置为使用外部插件服务。

observers:
- name: observer-0
  plugin:
    type: grpc
    addr: 127.0.0.1:8000
    tls: 
      secure: false
      serverName: example.com
type (string, default=grpc)
插件类型:grpc, http
addr (string, required)
插件服务地址。
tls (object, default=null)
设置后将使用TLS加密传输,默认不使用TLS加密。

使用观测器

当服务的状态变化时会通过服务上的观测器上报状态,如果服务开启了统计(enableStats选项),同时也会上报连接和流量统计信息。

services:
- name: service-0
  addr: ":8080"
  observer: observer-0 # 服务上的观测器
  handler:
    type: http
  listener:
    type: tcp
  metadata:
    enableStats: true # 开启统计
    observer.period: 5s
    observer.resetTraffic: false

observers:
- name: observer-0
  plugin:
    type: grpc
    addr: 127.0.0.1:8000
    tls: 
      secure: false
      serverName: example.com
enableStats (bool, default=false)
是否上报连接和流量数据。
observer.period (duration, default=5s)
观测器上报周期。
observer.resetTraffic (bool, default=false)
是否重置流量数据,开启后每次上报的流量为增量数据。

HTTP插件

observers:
- name: observer-0
  plugin:
    type: http
    addr: http://127.0.0.1:8000/observer
    timeout: 10s
timeout (duration, default=5s)
上报请求超时时长。

请求示例

上报服务状态

curl -XPOST http://127.0.0.1:8000/observer \
-d '{"events":[
{"kind":"service","service":"service-0","type":"status", 
"status":{"state":"running","msg":"service service-0 is running"}} 
]}'
kind (string)
事件种类:service - 服务级别事件, handler - 处理器级别事件
service (string)
服务名
type (string)
事件类型:status - 服务状态,stats - 统计信息
status.state (string)
服务状态:running - 服务创建并运行,ready - 服务已就绪,failed - 服务运行失败,closed - 服务已关闭
status.msg (string)
服务状态说明

插件响应

{"ok": true}

上报统计信息

单个服务会周期性(5秒)通过观测器上报统计信息,当服务的统计信息无更新时(无任何连接或流量变化)停止上报。

curl -XPOST http://127.0.0.1:8000/observer \
-d '{"events":[
{"kind":"service","service":"service-0","type":"stats", 
"stats":{"totalConns":1,"currentConns":0,"inputBytes":235,"outputBytes":632,"totalErrs":0}}
]}'
stats.totalConns (uint64)
服务处理的总连接数
stats.currentConns (uint64)
服务当前正在处理(未完成)的连接数
stats.inputBytes (uint64)
服务接收的数据总字节数
stats.outputBytes (uint64)
服务发送的数据总字节数
stats.totalErrs (uint64)
服务处理请求的总错误数

插件响应

{"ok": true}

重传机制

当上报失败,即插件服务未返回oktrue的响应时,观测器下一次会重新上传失败的事件,直到成功为止。

处理器(Handler)上的观测器

对于支持认证的处理器(HTTP,HTTP2,SOCKS4,SOCKS5,Relay,Tunnel),观测器也可以用在这些类型的处理器上。

services:
- name: service-0
  addr: ":8080"
  handler:
    type: http
    observer: observer-0
    metadata:
      observer.period: 5s
      observer.resetTraffic: false
  listener:
    type: tcp

observers:
- name: observer-0
  plugin:
    addr: 127.0.0.1:8000
observer.period (duration, default=5s)
观测器上报周期。
observer.resetTraffic (bool, default=false)
是否重置流量数据,开启后每次上报的流量为增量数据。

基于用户标识的流量统计

服务级别的观测器只能用来观测服务整体的统计信息,无法针对用户进行更细的划分。如果需要实现此功能需要组合使用认证器和处理器上的观测器插件。

认证器在认证成功后返回用户标识,GOST会将此用户标识信息再次传递给观测器插件服务。

Tunnel处理器

对于Tunnel处理器,统计对象为单个隧道,client值为Tunnel ID。

curl -XPOST http://127.0.0.1:8000/observer \
-d '{"events":[
{"kind":"handler","service":"service-0","client":"user1","type":"stats",
"stats":{"totalConns":1,"currentConns":0,"inputBytes":78,"outputBytes":574,"totalErrs":0}},
{"kind":"handler","service":"service-0","client":"user2","type":"stats",
"stats":{"totalConns":1,"currentConns":0,"inputBytes":78,"outputBytes":574,"totalErrs":0}}
]}'
client (string)
用户或隧道标识

Comments