monitor

package
v1.5.1 Latest Latest
Warning

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

Go to latest
Published: May 9, 2019 License: Apache-2.0 Imports: 25 Imported by: 0

README

Cilium node monitor

The node monitor provides an API for reading the events from the BPF datapath. When the process cilium-node-monitor is started it handles new connections to $RuntimePath/monitor.sock. Users of the API are expected to read the Meta and Payload structs (encoded in gob). Since the payload can vary in size to make decoding easier the Meta contains the size of the payload. The API is not stable yet and might change in the future. If you start depending on the current behavior, please consider creating tests so that potential breakage is detected earlier.

Notifications from the BPF datapath are transmitted via the perf ring buffer. The perf ring buffer is a single reader data structure. The node monitor provides access to the notifications to multiple readers by multiplexing all notifications to all registered readers.

The node monitor is normally built together with the Cilium agent. In the top level Makefile there is a target which makes it easier to test both changes to the agent and monitor by running

    $ make reload

If you prefer you can also compile the monitor separately

    $  make -C monitor

And then run it by

    $ ./monitor/cilium-node-monitor

Normally you would not need to run the monitor manually since it's already part of the startup in the agent. In the unlikely case, you would need to run a patched version of the monitor manually commenting out the call to go d.nodeMonitor.Run() in the runDaemon() function is enough to stop the agent from starting the node monitor and then you can execute your version of the node monitor.

Documentation

Index

Constants

This section is empty.

Variables

This section is empty.

Functions

func Execute

func Execute()

Execute is an entry point for node monitor

Types

type Monitor

type Monitor struct {
	lock.Mutex
	// contains filtered or unexported fields
}

Monitor structure for centralizing the responsibilities of the main events reader. There is some racey-ness around perfReaderCancel since it replaces on every perf reader start. In the event that a MonitorListener from a previous generation calls its cleanup after the start of the new perf reader, we might call the new, and incorrect, cancel function. We guard for this by checking the number of listeners during the cleanup call. The perf reader must have at least one MonitorListener (since it started) so no cancel is called. If it doesn't, the cancel is the correct behavior (the older generation cancel must have been called for us to get this far anyway).

func NewMonitor

func NewMonitor(ctx context.Context, nPages int, agentPipe io.Reader, server1_0, server1_2 net.Listener) (m *Monitor, err error)

NewMonitor creates a Monitor, and starts client connection handling and agent event handling. Note that the perf buffer reader is started only when listeners are connected.

Directories

Path Synopsis

Jump to

Keyboard shortcuts

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