puntplugin

package
v2.0.1+incompatible Latest Latest
Warning

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

Go to latest
Published: Apr 5, 2019 License: Apache-2.0 Imports: 18 Imported by: 11

README

Punt plugin

Written for: v1.7-vpp18.10

The punt plugin provides several options for how to configure the VPP to allow a specific IP traffic to be punted to the host TCP/IP stack. The plugin supports punt to the host (either directly, or via Unix domain socket) and registration of IP punt redirect rules.

Punt to host stack

All the incoming traffic matching one of the VPP interface addresses, and also matching defined L3 protocol, L4 protocol, and port - and would be otherwise dropped - will be instead punted to the host. If a Unix domain socket path is defined (optional), the traffic will be punted via socket. All the fields which serve as a traffic filter are mandatory.

Model

The punt plugin defines the following model which grants support for two main configuration items defined by different northbound keys.

The punt to host is defined as ToHost object in the generated proto model.

The key has a following format (for both, with or without socket):

vpp/config/v2/punt/tohost/l3/<L3_protocol>/l4/<L4_protocol>/port/<port_number>

L3/L4 protocol in the key is defined as a string value, however, the value is transformed to numeric representation in the VPP binary API.

The usage of L3 protocol ALL is exclusive for IP punt to host (without socket registration) in the VPP API. If used for the IP punt with socket registration, the vpp-agent calls the binary API twice with the same parameters for both, IPv4 and IPv6.

Requirements

Important note: in order to configure a punt to host via Unix domain socket, a specific VPP startup-config is required. The attempt to set punt without it results in errors in VPP. Startup-config:

punt {
  socket /tmp/socket/punt
}

The path has to match with the one in the northbound data.

Configuration

How to configure punt to host:

1. Using Key-value database: put proto-modeled data to the database under the correct key for punt to host configuration. If the database is the ETCD, it is possible to use vpp-agent-ctl utility. Let's assume that we want to configure a punt to host with socket registration (with default agent label vpp1):

vpp-agent-ctl -put "/vnf-agent/vpp1/vpp/config/v2/punt/tohost/l3/IPv4/l4/UDP/port/9000" json/punt-to-host.json

The more simple way is to use the configuration example directly in the vpp-agent-ctl. The example contains pre-defined data which can be put to the ETCD with a single command. Commands are different for a punt to host alone, or registered via socket:

vpp-agent-ctl -puntr        // simple punt to host
vpp-agent-ctl -rsocket      // register punt to host via socket

To remove/deregister data, use:

vpp-agent-ctl -puntd
vpp-agent-ctl -dsocket

2. Using REST not yet implemented

3. Using GRPC: not yet implemented

Limitations

Current limitations for a punt to host:

  • The UDP configuration cannot be shown (or even configured) in the VPP cli.
  • The VPP does not provide API to dump configuration, which takes the vpp-agent the opportunity to read existing entries and may case issues with resync.
  • Although the vpp-agent supports the TCP protocol as the L4 protocol to filter incoming traffic, the current VPP version don't.
  • Configured punt to host entry cannot be removed since the VPP does not support this option. The attempt to do so exits with an error.

Current limitations for a punt to host via unix domain socket:

  • The configuration cannot be shown (or even configured) in the VPP cli.
  • The vpp-agent cannot read registered entries since the VPP does not provide an API to dump.
  • The VPP startup config punt section requires unix domain socket path defined. The limitation is that only one path can be defined at a time.
Known issues
  • VPP issue: if the Unix domain socket path is defined in the startup config, the path has to exist, otherwise the VPP fails to start. The file itself can be created by the VPP.

IP redirect

Defined as the IP punt, IP redirect allows a traffic matching given IP protocol to be punted to the defined TX interface and next hop IP address. All those fields have to be defined in the northbound proto-modeled data. Optionally, the RX interface can be also defined as an input filter.

Model

IP redirect is defined as IpRedirect object in the generated proto model.

The key has a following format:

vpp/config/v2/punt/ipredirect/l3/<L3_protocol>/tx/<tx_interface_name>

L3 protocol is defined as string value (transformed to numeric in VPP API call). The table is the same as before.

If L3 protocol is set to ALL, the respective API is called for IPv4 and IPv6 separately.

Configuration

How to configure IP redirect:

1. Using the key-value database: put proto-modeled data to the database under the correct key for IP redirect configuration. If the database is the ETCD, it is possible to use vpp-agent-ctl utility. Let's assume that we want to configure following IP redirect (with default agent label vpp1). Since the configuration counts with an existing interface (tap1 in this case), the interface has to be configured as well (the order does not matter).

vpp-agent-ctl -put "/vnf-agent/vpp1/vpp/config/v2/interface/tap1" json/tap.json
vpp-agent-ctl -put "/vnf-agent/vpp1/vpp/config/v2/punt/ipredirect/l3/IPv4/tx/tap1" json/ip-redirect.json

The simple way is to use an configuration example directly in the vpp-agent-ctl. The example contains pre-defined data which can be put to ETCD with a single command. Let's configure interface and IP redirect:

vpp-agent-ctl -tap
vpp-agent-ctl -ipredir

To remove IP redirect entry, use:

vpp-agent-ctl -ipredird

In case the interface is not configured, the IP redirect data are cached and marked as pending, awaiting the interface to appear in order to be re-tried.

2. Using REST not yet implemented

3. Using GRPC: not yet implemented

The VPP cli command (for configuration verification) is show ip punt redirect .

Limitations
  • The VPP does not provide API calls to dump existing IP redirect entries. It may cause resync not to work properly.
Known issues
  • No issues are known with the current VPP version.

Documentation

Index

Constants

This section is empty.

Variables

View Source
var DefaultPlugin = *NewPlugin()

DefaultPlugin is a default instance of punt plugin.

Functions

This section is empty.

Types

type Deps

type Deps struct {
	infra.PluginDeps
	KVScheduler  kvs.KVScheduler
	GoVppmux     govppmux.API
	IfPlugin     ifplugin.API
	PublishState datasync.KeyProtoValWriter     // optional
	StatusCheck  statuscheck.PluginStatusWriter // optional
}

Deps lists dependencies of the punt plugin.

type Option

type Option func(puntPlugin *PuntPlugin)

Option is a function that can be used in NewPlugin to customize Plugin.

func UseDeps

func UseDeps(f func(deps *Deps)) Option

UseDeps returns Option that can inject custom dependencies.

type PuntPlugin

type PuntPlugin struct {
	Deps
	// contains filtered or unexported fields
}

PuntPlugin configures VPP punt to host or unix domain socket entries and IP redirect entries using GoVPP.

func NewPlugin

func NewPlugin(opts ...Option) *PuntPlugin

NewPlugin creates a new Plugin with the provided Options.

func (*PuntPlugin) AfterInit

func (p *PuntPlugin) AfterInit() error

AfterInit registers plugin with StatusCheck.

func (*PuntPlugin) Init

func (p *PuntPlugin) Init() (err error)

Init registers STN-related descriptors.

Directories

Path Synopsis

Jump to

Keyboard shortcuts

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