mirror of
https://github.com/bevyengine/bevy
synced 2024-11-22 04:33:37 +00:00
docs: Add section about using Tracy for profiling (#4534)
# Objective - Document how to do profiling with Tracy # Solution - The documentation of setting `RUST_LOG=info` in order to capture `wgpu` spans depends on https://github.com/bevyengine/bevy/pull/5182
This commit is contained in:
parent
2c9bc0b31f
commit
dfe9690052
1 changed files with 39 additions and 3 deletions
|
@ -2,7 +2,11 @@
|
|||
|
||||
## Runtime Flame Graph: `tracing` spans
|
||||
|
||||
Bevy has built-in [tracing](https://github.com/tokio-rs/tracing) spans to make it cheap and easy to profile Bevy ECS systems, render logic, engine iternals, and user app code. Enable the `trace` cargo feature to enable Bevy's built-in spans. You also need to select a `tracing` backend using the following cargo features:
|
||||
Bevy has built-in [tracing](https://github.com/tokio-rs/tracing) spans to make it cheap and easy to profile Bevy ECS systems, render logic, engine iternals, and user app code. Enable the `trace` cargo feature to enable Bevy's built-in spans.
|
||||
|
||||
If you also want to include `wgpu` tracing spans when profiling, they are emitted at the `tracing` `info` level so you will need to make sure they are not filtered out by the `LogSettings` resource's `filter` member which defaults to `wgpu=error`. You can do this by setting the `RUST_LOG=info` environment variable when running your application.
|
||||
|
||||
You also need to select a `tracing` backend using the following cargo features:
|
||||
|
||||
### Backend: trace_chrome
|
||||
|
||||
|
@ -12,13 +16,45 @@ After running your app a `json` file in the "chrome tracing format" will be prod
|
|||
|
||||
![image](https://user-images.githubusercontent.com/2694663/141657409-6f4a3ad3-59b6-4378-95ba-66c0dafecd8e.png)
|
||||
|
||||
### Backend: trace_tracy
|
||||
|
||||
The [Tracy profiling tool](https://github.com/wolfpld/tracy) is:
|
||||
> A real time, nanosecond resolution, remote telemetry, hybrid frame and sampling profiler for games and other applications.
|
||||
|
||||
There are binaries available for Windows, and installation / build instructions for other operating systems can be found in the [Tracy documentation PDF](https://github.com/wolfpld/tracy/releases/latest/download/tracy.pdf).
|
||||
|
||||
It has a command line capture tool that can record the execution of graphical applications, saving it as a profile file. Tracy has a GUI to inspect these profile files. The GUI app also supports live capture, showing you in real time the trace of your app.
|
||||
|
||||
In one terminal, run:
|
||||
`./capture-release -o my_capture.tracy`
|
||||
This will sit and wait for a tracy-instrumented application to start, and when it does, it will automatically connect and start capturing. Note that on Windows, the capture tool is called `capture.exe`.
|
||||
|
||||
Then run your application, enabling the `trace_tracy` feature:
|
||||
`cargo run --release --features bevy/trace_tracy`
|
||||
|
||||
After running your app, you can open the captured profile file (`my_capture.tracy` in the example above) in the Tracy GUI application to see a timeline of the executed spans.
|
||||
|
||||
Alternatively, directly run the tracy GUI and then run your application, for live capture. However, beware that running the live capture on the same machine will be a competing graphical application, which may impact results. Pre-recording the profile data through the CLI tool is recommended for more accurate traces.
|
||||
|
||||
In any case, you'll see your trace in the GUI window:
|
||||
|
||||
![Tracy timeline demonstrating the performance breakdown of a Bevy app](https://user-images.githubusercontent.com/302146/163988636-25c017ab-64bc-4da7-a897-a80098b667ef.png)
|
||||
|
||||
There is a button to display statistics of mean time per call (MTPC) for all systems:
|
||||
|
||||
![A table in the Tracy GUI showing the MTPC (mean time per call) for all instrumented spans in the application](https://user-images.githubusercontent.com/302146/163988302-c21102d8-b7eb-476d-a741-a2c28d9bf8c1.png)
|
||||
|
||||
Or you can select an individual system and inspect its statistics (available through the "statistics" button in the top menu) to see things like the distribution of execution times in a graph, or statistical aggregates such as mean, median, standard deviation, etc. It will look something like this:
|
||||
|
||||
![A graph and statistics in the Tracy GUI showing the distribution of execution times of an instrumented span in the application](https://user-images.githubusercontent.com/302146/163988464-86e1a3ee-e97b-49ae-9f7e-4ff2b8b761ad.png)
|
||||
|
||||
### Adding your own spans
|
||||
|
||||
Add spans to your app like this (these are in `bevy::prelude::*` and `bevy::log::*`, just like the normal logging macros).
|
||||
|
||||
```rust
|
||||
{
|
||||
// creates a span and starts the timer
|
||||
// creates a span and starts the timer
|
||||
let my_span = info_span!("span_name", name = "span_name").entered();
|
||||
do_something_here();
|
||||
} // my_span is dropped here ... this stops the timer
|
||||
|
@ -28,7 +64,7 @@ Add spans to your app like this (these are in `bevy::prelude::*` and `bevy::log:
|
|||
// Prefer the previous, simpler syntax unless you need the extra control.
|
||||
let my_span = info_span!("span_name", name = "span_name");
|
||||
{
|
||||
// starts the span's timer
|
||||
// starts the span's timer
|
||||
let guard = my_span.enter();
|
||||
do_something_here();
|
||||
} // guard is dropped here ... this stops the timer
|
||||
|
|
Loading…
Reference in a new issue