4.6 KiB
Profiling influxdb3
This document explains several profiling strategies.
Preparation
Choosing a profile
You will need to choose a profile to build and run the influxdb3
binary. Available profiles are
configured in [Cargo.toml] and are listed here:
release
: this is the profile used for release builds, and will produce a fully-optimized production quality release binary. The compile time for this profile can be quite long, so for rapid iteration, this profile is not recommended.quick-release
: this is a modified version ofrelease
intended to produce a close-to-production binary, but with a faster build time. So, it is more suitable to rapid iterations and testing out changes.bench
: this is the same asrelease
, but will compile the binary withdebuginfo
turned on for more readable symbols in generated profiles.quick-bench
: a modified version ofquick-release
that compiles the binary withdebuginfo
turned on.dev
: this profile produces an unoptimized binary withdebuginfo
turned on.
If you are getting started, we recommend using either the quick-release
or quick-bench
profiles
to get up and running faster, then once you are ready, and need to get as much performance as
possible out of the binary, use release
or bench
.
Building and running the binary
Once you have chosen a profile, you can build the influxdb3
binary using cargo:
cargo build -p influxdb3 --profile <profile>
This will build the binary and place it in the target
folder in your working directory, e.g.,
target/<profile>/influxdb3
.
You can then prfile the influxdb3
server, or whichever command, using the fully-qualified path
and the profiling tools of your choice. For example,
<path_to_working_directory>/target/<profile>/influxdb3 serve
Profiling Tools
macOS
Instruments is a versatile profiling tool packaged with XCode on macOS that comes with several built-in profiling tools.
In order to profile your compiled influxdb3
binary, you will need to choose it as the target in
Instruments, and then provide the necessary environment variables or command line arguments. For
example, to profile a running influxdb3
instance using the local file system for object storage,
you would choose the compiled target as:
<path_to_working_directory>/target/<profile>/influxdb3
and then provide the command-line arguments:
serve --object-store=file --data-dir=~/.influxdb3
You can then start your profiled binary by pressing the red record button, File > Record Trace
, or with the shortcut ⌘
+R
.
If the default sampling frequency in Instruments is not resolute enough, then you can open the File > Recording Options and enable High-Frequency recording.
Instruments: CPU/Performance Profiling
There are several instruments useful for profiling the CPU and performance of influxdb3
.
- Time Profiler (sample-based CPU profiler)
- CPU Profiler (cycle-based CPU profiler)
- Filesystem Activity (file system and disk I/O activity)
- System Call Trace (system calls and CPU scheduling)
Instruments: Allocations
The allocations instrument is a powerful tool for tracking heap allocations on macOS and recording call stacks.
It can be used with Rust and influxdb3
, but requires some additional steps on aarch64 and later
versions of macOS due to increased security.
Preparing binary
You must compile influxdb3
with --no-default-features
to ensure the default system allocator is
used. Following the compilation step, you must codesign the binary with
the get-task-allow
entitlement set to true
. Without the codesign step, the Allocations
instrument will fail to start with an error similar to the following:
Required Kernel Recording Resources Are in Use
First, generate a temporary entitlements plist file, named tmp.entitlements
:
/usr/libexec/PlistBuddy -c "Add :com.apple.security.get-task-allow bool true" tmp.entitlements
Then codesign the file with the tmp.entitlements
file:
codesign -s - --entitlements tmp.entitlements -f target/release/influxdb3
You can verify the file is correctly code-signed as follows:
codesign --display --entitlements - target/release/influxdb3
Executable=<path_to_working_dir>/target/<profile>/influxdb3
[Dict]
[Key] com.apple.security.get-task-allow
[Value]
[Bool] true
or the running influxdb3
process using its PID:
codesign --display --entitlements - +<PID>