Versions Compared

Key

  • This line was added.
  • This line was removed.
  • Formatting was changed.

...

Socket initialization includes, the client sockets creation, connecting to the server socket , sending the client registration message to the server and waiting for registration to be accepted by the server to get the plugin  initialization to be succeed. In case of registration failure , the sockets will be closed and plugin initialization results to be failed.  The plugin does provide some resiliency when server socket is not connected, i.e. during plugin initialization if it don’t see the server socket, it would keep trying to connect to the server for 6 seconds, if still no connection is established , the plugin  will be marked as uninitialized. getting the response. 

Plugin read loop:

Once all the After the  socket initialization happens , the plugin read loop will be kicked off for every 6 plugin interval  seconds to read the stats from DPDK by sending JSON encoded message to the server and waiting for the response. During the  read loop if the  plugin  don’t see the server socket ,  it would try reconnecting  to it for 6 seconds, in case of no success it would  result in plugin read failed.

Setup:

Plugin configuration:

...

      The port based dpdk stats will have port number suffixed at the end of the each stat name. The application or global stats are the ones
without any suffix.

Dependencies: 

1)This plugin depends on the DPDK 19.08 release


Building and Running DPDK  application:

1)To fetch DPDK stats the DPDK has to be compiled with below telemetry config flag set to y

CONFIG_RTE_LIBRTE_TELEMETRY=y

2)Also the DPDK application should be run with "–telemetry" eal option.

 Ex:  $dpdk/app/testpmd --telemetry  -l 2,3,4 -n 4 

Reference: 

  1. DPDK telemetry library          - http://lxr.dpdk.org/dpdk/v19.08/source/lib/librte_telemetry
  2. DPDK telemetry library doc:  - http://lxr.dpdk.org/dpdk/v19.08/source/doc/guides/howto/telemetry.rst

...