Skip to content

azat/chdig

Repository files navigation

chdig

Dig into ClickHouse with TUI interface.

Installation

chdig is also available as part of clickhouse - clickhouse chdig, but that version may be slightly outdated.

Pre-built packages (.deb, .rpm, archlinux, .tar.gz) and standalone binaries for Linux and macOS are available for both x86_64 and aarch64 architectures.

The latest unstable release can be found on GitHub.

See also the complete list of releases.

Package repositories (AUR, Scoop, Homebrew)

archlinux user repository (aur)

And also for archlinux there is an aur package:

Note: chdig-latest-bin is recommended because it is latest available version and you don't need toolchain to compile

scoop (windows)

scoop bucket add extras
scoop install extras/chdig

brew (macos)

brew install chdig

Demo

asciicast

Motivation

The idea is came from everyday digging into various ClickHouse issues.

ClickHouse has a approximately universe of introspection tools, and it is easy to forget some of them. At first I came with some slides and a picture (to attract your attention) by analogy to what Brendan Gregg did for Linux:

Know Your ClickHouse

Note, the picture and the presentation had been made in the beginning of 2022, so it may not include some new introspection tools.

But this requires you to dig into lots of places, and even though during this process you will learn a lot, it does not solves the problem of forgetfulness. So I came up with this simple TUI interface that tries to make this process simpler.

chdig can be used not only to debug some problems, but also just as a regular introspection, like top for Linux.

Features

  • top like interface (or csysdig to be more precise)
  • Flamegraphs (CPU/Real/Memory/Live)
  • Cluster support (--cluster) - aggregate data from all hosts in the cluster
  • Historical support (--history) - includes rotated system.*_log_* tables
  • clickhouse-client compatibility (including --connection) for options and configuration files

And there is a huge bunch of ideas.

Note, this it is in a pre-alpha stage, so everything can be changed (keyboard shortcuts, views, color schema and of course features)

Requirements

If something does not work, like you have too old version of ClickHouse, consider upgrading.

Note: the oldest version that had been tested was 21.2 (at some point in time)

Build from sources

cargo build

Note

If you see an error like failed to authenticate when downloading repository: git@github.com:azat-rust/cursive, it is likely because your local Git config is rewriting https://github.com/ to git@github.com::

[url "git@github.com:"]
    insteadOf = https://github.com/

Cargo’s built-in Git library does not handle this case gracefully. You can either remove that config entry or tell Cargo to use the system Git client instead:

# ~/.cargo/config.toml
[net]
git-fetch-with-cli = true

Third party libraries

Third party services

References

About

Dig into ClickHouse with TUI interface.

Topics

Resources

License

Stars

Watchers

Forks

Contributors 8