aboutsummaryrefslogtreecommitdiffstats
path: root/src/plugins/sflow/sflow.rst
blob: f9c18488363d98a55be8a0beda9918052ac2b7b2 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
.. _Sflow_agent:

.. toctree::

SFlow Monitoring Agent
======================

Overview
________

This plugin implements the random packet-sampling and interface
telemetry streaming required to support standard sFlow export
on Linux platforms. The overhead incurred by this monitoring is
minimal, so that detailed, real-time traffic analysis can be
achieved even under high load conditions, with visibility into
any fields that appear in the packet headers. If the VPP linux-cp
plugin is running then interfaces will be mapped to their
equivalent Linux tap ports.

Example Configuration
_____________________

::
    sflow sampling-rate 10000
    sflow polling-interval 20
    sflow header-bytes 128
    sflow enable GigabitEthernet0/8/0
    sflow enable GigabitEthernet0/9/0
    sflow enable GigabitEthernet0/a/0
    ...
    sflow enable GigabitEthernet0/a/0 disable

Detailed notes
______________

Each VPP worker that has at least one interface, will create a FIFO
and enqueues samples to it from the interfaces it is servicing that
are enabled. There is a process running in the main thread that will
dequeue the FIFOs periodically. If the FIFO is full, the worker will
drop samples, which helps ensure that (a) the main thread is not
overloaded with samples and (b) that individual workers and interfaces,
even when under high load, can't crowd out other interfaces and workers.

You can change the sampling-rate at runtime, but keep in mind that
it is a global variable that applies to workers, not interfaces.
This means that (1) all workers will sample at the same rate, and (2)
if there are multiple interfaces assigned to a worker, they'll share
the sampling rate which will undershoot, and similarly (3) if there
are multiple RX queues assigned to more than one worker, the effective
sampling rate will overshoot.

External Dependencies
_____________________

This plugin writes packet samples to the standard Linux netlink PSAMPLE
channel, so the kernel psample module must be loaded with modprobe or
insmod. As such, this plugin only works for Linux environments.

It also shares periodic interface counter samples vi netlink USERSOCK.
The host-sflow daemon, hsflowd, at https://sflow.net is one example of
a tool that will consume this feed and emit standard sFlow v5.