LTTNG-SNAPSHOT(1) | LTTng Manual | LTTNG-SNAPSHOT(1) |
lttng-snapshot - Take LTTng snapshots and configure snapshot outputs
Add a snapshot output:
lttng [GENERAL OPTIONS] snapshot add-output [--max-size=SIZE]
[--name=NAME] [--session=SESSION]
(--ctrl-url=URL --data-url=URL | URL)
Remove a snapshot output:
lttng [GENERAL OPTIONS] snapshot del-output [--session=SESSION]
(ID | NAME)
List current snapshot outputs:
lttng [GENERAL OPTIONS] snapshot list-output [--session=SESSION]
Take a snapshot:
lttng [GENERAL OPTIONS] snapshot record [--max-size=SIZE]
[--name=NAME] [--session=SESSION]
(--ctrl-url=URL --data-url=URL | URL)
The lttng snapshot command manages the snapshot outputs and takes snapshots.
A snapshot is a dump of the current sub-buffers of all the channels of a given tracing session. When a snapshot is taken, the memory dump is sent to the registered snapshot outputs.
The tracing session should be created in snapshot mode to make sure that taking snapshots is allowed. This is done at tracing session creation time using the lttng-create(1) command’s --snapshot option.
Note that, when a snapshot is taken, the sub-buffers are not cleared. This means that different recorded snapshots may contain the same events.
If you want, instead, to keep all the trace data, but divide it into archived chunks which are then free to process (just like snapshots), see the lttng-rotate(1) and lttng-enable-rotation(1) commands. Trace chunk archives do not overlap like snapshots can.
Snapshot outputs are the destinations of snapshot files when a snapshot is taken using the record action.
As of this version, only one snapshot output is allowed.
A snapshot output can be added using the add-output action. The output destination URL is set using either the URL positional argument, or both the --ctrl-url and --data-url options. See lttng-create(1) to learn more about the URL format.
A name can be assigned to an output when adding it using the --name option. This name is part of the names of the snapshot files written to this output.
By default, the snapshot files can be as big as the sum of the sizes of all the sub-buffers or all the channels of the selected tracing session. The maximum total size of all the snapshot files can be configured using the --max-size option.
Snapshot outputs can be listed using the list-output action.
Snapshot outputs can be removed using the del-output action. The configured name can be used when removing an output, or an ID as listed by the list-output action.
Taking a snapshot of the current tracing session is as easy as:
$ lttng snapshot record
This writes the snapshot files to the configured output. It is possible to use a custom, unregistered output at record time using the same options supported by the add-output action.
Before taking a snapshot on a system with a high event throughput, it is recommended to first run lttng stop (see lttng-stop(1)). Otherwise, the snapshot could contain "holes", the result of the tracers overwriting unconsumed trace packets during the record operation. After the snapshot is recorded, the tracers can be started again with lttng start (see lttng-start(1)).
General options are described in lttng(1).
-s SESSION, --session=SESSION
-C URL, --ctrl-url=URL
-D URL, --data-url=URL
-m SIZE, --max-size=SIZE
-n NAME, --name=NAME
-h, --help
This option, like lttng-help(1), attempts to launch /usr/bin/man to view the command’s man page. The path to the man pager can be overridden by the LTTNG_MAN_BIN_PATH environment variable.
--list-options
LTTNG_ABORT_ON_ERROR
LTTNG_HOME
LTTNG_MAN_BIN_PATH
LTTNG_SESSION_CONFIG_XSD_PATH
LTTNG_SESSIOND_PATH
The --sessiond-path option has precedence over this environment variable.
Note that the lttng-create(1) command can spawn an LTTng session daemon automatically if none is running. See lttng-sessiond(8) for the environment variables influencing the execution of the session daemon.
$LTTNG_HOME/.lttngrc
This is where the per-user current tracing session is stored between executions of lttng(1). The current tracing session can be set with lttng-set-session(1). See lttng-create(1) for more information about tracing sessions.
$LTTNG_HOME/lttng-traces
$LTTNG_HOME/.lttng
$LTTNG_HOME/.lttng/sessions
/etc/lttng/sessions
$LTTNG_HOME defaults to $HOME when not explicitly set.
0
1
2
3
4
If you encounter any issue or usability problem, please report it on the LTTng bug tracker <https://bugs.lttng.org/projects/lttng-tools>.
This program is part of the LTTng-tools project.
LTTng-tools is distributed under the GNU General Public License version 2 <http://www.gnu.org/licenses/old-licenses/gpl-2.0.en.html>. See the LICENSE <https://github.com/lttng/lttng-tools/blob/master/LICENSE> file for details.
Special thanks to Michel Dagenais and the DORSAL laboratory <http://www.dorsal.polymtl.ca/> at École Polytechnique de Montréal for the LTTng journey.
Also thanks to the Ericsson teams working on tracing which helped us greatly with detailed bug reports and unusual test cases.
9 November 2018 | LTTng 2.12.3 |