Quick start
The old-tracing system (based on iohk-monitoring-framework) exists together with new-tracing (based on trace-dispatcher and cardano-tracer).
The Old-tracing system will be eventually decommisoned. In this transition time new-tracing can be tested and improved. Since we have several hundred trace messages it is expected that you will find regressions and bugs in the port, please help to find and fix them.
In this transition time new tracing will for technical reason have a restricted functionality, as e.g. the reconfiguration of a running node is not available.
To switch to new tracing set the value UseTraceDispatcher
to true. If you do this, the
config file needs to contain several values for the configuration of new-tracing, as we
describe next.
The current tracing system has two ways to identify the message, a hierarchical name we
call it's Namespace
and the Kind field
in machine representation. We base our implementation
on the namespace, and require a one-to-one correspondence between namespaces and messages (bijective mapping).
As we have two mechanisms for the same purpose for historic reasons, we will soon deprecate the Kind field, and it will disappear in the near future. So we strongly advice to use namespaces for any analysis tools of traces!
Configuration of new tracing
In Cardano a default configuration is given in the module Cardano.Node.Tracing.DefaultTraceConfig. In the config file all entries of the default configuration can be overridden. To remove a frequency limiter, define a limiter with maxFrequency 0.0.
Specify a filter for the severity of the messages you want to see, e.g.:
# Show messages of Severity Notice or higher as default
"":
severity: Notice
# But show ChainDB messages starting from Info
ChainDB:
severity: Info
So the namespaces are used for configuration values, which works down to individual messages, and the more specialized value overwrites the more general.
If you don't want to see any messages from tracers the new severity Silence
exists, which suppresses all messages.
Specify in which detail level, the messages get shown.
"":
# Keep this
severity: Notice
# All messages are shown with normal detail level
detail: DNormalOther options would be DMinimal, DDetailed and DMaximum. This has only an effect on messages which support the representation in different ways.
Specify limiters for the frequency of messages
Eliding tracers are not supported in new-tracing, instead you can limit the frequency in which messages get shown.
ChainDB.AddBlockEvent.AddedBlockToQueue:
# Only show a maximum of 2 of these messages per second
maxFrequency: 2.0The activity of limiters will be written in the traces as well.
Specify the backends the messages are routed to.
"":
# Keep this
severity: Notice
# And this
detail: DNormal
# And specify a list of backends to use
backends:
- Stdout MachineFormat
- EKGBackend
- ForwarderThese are all the backends currently supported. With Stdout you have the options MachineFormat or HumanFormatColoured/HumanFormatUncoloured. If messages don't support representation in HumanFormat* they are shown in MachineFormat anyway.
Forwarder means that messages are send to cardano-tracer
Configuration can be written in JSON and YAML, we have shown the examples in YAML.
Configuration and use of cardano-tracer
cardano-tracer
is a part of the new tracing infrastructure. It is a separate service that accepts different messages from the node and handles them.
So it is assumed that if you want to use the new tracing infrastructure - you will use cardano-tracer
. Please read its documentation for more details.
This example describes the simplest case, when the node and cardano-tracer
on the same machine.
First of all, add --tracer-socket-path-connect /tmp/forwarder.sock
option to the node's CLI options, asking it to connect to cardano-tracer
.
Then build and run cardano-tracer
:
$ cabal build cardano-tracer && cabal install cardano-tracer --installdir=PATH_TO_DIR --overwrite-policy=always
$ cd PATH_TO_DIR
$ ./cardano-tracer --config PATH_TO_CONFIG
where PATH_TO_CONFIG
is a path to tracer's configuration file. This is an example of such a configuration:
---
network:
tag: AcceptAt
contents: "/tmp/forwarder.sock"
logging:
- logRoot: "/tmp/cardano-tracer-logs"
logMode: FileMode
logFormat: ForMachine
That's it. After you run the node, it will establish the connection with cardano-tracer
and will start to forward messages to it.
As a result, you will find log files, in JSON format, in /tmp/cardano-tracer-logs
directory.
Development during transition-time
For developing tracers in the transition time we suggest:
Don't use strictness annotations for trace types. Trace messages are either discarded immediately (which happens frequently) or instantly converted to another format but never stored. So strictness annotations make the code less efficient without any benefit. As well it doesn't play well together with the required prototypes of messages in the new framework.
If you develop new tracers we suggest that you develop the new tracers first, and then map to old tracers, as the new tracers will survive. You will find plenty of examples in cardano-node under Cardano.Node.Tracing.Tracers.
Contact the benchmarking team or node-logging channel for any questions and reviews.
Documentation of trace messages and further documentation
This is a document which is regenerated periodically and documents all trace-messages, metrics and data-points in cardano-node. It as well displays the handling of these messages with the current default configuration:
This document describes the underlying library trace-dispatcher:
trace-dispatcher: efficient, simple and flexible program tracing
This document describes a seperate service for logging and monitoring Cardano nodes: