- Home
- About Pixie
- Installing Pixie
- Using Pixie
- Tutorials
- Reference
Pixie uses eBPF to automatically instrument Kubernetes applications.
Pixie ships with a set of default data sources, which can also be extended by the user.
Pixie automatically collects the following data:
Protocol traces: Full-body messages between the pods of your applications. Tracing currently supports the following list of protocols. For more information, see the Request Tracing, Service Performance, and Database Query Profiling tutorials.
Resource metrics: CPU, memory and I/O metrics for your pods. For more information, see the Infra Health tutorial.
Network metrics: Network-layer and connection-level RX/TX statistics. For more information, see the Network Monitoring tutorial.
JVM metrics: JVM memory management metrics for Java applications.
Application CPU profiles: Sampled stack traces from your application. Pixie’s continuous profiler is always running to help identify application performance bottlenecks when you need it. Currently supports compiled languages (Go, Rust, C/C++). For more information, see the Continuous Application Profiling tutorial.
Pixie can also be configured by the user to collect dynamic logs from Go application code and to run custom BPFTrace scripts.
Pixie automatically traces the following protocols:
Protocol | Support | Notes |
---|---|---|
HTTP | Supported | |
HTTP2 | Supported for Golang gRPC (with and without TLS). | Golang apps must have debug information. |
DNS | Supported | |
NATS | Supported | Requires a NATS build with debug information. |
MySQL | Supported | |
PostgreSQL | Supported | |
Cassandra | Supported | |
Redis | Supported | |
Kafka | Supported | |
AMQP | Supported |
Additional protocols are under development.
Pixie supports tracing of traffic encrypted with the following libraries:
Library | Notes |
---|---|
OpenSSL | Version 1.1.0, 1.1.1 or 3.x dynamically linked. |
Go TLS -- standard and boringcrypto | Requires a build with debug information. |
BoringSSL |