Skip to content

Latest commit

 

History

History
90 lines (67 loc) · 3.6 KB

Tracing.md

File metadata and controls

90 lines (67 loc) · 3.6 KB

Event Tracing in KV-Engine

Memcached utilises Phosphor to achieve high performance event tracing.

Memcached is explicitly tooled using trace macros which log timestamps and some associated metadata (categories, names, arguments). An example of such a trace macro is given below:

TRACE_EVENT("category", "name", 12345, 67.89);

The full selection of trace macros is documented in the Phosphor header file.

Enabling Tracing

Tracing can be enabled in a basic mode through the use of the PHOSPHOR_TRACING_START environment variable. An example in conjunction with the memcached testapp is shown here:

 PHOSPHOR_TRACING_START="save-on-stop:testapp.%p.json" ./memcached_testapp --gtest_filter="*GetSetTest*"

This will run the memcached Get/Set tests and dump a file in the form 'testapp..json' into the current directory each time the memcached daemon exits. This json file can then be loaded into the Google chrome trace viewer (chrome://tracing).

The environment variable accepts any string-form tracing config as described below.

Tracing can also be controlled via the IOCTL MCBP commands - the easiest way to do this is with the mcctl executable:

$ ./mcctl -h localhost:11210 get trace.status
enabled
  • get trace.status: Returns the current tracing status, either 'enabled' or 'disabled'
  • get trace.config: Returns the current tracing config
  • get trace.dump.begin: Converts the last trace into a new dump and returns the uuid of the new dump
  • get trace.dump.chunk?uuid=<uuid>: Returns the next chunk from the dump of the given uuid
  • set trace.config: Sets the tracing config
  • set trace.start: Starts tracing
  • set trace.stop: Stops tracing
  • set trace.dump.clear: Clears the the dump specified by uuid in the value

A trace can be performed via IOCTL using the following steps

set trace.start
<do stuff you want traced>
set trace.stop
get trace.dump.begin (save the returned uuid)
get trace.dump.chunk?uuid=<uuid> (and repeat until you recieve an empty chunk)
set trace.dump.clear <uuid>

The chunks must then be concatenated to assemble the full JSON dump. This can be done trivially with mcctl and bash:

$ ./mcctl -h localhost:11210 get trace.dump.chunk?uuid=<uuid> >> trace.json

Tracing Config

There are several semi-colon (';') separated options that can be used as part of a tracing config.

  • save-on-stop: Save to a file when tracing stops, accepts %p (pid) and %d (timestamp) placeholders for the given filename.
  • buffer-mode: Accepts one of 'ring' or 'fixed' for a buffer which either overwrites itself when full or stops tracing when full.
  • buffer-size: The size of the trace buffer in bytes to be created
  • enabled-categories: A comma-separated list of categories to be enabled. This supports basic globbing '*' and '?'.
  • disabled-categories: A comma-separated list of categories to be explicitly disabled (This mask is applied after the enabled-categories mask), also supports globbing.

Example Config:

buffer-mode:ring;buffer-size:20000000;enabled-categories:memcached/*;disabled-categories:memcached/state_machine

This particular config would create a 20MB ring buffer, with all memcached categories enabled except for the memcached 'state_machine' category.

Tracing Categories

The convention is followed that memcached categories are prefixed with 'memcached/' and ep-engine categories are prefixed with 'ep-engine/'. This ensures no collisions and allows all categories in a component to be enabled with a wild card (e.g. 'memcached/*').