This repository contains implementation for the sonic system telemetry services:
- dial-in mode system telemetry server:
telemetry
- dial-out mode system telemetry client
dialout_client_cli
Install go in your system https://golang.org/doc/install. Requires golang1.8+.
To install dial-in mode system telemetry server, run
go get -u github.com/sonic-net/sonic-gnmi/telemetry
To install dial-out mode system telemetry client, run
go get -u github.com/sonic-net/sonic-gnmi/dialout/dialout_client_cli
There is also a test program dialout_server_cli for collecting data from dial-out mode system telemetry client. Note: it is for testing purpose only.
go get -u github.com/sonic-net/sonic-gnmi/dialout/dialout_server_cli
The binaries will be installed under $GOPATH/bin/, they may be copied to any SONiC switch and run there.
You can also build a debian package and install it:
git clone https://github.com/sonic-net/sonic-gnmi.git
pushd sonic-gnmi
dpkg-buildpackage -rfakeroot -b -us -uc
popd
- See SONiC gRPC telemetry for how to run dial-in mode system telemetry server
- See SONiC telemetry in dial-out mode for how to run dial-out mode system telemetry client
- See gNMI Usage Examples for gNMI client usage examples.
SONiC publishes events of interest via gNMI.
Sample events could be bgp-state change, link-state change.
A sample query URL is as below.
gnmi_cli -client_types=gnmi -a 127.0.0.1:50051 -t EVENTS -logtostderr -insecure -v 7 -streaming_type ON_CHANGE -q all -qt s
The events URL can take the following optional parameters.
heartbeat:
[heartbeat=<N>]
The SONiC switch publishes periodic hearbeats when there are no events to publish.
The frequency of the heartbeat can be controlled by this parameter as beat in every N seconds.
usecache:
[usecache=true/false]
The SONiC switch does offline cache when gNMI client is down.
The cached events are delivered upon nest gNMI connection
Only one client should use the cache service
The cached events are delivered upon nest gNMI connection
If you are running test clients, use this param to turn off cache use.
Sample URL:
gnmi_cli -client_types=gnmi -a 127.0.0.1:50051 -t EVENTS -logtostderr -insecure -v 7 -streaming_type ON_CHANGE -q all[heartbeat=5][usecache=false] -qt s
Add -output_file=<file>
Add -expected_event=<event module:event tag>
e.g. -expected_event=sonic-events-bgp:bgp-state
Add -expected_count <N>
Add -streaming_timeout 10
The following cmd will run the tool until it receives 5 test events or timeout upon 10s, whichever is earlier and receives events are written into file "/tmp/ee".
gnmi_cli -client_types=gnmi -a 127.0.0.1:50051 -t EVENTS -logtostderr -insecure -v 7 -qt s -q all[heartbeat=5] -streaming_type ON_CHANGE -output_file=/tmp/ee -expected_event=":test-tag" -expected_count 5 -streaming_timeout 10
For general questions, setup help, or troubleshooting:
For bug reports or feature requests, please open an Issue.
See the contributors guide for information about how to contribute.
We're following basic GitHub Flow. If you have no idea what we're talking about, check out GitHub's official guide. Note that merge is only performed by the repository maintainer.
Guide for performing commits:
- Isolate each commit to one component/bugfix/issue/feature
- Use a standard commit message format:
[component/folder touched]: Description intent of your changes [List of changes] Signed-off-by: Your Name your@email.com
For example:
swss-common: Stabilize the ConsumerTable * Fixing autoreconf * Fixing unit-tests by adding checkers and initialize the DB before start * Adding the ability to select from multiple channels * Health-Monitor - The idea of the patch is that if something went wrong with the notification channel, we will have the option to know about it (Query the LLEN table length). Signed-off-by: user@dev.null
- Each developer should fork this repository and add the team as a Contributor
- Push your changes to your private fork and do "pull-request" to this repository
- Use a pull request to do code review
- Use issues to keep track of what is going on