]> git.proxmox.com Git - mirror_ovs.git/commit
userspace: Improved packet drop statistics.
authorAnju Thomas <anju.thomas@ericsson.com>
Wed, 18 Dec 2019 04:48:12 +0000 (05:48 +0100)
committerIlya Maximets <i.maximets@ovn.org>
Tue, 7 Jan 2020 16:01:42 +0000 (17:01 +0100)
commita13a0209750c424556189796061c40d08c689467
tree32b4f84fdc418f497b25a41828dd7788aa0f20d8
parent924d94a695a6ca54b83d4bd42ec196ba53947c6d
userspace: Improved packet drop statistics.

Currently OVS maintains explicit packet drop/error counters only on port
level.  Packets that are dropped as part of normal OpenFlow processing
are counted in flow stats of “drop” flows or as table misses in table
stats. These can only be interpreted by controllers that know the
semantics of the configured OpenFlow pipeline.  Without that knowledge,
it is impossible for an OVS user to obtain e.g. the total number of
packets dropped due to OpenFlow rules.

Furthermore, there are numerous other reasons for which packets can be
dropped by OVS slow path that are not related to the OpenFlow pipeline.
The generated datapath flow entries include a drop action to avoid
further expensive upcalls to the slow path, but subsequent packets
dropped by the datapath are not accounted anywhere.

Finally, the datapath itself drops packets in certain error situations.
Also, these drops are today not accounted for.This makes it difficult
for OVS users to monitor packet drop in an OVS instance and to alert a
management system in case of a unexpected increase of such drops.
Also OVS trouble-shooters face difficulties in analysing packet drops.

With this patch we implement following changes to address the issues
mentioned above.

1. Identify and account all the silent packet drop scenarios
2. Display these drops in ovs-appctl coverage/show

Co-authored-by: Rohith Basavaraja <rohith.basavaraja@gmail.com>
Co-authored-by: Keshav Gupta <keshugupta1@gmail.com>
Signed-off-by: Anju Thomas <anju.thomas@ericsson.com>
Signed-off-by: Rohith Basavaraja <rohith.basavaraja@gmail.com>
Signed-off-by: Keshav Gupta <keshugupta1@gmail.com>
Acked-by: Eelco Chaudron <echaudro@redhat.com
Acked-by: Ben Pfaff <blp@ovn.org>
Signed-off-by: Ilya Maximets <i.maximets@ovn.org>
20 files changed:
datapath/linux/compat/include/linux/openvswitch.h
lib/dpif-netdev.c
lib/dpif.c
lib/dpif.h
lib/odp-execute.c
lib/odp-util.c
ofproto/ofproto-dpif-ipfix.c
ofproto/ofproto-dpif-sflow.c
ofproto/ofproto-dpif-xlate.c
ofproto/ofproto-dpif-xlate.h
ofproto/ofproto-dpif.c
ofproto/ofproto-dpif.h
tests/automake.mk
tests/dpif-netdev.at
tests/drop-stats.at [new file with mode: 0644]
tests/ofproto-dpif.at
tests/testsuite.at
tests/tunnel-push-pop.at
tests/tunnel.at
vswitchd/vswitch.xml