A safe, dynamic tracing tool for the Java platform
BTrace dynamically instruments running Java applications to inject tracing code at runtime, without stopping the application or recompiling code. Similar to DTrace for OpenSolaris, BTrace uses bytecode instrumentation to trace methods, monitor performance, and diagnose issues in production environments.
- Based on ASM
- Powered by JCTools
- Powered by hppcrt
- Optimized with JProfiler Java Profiler
- Build env helper using SDKMAN!
You will need the following applications installed
cd <btrace>
./gradlew :btrace-dist:buildOutput locations:
- Binary distributions:
btrace-dist/build/distributions/(*.tar.gz, *.zip, *.rpm, *.deb) - Exploded binary (BTRACE_HOME):
btrace-dist/build/resources/main/
Updating golden files: When instrumentor code changes, update test golden files with:
./gradlew test -PupdateTestDataCommit the regenerated golden files to Git.
For a fast local cycle, run unit tests and skip integration tests (which start forked JVMs):
export GRADLE_USER_HOME="$PWD/.gradle-home" # keep caches inside the repo (optional)
./gradlew --no-daemon test -x integration-tests:testTips:
- Prefer IPv4 if your environment has odd local IPs: set
GRADLE_OPTS="-Djava.net.preferIPv4Stack=true -Djava.net.preferIPv6Addresses=false". - Run specific modules:
- Runtime:
./gradlew :btrace-runtime:test - Extension:
./gradlew :btrace-extension:test - Compiler:
./gradlew :btrace-compiler:test - Instr:
./gradlew :btrace-instr:test
- Runtime:
- Update instrumentor golden files when bytecode output changes:
./gradlew test -PupdateTestData.
Integration tests (optional):
./gradlew --no-daemon integration-tests:testThese may exercise privileged extensions. If you run into permission denials, provide a policy file and pass it to the test JVMs via -Dbtrace.permissions=/path/to/permissions.properties.
Use JBang to run BTrace without manual installation:
# Install JBang (one time)
curl -Ls https://sh.jbang.dev | bash -s - app setup
# Use BTrace immediately (replace <version> with desired version, e.g., 2.3.0)
jbang org.openjdk.btrace:btrace-client:<version> <PID> <script.java>
# After first run, use shorter alias
jbang btrace <PID> <script.java>Note: Replace <version> with the desired BTrace version (e.g., 2.3.0). See releases for available versions.
Benefits: Zero installation, automatic version management, works everywhere (Windows/macOS/Linux/containers), perfect for CI/CD.
Extract agent JARs (if needed for --agent-jar/--boot-jar flags):
# Extract embedded JARs
jbang btrace --extract-agent ~/.btrace
# This creates ~/.btrace/btrace-agent.jar and ~/.btrace/btrace-boot.jar
# Then use them:
jbang btrace --agent-jar ~/.btrace/btrace-agent.jar --boot-jar ~/.btrace/btrace-boot.jar <PID> <script.java>
# Or find them in Maven local repository (after first jbang run):
# ~/.m2/repository/org/openjdk/btrace/btrace-agent/<version>/btrace-agent-<version>.jar
# ~/.m2/repository/org/openjdk/btrace/btrace-boot/<version>/btrace-boot-<version>.jarSee Getting Started Guide for complete JBang documentation and examples.
Download: Get the latest release from the release page
# Extract the archive
tar -xzf btrace-*.tar.gz
# or
unzip btrace-*.zip
# Set environment variables (optional but recommended)
export BTRACE_HOME=/path/to/btrace
export PATH=$BTRACE_HOME/bin:$PATH# RPM-based systems
sudo rpm -i btrace-*.rpm
# Debian-based systems
sudo dpkg -i btrace-*.debDocker images:
# Copy BTrace into your application image
FROM btrace/btrace:latest AS btrace
FROM bellsoft/liberica-openjdk-debian:11-cds
COPY --from=btrace /opt/btrace /opt/btrace
ENV BTRACE_HOME=/opt/btrace PATH="${PATH}:${BTRACE_HOME}/bin"
# Your application...Available variants:
btrace/btrace:latest- Debian-based (~25MB)btrace/btrace:latest-alpine- Alpine-based (~15MB)btrace/btrace:latest-distroless- Distroless (~10MB)
See docker/README.md for complete Docker documentation.
With JBang (no installation required):
# Attach to running application
jbang btrace <PID> <trace_script.java>
# Extract agent JARs
jbang btrace --extract-agent ~/.btraceWith installed BTrace:
# Attach to running application
btrace <PID> <trace_script.java>
# Compile BTrace script
btracec <trace_script.java>
# Launch application with BTrace agent
btracer <compiled_script.class> <java-application-and-args>BTrace now supports DTrace-style oneliners for quick debugging without writing full Java scripts:
# Trace method entry with arguments
btrace -n 'javax.swing.*::setText @entry { print method, args }' <PID>
# Find slow database queries (>100ms)
btrace -n 'java.sql.Statement::execute* @return if duration>100ms { print method, duration }' <PID>
# Count method invocations
btrace -n 'java.util.HashMap::get @entry { count }' <PID>
# Print stack trace on OutOfMemoryError
btrace -n 'java.lang.OutOfMemoryError::<init> @return { stack(10) }' <PID>Supported features:
- Locations:
@entry,@return,@error - Actions:
print,count,time,stack - Filters:
if duration>NUMBERms,if args[N]==VALUE - Patterns: Wildcards (
*,?) and regex (/pattern/)
See Oneliner Guide for complete syntax and examples.
For comprehensive documentation, tutorials, and guides:
- BTrace Documentation Hub - Complete documentation index with learning paths, quick reference, troubleshooting, and more
- Getting Started Guide - Get up and running in 5 minutes
- BTrace Wiki - External wiki with additional resources
BTrace supports extensions (like StatsdExtension) that provide additional functionality. Extensions require explicit permissions for security:
- Default permissions (always granted): MESSAGING, AGGREGATION, JFR_EVENTS, PROFILING
- Standard permissions (granted unless denied): FILE_READ, SYSTEM_PROPS, THREAD_INFO, MEMORY_INFO
- Privileged permissions (require explicit grant): FILE_WRITE, NETWORK, THREADS, NATIVE, EXEC, REFLECTION, CLASSLOADER, UNLIMITED_MEMORY
Permissions are enforced based on extension/service descriptors and agent grants specified at attach-time.
Grant permissions at runtime:
btrace --grant=NETWORK,THREADS <PID> MyProbe.classIf extensions fail to load, use -le to troubleshoot:
btrace -le <PID>See the Tutorial for detailed documentation.
Extensions CLI: use btracex to inspect and manage extensions and the simplified permission policy:
btracex inspect <zip|dir>prints extension id, version, services, and whether it’s privileged.btracex policy print|set [--policy-file <path>|--home|--classpath <outDir>]editsallowExtensions,denyExtensions,allowPrivileged.btracex listshows installed extensions;btracex installinstalls from Maven coordinates.
Note: Extension “required permissions” are informational and help operators assess risk. Implementation linking is controlled by per‑extension allow/deny lists and the allowPrivileged flag; when blocked, APIs remain available and SHIMs are used so probes continue safely.
- Launch-time policy can be set via agent args (operator-controlled):
-javaagent:btrace-agent.jar=...,grant=NETWORK,THREADS,grantAll=false-javaagent:btrace-agent.jar=...,allowExtensions=btrace-statsd,my-metrics,denyExtensions=legacy-foo
- Optional policy file (process-local):
-Dbtrace.permissions=/path/to/permissions.propertiesor~/.btrace/permissions.properties. - When an extension impl is blocked, the API remains on bootstrap so SHIMs can be generated.
See docs/PermissionPolicy.md for details and examples.
- Launch:
btracex inspect(with no args) opens an interactive view of installed extensions. - Header: shows current policy file path and the list of scanned repositories.
- Table: columns State, Id, Version. State uses compact symbols:
?(default),+(allowed),-(denied). - Details: selection updates automatically; shows the full-word state:
default/allowed/deniedand the full path. - Legend: a short legend under the table maps the state symbols.
Screenshot / demo (optional):
See also: docs/TUI.md for recording tips and an ASCII preview.
Keys
- Navigate: Arrow keys, PageUp/PageDown, Home/End
- Toggle state: space (flows
? → + (confirm) → - → +; onlycclears to default) - Clear:
c(removes extension id from both allow and deny lists) - Explain privileges:
e(opens a dialog with required permissions and risk descriptions) - Filter:
/(filter by id or path) - Sort:
s(choose column; repeat to toggle asc/desc) - Adjust split:
m(enter mode), then Up/Down to resize; pressEscormagain to exit - Help / Quit:
?/q
The BTrace Maven Plugin enables:
- Compilation of BTrace scripts during the build process
- BTrace Project Archetype for quick project setup
Important: Pull requests can only be accepted from signers of the Oracle Contributor Agreement.
See CLAUDE.md for detailed development guidelines and project architecture.
- Slack: btrace.slack.com
- Gitter: gitter.im/btraceio/btrace
- Issues: GitHub Issues
BTrace is licensed under GPLv2 with the Classpath Exception. See LICENSE for details.


