Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/google/gnxi

gNXI Tools - gRPC Network Management/Operations Interface Tools
https://github.com/google/gnxi

gnmi gnmi-client gnmi-protocol gnmi-target gnoi gnoi-client gnoi-protocols gnoi-target go

Last synced: about 2 months ago
JSON representation

gNXI Tools - gRPC Network Management/Operations Interface Tools

Awesome Lists containing this project

README

        

[![License](https://img.shields.io/github/license/google/gnxi?style=for-the-badge)](https://opensource.org/licenses/Apache-2.0)
[![GoDoc](https://img.shields.io/badge/godoc-reference-blue?style=for-the-badge)](https://godoc.org/github.com/google/gnxi)
[![Go Report Card](https://goreportcard.com/badge/github.com/google/gnxi?style=for-the-badge)](https://goreportcard.com/report/github.com/google/gnxi)
[![Build Status](https://img.shields.io/travis/google/gnxi?style=for-the-badge)](https://travis-ci.org/google/gnxi)
[![Code coverage master](https://img.shields.io/codecov/c/github/google/gnxi/master?style=for-the-badge)](https://codecov.io/github/google/gnxi?branch=master)

# gNxI Tools

* gNMI - gRPC Network Management Interface
* gNOI - gRPC Network Operations Interface

A collection of tools for Network Management that use the gNMI and gNOI protocols.

### Summary

Notes about these tools:

* They are intended for testing and as reference implementation of the protocol.
* They log to stderr by default, disable with `-logtostderr=false`.
* They use glog's log levels, use `-v 1` to log proto message exchanges.

#### gNMI Clients:

* [gNMI Capabilities](./gnmi_capabilities)
* [gNMI Get](./gnmi_get)
* [gNMI Set](./gnmi_set)
* [gNMI Subscribe](./gnmi_subscribe)

#### gNMI Targets:

* [gNMI Target](./gnmi_target)

#### gNOI Clients

* [gNOI Cert](./gnoi_cert)
* [gNOI OS](./gnoi_os)
* [gNOI Reset](./gnoi_reset)

#### gNOI Targets

* [gNOI Target](./gnoi_target)

#### Helpers

* [gNOI mockOS](./gnoi_mockos)
* [certificate generator](./certs)

### Documentation

* See [gNMI Protocol documentation](https://github.com/openconfig/reference/tree/master/rpc/gnmi).
* See [gNOI Protocol documentation](https://github.com/openconfig/gnoi).
* See [Openconfig documentation](http://www.openconfig.net/).

## Getting Started

These instructions will get you a copy of the project up and running on your local machine.

### Prerequisites

Install __go__ in your system https://golang.org/doc/install. Requires golang1.14+.

### Download sources

```
go get github.com/google/gnxi
ls $GOPATH/src/github.com/google/gnxi
```

### Building and installing binaries

```
cd $GOPATH
mkdir bin
# This reads the go modules dependencies for installation
cd src/github.com/google/gnxi
go install ./...
ls -la $GOPATH/bin
```

### Generating certificates

```
cd $GOPATH/bin
./../src/github.com/google/gnxi/certs/generate.sh
```

### Running a client

```
cd $GOPATH/bin
./gnoi_reset \
-target_addr localhost:9339 \
-target_name target.com \
-rollback_os \
-zero_fill \
-key client.key \
-cert client.crt \
-ca ca.crt
```

Optionally define $GOBIN as $GOPATH/bin and add it to your path to run the binaries from any folder.

```
export GOBIN=$GOPATH/bin
export PATH=$PATH:$GOBIN
```

## Disclaimer

* This is not an official Google product.
* See [how to contribute](CONTRIBUTING.md).