SkillAgentSearch skills...

Lazyjournal

TUI for viewing logs from journald, auditd, file system, Docker and Podman containers, Compose stacks and Kubernetes pods with support for log highlighting and several filtering modes.

Install / Use

/learn @Lifailon/Lazyjournal

README

<p align="center"> <img src="/img/logo.png"> </p> <p align="center"> <a href="https://github.com/Lifailon/lazyjournal/releases"><img title="GitHub Download" src="https://img.shields.io/github/downloads/lifailon/lazyjournal/total?logo=github&color=green&label=Downloads"></a> <a href="https://launchpad.net/~lifailon/+archive/ubuntu/lazyjournal"><img title="Ubuntu Launchpad PPA" src="https://img.shields.io/badge/dynamic/json?url=https%3A%2F%2Fapi.launchpad.net%2F1.0%2F~lifailon%2F%2Barchive%2Fubuntu%2Flazyjournal%3Fws.op%3DgetPublishedSources%26distro_series%3Dhttps%3A%2F%2Fapi.launchpad.net%2F1.0%2Fubuntu%2Fjammy%26status%3DPublished&query=entries[0].source_package_version&label=Ubuntu+PPA&logo=ubuntu&color=orange"></a> <a href="https://formulae.brew.sh/formula/lazyjournal"><img title="Homebrew" src="https://img.shields.io/homebrew/v/lazyjournal?logo=homebrew&color=yellow&label=Homebrew"></a> <a href="https://anaconda.org/conda-forge/lazyjournal"><img title="Conda Forge" src="https://img.shields.io/conda/vn/conda-forge/lazyjournal?logo=anaconda&color=green&label=Conda"></a> <a href="https://aur.archlinux.org/packages/lazyjournal"><img title="Arch Linux" src="https://img.shields.io/aur/version/lazyjournal?logo=arch-linux&color=blue&label=AUR"></a> <a href="https://hub.docker.com/r/lifailon/lazyjournal"><img title="Docker Hub" src="https://img.shields.io/docker/image-size/lifailon/lazyjournal/latest?logo=docker&color=blue&label=Docker+Hub"></a> <br> <a href="https://github.com/Lifailon/lazyjournal/actions/workflows/build.yml"><img title="Actions Build"src="https://github.com/Lifailon/lazyjournal/actions/workflows/build.yml/badge.svg"></a> <a href="https://github.com/Lifailon/lazyjournal/wiki"><img title="Go coverage report"src="https://raw.githubusercontent.com/wiki/Lifailon/lazyjournal/coverage.svg"></a> <a href="https://goreportcard.com/report/github.com/Lifailon/lazyjournal"><img src="https://goreportcard.com/badge/github.com/Lifailon/lazyjournal" alt="Go Report"></a> <a href="https://app.fossa.com/projects/git%2Bgithub.com%2FLifailon%2Flazyjournal?ref=badge_shield&issueType=security" alt="FOSSA Status"><img src="https://app.fossa.com/api/projects/git%2Bgithub.com%2FLifailon%2Flazyjournal.svg?type=shield&issueType=security"/></a> <br> <a href="https://github.com/avelino/awesome-go?tab=readme-ov-file#logging"><img src="https://awesome.re/mentioned-badge.svg" alt="Mentioned in Awesome Go"></a> <a href="https://pkg.go.dev/github.com/Lifailon/lazyjournal"><img src="https://pkg.go.dev/badge/github.com/Lifailon/lazyjournal.svg" alt="Go Reference"></a> <a href="https://deepwiki.com/Lifailon/lazyjournal"><img src="https://deepwiki.com/badge.svg" alt="Ask DeepWiki"></a> </p>

Terminal user interface for viewing logs from journald, auditd, file system, Docker and Podman containers, Compose stacks and Kubernetes pods with support for log highlighting and several filtering modes. Written in Go with the awesome-gocui (fork gocui) library.

This tool is inspired by and made with love for LazyDocker and LazyGit. It is also included in Awesome-Go, Awesome-TUIs and Awesome-Docker, check out other useful projects on the repository pages.

[!NOTE] You can try it out on the Killercoda playground.

Regex filtering

Features

  • Simple installation, to run download one executable file without dependencies and settings.
  • It is possible to launch the interface in a Web browser when running in a Docker container.
  • Centralized search for the required journal by filtering all lists (log sources).
  • Streaming output of new events from the selected journal (like tail).
  • List of all services (including disabled unit files) with current state from systemd to access their logs.
  • View all system and user journals via journalctl (tool for reading logs from journald).
  • List of all system boots for kernel log output.
  • List of audit rules from auditd for filtering by keys and viewing in interpret format.
  • File system logs such as for Apache or Nginx, as well as syslog, messages, etc. from /var/log.
  • Lists all log files in users' home directories, as well as descriptor log files used by processes.
  • Reading archive logs truncated during rotation (gz, xz and bz2 formats) and Packet Capture (pcap format).
  • Apple System Logs support (asl format).
  • Windows Event Logs via PowerShell and wevtutil, as well as application logs from Windows file system.
  • Docker and Swarm logs from the file system or stream, including built-in timestamps and filtering by stream.
  • Logs of all containers in Docker Compose stacks, sorted by time for all entries.
  • Podman logs, without the need to run a background process (socket).
  • Kubernetes pods logs (you must first configure the cluster connection in kubeconfig).
  • Logs of k3s pods and containers from the file system on any nodes (including workers).
  • Search and analyze all logs from remote hosts in one interface using rsyslog configuration.
  • Access to logs on remote systems via the ssh protocol.
  • Supports context and namespace switching interface for Docker and Kubernetes.

Filtering

Supports 4 filtering modes:

  • Default - case sensitive exact search.
  • Fuzzy (like fzf) - custom inexact case-insensitive search (searches for all phrases separated by a space anywhere on a line).
  • Regex (like grep) - search with regular expression support, based on the built-in regexp library, case-insensitive by default (in case a regular expression syntax error occurs, the input field will be highlighted in red).
  • Date - filtering by date (since and/or until) for journald logs, as well as Docker or Podman containers (only supported in streaming mode) using the left and right arrow keys. This mode can be used in combination with other filtering modes and can improve loading performance for large logs. Changing the UTC offset is supported using the -T/--timezone-filter flag or the timezoneFilter configuration parameter (default: +00:00).

Highlighting

Several log output coloring modes are supported:

  • default - built-in log highlighter by default, requires no dependencies and is several times faster than other tools (including in command-line mode).
  • tailspin - uses tailspin.
  • bat - uses bat in ansi mode and log language (much slower than other modes).

When using external tools, they are required to be already installed on your system. You can also disable output highlighting with the Ctrl+Q keyboard shortcut, this is useful for improving performance when viewing large logs or if your terminal already has a built-in highlighting feature, such as WindTerm.

The built-in highlighting by default supports several color groups:

  • Custom - URLs, HTTP request methods and response status codes, double quotes and braces for json, file paths and processes in UNIX.
  • Yellow - warnings and known names (host name and system users).
  • Green - keywords indicating success.
  • Red - keywords indicating error.
  • Blue - statuses and actions (restart, update, etc).
  • Light blue - numbers (date, time, timestamp, bytes, versions, percentage, integers, IP and MAC addresses).

A full list of all keywords can be found in the color.log file (used for testing only).

[!IMPORTANT] If you have suggestions for improving log highlighting (e.g. adding new keywords), you can open an issue for a new feature.

Install

Binaries are available for download on the GitHub releases page.

Unix-based

Run the command in the console to quickly install or update the stable version for Linux, macOS or the BSD-based system:

curl -sSL https://raw.githubusercontent.com/Lifailon/lazyjournal/main/scripts/install.sh | bash

This command will run a script that will download the latest binary (auto-detect OS and arch) from the GitHub repository to your home directory along with other executables (default path is ~/.local/bin/lazyjournal) and configurations (~/.config/lazyjournal/config.yml) for the current user, and also grant execute permission.

apt (Ubuntu / Debian)

To install and remove packages on an Ubuntu system, you can use the apt package manager from the PPA repository:

sudo add-apt-repository -y ppa:lifailon/lazyjournal
sudo apt update
sudo apt install -y lazyjournal

Or download the deb package from the GitHub releases page for installation on any Debian-based system.

curl -sSL https://github.com/Lifailon/lazyjournal/releases/download/0.8.6/lazyjournal-0.8.6-$(dpkg --print-architecture).deb -o /tmp/lazyjournal.deb
sudo apt install -y /tmp/lazyjournal.deb && rm /tmp/lazyjournal.deb

Homebrew (macOS / Linux)

Use the following command to install lazyjournal using Homebrew:

brew install lazyjournal

Conda / Mamba / Pixi (Linux / macOS / Windows)

If you use package managers like conda or mamba, you can install lazyjournal from [co

View on GitHub
GitHub Stars1.2k
CategoryCustomer
Updated3h ago
Forks29

Languages

Go

Security Score

100/100

Audited on Mar 22, 2026

No findings