How to Profile Databend
CPU profiling
go tool pprof -svg http://localhost:8080/debug/pprof/profile?seconds=30 > cpu.svg
data:image/s3,"s3://crabby-images/a7720/a77207cfb55dcdffad3a10c4a361682f5ec27f88" alt=""
Memory profiling
databend-query
and databend-meta
can be built optionally with jemalloc
,
which provides various memory profiling features.
Currently, it does not work on Mac, with either intel or ARM.
Enable memory profiling
Build
databend-query
withmemory-profiling
feature enabled:cargo build --bin databend-query --release --features memory-profiling
Fire up
databend
, using environment variableMALLOC_CONF
to enable memory profiling:MALLOC_CONF=prof:true,lg_prof_interval:30 ./target/release/databend-query
Generate heap profile
Generate a call graph in pdf
illustrating memory allocation during this interval:
jeprof --pdf ./target/release/databend-query heap.prof > heap.pdf
data:image/s3,"s3://crabby-images/04763/04763ad7fe2b267a60b3e253996c27a696b9c60c" alt=""
Fast jeprof
jeprof is very slow for large heap analysis, the bottleneck is addr2line
, if you want to speed up from 30 minutes to 3s, please use :
git clone https://github.com/gimli-rs/addr2line
cd addr2line
cargo b --examples -r
cp ./target/release/examples/addr2line <your-addr2line-find-with-whereis-addr2line>