Observer¶
The observer is a component used to observe the internal status of the service, including service status changes, connection and traffic statistics, and the observer reports this information through events.
Dynamic configuration
Observer supports dynamic configuration via Web API.
Limitation
Observer are currently only available as plugins.
Plugin¶
Observer can be configured to use external plugin services.
observers:
- name: observer-0
plugin:
type: grpc
addr: 127.0.0.1:8000
tls:
secure: false
serverName: example.com
type
(string, default=grpc)- plugin type:
grpc
,http
. addr
(string, required)- Plugin server address.
tls
(object, default=null)- TLS encryption will be used for transmission, TLS encryption is not used by default.
Usage¶
When the status of the service changes, the status will be reported through the observer on the service. If the service has statistics enabled (enableStats
option), connection and traffic statistics will also be reported.
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)- Whether to report connection and traffic data.
observer.period
(duration, default=5s)- Observer reporting period.
observer.resetTraffic
(bool, default=false)- Whether to reset traffic data. After enabling, the traffic reported each time is incremental data.
HTTP Plugin¶
timeout
(duration, default=0s)- Request timeout.
Example¶
Report Service Status¶
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)- kind of event:
service
- service level,handler
- handler level service
(string)- service name
type
(string)- event types:
status
- service status,stats
- statistics status.state
(string)- status of service:
running
,ready
,failed
,closed
status.msg
(string)- description of status
Report Statistic*¶
A single service will report statistics through the observer periodically (5 seconds), and stop reporting when the service's statistics is not updated (without any connection or traffic changes).
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)- Total number of connections handled by the service
stats.currentConns
(uint64)- The number of current pending connections of the service
stats.inputBytes
(uint64)- Total number of bytes of data received by the service
stats.outputBytes
(uint64)- Total number of bytes of data sent by the service
stats.totalErrs
(uint64)- total number of errors in service processing requests
Response:
Retry Mechanism
When the report fails, that is, the plugin service does not return a response with ok
equal to true
, the observer will re-upload the failed event next time until it succeeds.
Observer In Service Handler¶
For proxy services that support authentication (HTTP, HTTP2, SOCKS4, SOCKS5, Relay), the observer is also available to Handler.
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 reporting period.
observer.resetTraffic
(bool, default=false)- Whether to reset traffic data. After enabling, the traffic reported each time is incremental data.
Observer Based On Client ID¶
Service-level observer can only be used to observe the statistics of the overall service and cannot be divided into more detailed categories for users. If you need to implement this function, you need to use a combination of the authenticator and the observer plugin on the handler.
The Authenticator returns the client ID after successful authentication. GOST will pass this client ID information to the Observer plugin server again. For Tunnel handler,the value of client
is Tunnel ID.
Tunnel Handler
For Tunnel handler, the oberver acts on a single Tunnel, the client value is the 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)- client or tunnel ID, generated by Authenticator.