Skip to content
This repository has been archived by the owner on Apr 22, 2022. It is now read-only.

Latest commit

 

History

History
81 lines (55 loc) · 2.52 KB

README.md

File metadata and controls

81 lines (55 loc) · 2.52 KB

CNI: Post Processing: Manage routes on the host

This is a CNI plugin. To learn more about CNI, see cni.dev.

Overview

host-routes manages routes on the host based on the outputs of previous plugins or its own config.

Configuration

To configure, add this plugin after other plugins. Where it goes will depend on what you want it to do.

{
  "type": "host-routes",
  "routing": "expression",
  "tries": 3,
}

The routing field should contain a jq expression as a string, which should evaluate to an array of Routing objects, with these fields:

  • prefix (IP address/subnet as string, required): the routing prefix.
  • device (string, optional): the device name to route to.
  • gateway (IP address as string, optional): the gateway to route via.

Returning an empty array is acceptable.

The jq expression is invoked with the network config as input, and is limited to 1 second running time.

tries defines how many times failing actions will be retried. Defaults to 3, caps out at 10, setting to 0 or an invalid value will use the default.

Output

This plugin takes the prevResult if present, or an empty / all-defaults one otherwise, and adds (to) a hostRoutes array containing the Routing objects returned by the jq expression. Note that this is not supported by libcni, which will ignore it, so is useful only as debug at this point.

Deletes

The expression will be invoked in the same way, and should return the same things, such that the routes can be cleaned up.

Failure to remove one route will not prevent the following ones from being removed, but will still return an error.

Log file

Error and warn logs are always copied to STDERR.

The verbose flavour logs at debug level to /var/log/cni/host-routes.log.

The logging is suitable for investigating issues in production. Note that log messages may span multiple lines and that their format can change at any time.

The version of the plugin is reported at debug level on startup.

Errors

The plugin errors when:

  • the routing field is missing or not a string.
  • it's not a valid jq expression.
  • the jq expression errors.
  • the jq evaluation times out.
  • it evaluates to an invalid structure.
  • the routing fail to apply.