This crate provides a bridge between gstreamer and the tracing ecosystem.
The goal is to allow Rust applications utilizing GStreamer to better integrate into application
that otherwise use the [tracing
] crate for their observability needs.
To output gstreamer
log messages as [tracing
] events, call the [integrate_events
]
function. Calling it before the call to any other gstreamer
call (especially before the
gstreamer::init
) is most likely to correctly forward all of the messages:
```rust // Set up the tracing subscriber. // // e.g. tracing_subscriber::fmt::init();
tracinggstreamer::integrateevents(); gstreamer::debugremovedefaultlogfunction(); gstreamer::init(); ```
Keep in mind that both GST_DEBUG
and tracing filters are in effect. The gstreamer
side of
filters can be relaxed from code via:
gstreamer::debug_set_default_threshold(gstreamer::DebugLevel::Count);
Similarly you can use tracing
APIs to adjust the filters on the tracing
side.
To provide tracing
with more contextual information for some of the events, you can also enable
support for generating spans via gstreamer
's own tracing infrastructure.
This functionality can be enabled by calling the [integrate_spans
] function. It must be called
after gstreamer::init
.
rust
gstreamer::init();
tracing_gstreamer::integrate_spans();
This section demonstrates the results obtained with different kinds of subscribers.
tracing_subscriber::fmt
This subscriber is a great replacement for the built-in gstreamer log handler. Here's an example of what the output might look like when using this subscriber:
``text
$ env RUST_LOG=info cargo run --example videoenc
Finished dev [unoptimized + debuginfo] target(s) in 0.04s
Running
target/debug/examples/videoenc`
Jan 01 00:00:00.000 INFO gstreamer::GSTINIT: Initializing GStreamer Core Library version 1.18.4
audiotestsrc num-buffers=120
! opusenc
! mux.
'
```
Certain messages may also provide more information than the built-in logger. While builtin logger
does present you with the type and address of the object being logged, tracing-gstreamer
may
provide more readily useful information such as the element name:
text
Jan 01 00:00:00.000 INFO gstreamer::GST_STATES: completed state change to READY gobject.address=94331150660528 gobject.type="GstAudioTestSrc" gstobject.name="audiotestsrc0" gstelement.state="ready" gstelement.pending_state="void-pending"
or provide additional context via spans, which may help to figure out which element is logging the message when there is no other way to tell this otherwise, such as in this example:
text
Jan 01 00:00:00.000 INFO pad_push{gstpad.state={NEED_PARENT} gstpad.parent.name="audiotestsrc0"}: gstreamer::structure: Expected field 'channel-mask' in structure: audio/x-raw, rate=(int)48000, channels=(int)1, format=(string)S16LE, layout=(string)interleaved;
tracing-tracy
Tracy is a profiler focused primarily on game development workloads, but works fairly well for
general purpose code as well. Tracy features a sampling profiler, but works best with applications
that have manually instrumented points of interest. tracing
is a great source of such manual
instrumentation points and tracing-tracy
is the bridge between the two. The following video
demonstrates the videoenc
example from this repository adapted to utilize the tracing-tracy
subscriber.
In this video there are a couple of highlights
queue
s would help?)opusenc0
element sometimes takes an unusually long time because the
downstream muxer already has a buffer queued at the time.Similar results can be achieved with some other subscribers as well.