gateway

package
v0.0.0-...-ebe92bc Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Feb 15, 2023 License: Apache-2.0 Imports: 35 Imported by: 0

Documentation

Overview

Package gateway provides an easily configurable server that can connect to multiple gNMI targets (devices) and relay received messages to various exporters and to downstream gNMI clients.

Targets are configured via a TargetLoader which generate all of the needed configuration for connecting to a target. See github.com/openconfig/gnmi/proto/target for details on the Configuration options that are available. See the TargetLoader docs for the minimum configuration required to connect to a target.

The gateway only supports TLS so you'll need to generate some keys first if you don't already have them. In production you should use properly signed TLS certificates.

# Generate private key (server.key)
openssl genrsa -out server.key 2048
# or
openssl ecparam -genkey -name secp384r1 -out server.key

# Generation of self-signed(x509) public key (server.crt) based on the private key (server.key)
openssl req -new -x509 -sha256 -key server.key -out server.crt -days 3650

You'll also need a copy of the latest OpenConfig YANG models if you don't already have it.

git clone https://github.com/openconfig/public.git oc-models

Finally, you need to build your target configurations. Copy targets-example.json to targets.json and edit it to match the targets you want to connect to.

cp targets-example.json targets.json
vim targets.json

See the example below or the Main() function in gateway.go for an example of how to start the server. If you'd like to just use the built-in loaders and exporters you can configure them more easily from the command line:

go build
./gnmi-gateway -EnableGNMIServer -EnablePrometheusExporter -OpenConfigDirectory=./oc-models/
Example

A simple example of how to configure the gateway.

config := &configuration.GatewayConfig{
	EnableGNMIServer:    true,
	OpenConfigDirectory: "./oc-models",
	ServerListenPort:    2906,
	ServerTLSCert:       "server.crt",
	ServerTLSKey:        "server.key",
	TargetLoaders: &configuration.TargetLoadersConfig{
		Enabled:                []string{"json"},
		JSONFile:               "targets.json",
		JSONFileReloadInterval: 60 * time.Second,
	},
	TargetDialTimeout: 5 * time.Second,
	TargetLimit:       100,
	ZookeeperHosts:    []string{"127.0.0.1"},
	ZookeeperTimeout:  1 * time.Second,
}

gateway := NewGateway(config)
err := gateway.StartGateway(&StartOpts{
	TargetLoaders: []loaders.TargetLoader{json.NewJSONFileTargetLoader(config)},
	Exporters: []exporters.Exporter{
		prometheus.NewPrometheusExporter(config),
	},
}) // run forever (or until an error happens)
if err != nil {
	fmt.Printf("Gateway exited with an error: %v", err)
	os.Exit(1)
}
Output:

Index

Examples

Constants

This section is empty.

Variables

View Source
var (
	// Buildtime is set to the current time during the build process by GOLDFLAGS
	Buildtime string
	// Version is set to the current git tag during the build process by GOLDFLAGS
	Version string
)
View Source
var (
	CPUProfile   string
	PrintVersion bool
	PProf        bool
)

Functions

func Main

func Main()

Main is the entry point for the command-line and it's a good example of how to call StartGateway but other than that you probably don't need Main for anything.

func ParseArgs

func ParseArgs(config *configuration.GatewayConfig) error

ParseArgs will parse all of the command-line parameters and configured the associated attributes on the GatewayConfig. ParseArgs calls flag.Parse before returning so if you need to add arguments you should make any calls to flag before calling ParseArgs.

func SetupDebugging

func SetupDebugging(config *configuration.GatewayConfig) (func(), error)

SetupDebugging optionally sets up debugging features including -LogCaller and -PProf.

Types

type CacheClient

type CacheClient struct {
	External bool
	// contains filtered or unexported fields
}

func NewCacheClient

func NewCacheClient(name string, newClient func(leaf *ctree.Leaf), external bool, size uint64) *CacheClient

NewCacheClient creates a new cache client instance and starts the associated goroutines.

func (*CacheClient) Send

func (c *CacheClient) Send(leaf *ctree.Leaf)

type Gateway

type Gateway struct {
	// contains filtered or unexported fields
}

func NewGateway

func NewGateway(config *configuration.GatewayConfig) *Gateway

NewGateway returns an new Gateway instance.

func (*Gateway) AddClient

func (g *Gateway) AddClient(name string, newClient func(leaf *ctree.Leaf), external bool)

Client functions need to complete very quickly to prevent blocking upstream.

func (*Gateway) ConnectToZookeeper

func (g *Gateway) ConnectToZookeeper() (*zk.Conn, error)

func (*Gateway) StartGNMIServer

func (g *Gateway) StartGNMIServer() error

StartGNMIServer will start the gNMI server that serves the Subscribe interface to downstream gNMI clients.

func (*Gateway) StartGateway

func (g *Gateway) StartGateway(opts *StartOpts) error

StartGateway starts up all of the loaders and exporters provided by StartOpts. This is the primary way the server should be started.

type StartOpts

type StartOpts struct {
	// Loader for targets
	TargetLoaders []loaders.TargetLoader
	// Exporters to run
	Exporters []exporters.Exporter
}

StartOpts is passed to StartGateway() and is used to set the running configuration

type ZKLogger

type ZKLogger struct {
	// contains filtered or unexported fields
}

func (*ZKLogger) Printf

func (z *ZKLogger) Printf(a string, b ...interface{})

Directories

Path Synopsis
Package clustering provides an interface to register and list members in a cluster.
Package clustering provides an interface to register and list members in a cluster.
Package configuration contains the GatewayConfig type that is used by the gateway package and all of it's sub-packages.
Package configuration contains the GatewayConfig type that is used by the gateway package and all of it's sub-packages.
Package connections provides the connection manager that forms the transport connection to gNMI targets and initiates gNMI RPC calls.
Package connections provides the connection manager that forms the transport connection to gNMI targets and initiates gNMI RPC calls.
Package exporters provides an interface to export gNMI notifications to other systems or data formats.
Package exporters provides an interface to export gNMI notifications to other systems or data formats.
all
debug
Package debug provides an exporter that will log all received gNMI messages for debugging purposes.
Package debug provides an exporter that will log all received gNMI messages for debugging purposes.
Package loaders provides an interface load target configurations into the connection manager.
Package loaders provides an interface load target configurations into the connection manager.
all
netbox
Package netbox provides a TargetLoader for loading devices from NetBox.
Package netbox provides a TargetLoader for loading devices from NetBox.
simple
Package simple provides a TargetLoader for parsing a simple target YAML config file.
Package simple provides a TargetLoader for parsing a simple target YAML config file.
Package openconfig provides useful types and functions for interacting with OpenConfig modeled data.
Package openconfig provides useful types and functions for interacting with OpenConfig modeled data.
Package server implements the gnmi.proto service API.
Package server implements the gnmi.proto service API.

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL