Rustlog is a Twitch logging service based on justlog. It provides the same web UI and API, but it utilizes Clickhouse for storage instead of text files.
Create a config.json
file (see CONFIG.md)
version: "3.8"
services:
clickhouse:
image: clickhouse/clickhouse-server:latest
container_name: clickhouse
volumes:
- "./ch-data:/var/lib/clickhouse:rw"
environment:
CLICKHOUSE_DB: "rustlog"
restart: unless-stopped
rustlog:
image: ghcr.io/boring-nick/rustlog:master
container_name: rustlog
ports:
- 8025:8025
volumes:
- "./config.json:/config.json"
depends_on:
- clickhouse
restart: unless-stopped
- Follow the Contributing excluding the last step
cargo build --release
- The resulting binary will be at
target/release/rustlog
- Significantly better storage efficiency (3x+ improvement) thanks to not duplicating log files, more efficient structure and better compression (using ZSTD in Clickhouse)
- Blazing fast log queries with response streaming and a highly performant IRC parser
- Support for ndjson logs responses
Requirements:
- rust
- yarn
- docker with docker-compose (optional, will need to set up Clickhouse manually without it)
Steps:
- Clone the repository (make sure to include submodules!):
git clone --recursive https://github.com/boring-nick/rustlog
If you already cloned the repo without --recursive
, you can initialize submodules with:
git submodule update --init --recursive
- Set up the database (Clickhouse):
This repository provides a docker-compose to quickly set up Clickhouse. You can use it with:
docker-compose -f docker-compose.dev.yml up -d
Alternatively, you can install Clickhouse manually using the official guide.
- Create a config file
Copy config.dist.json
to config.json
and configure your database and twitch credentials. If you installed Clickhouse with Docker, the default database configuration works.
- Build the frontend:
cd web
yarn install
yarn build
cd ..
- Build and run rustlog:
cargo run
You can now access rustlog at http://localhost:8025.
See MIGRATION.md