atuinsh

    atuinsh/atuin

    #227 this week

    ✨ Making your shell magical

    cli
    bash
    fish
    history
    rust
    shell
    Rust
    MIT
    29.6K stars
    836 forks
    29.6K GitHub watchers
    Updated 6/23/2026
    View on GitHub

    Backblaze Generative Media Hackathon

    Build the next generation of AI media apps with Genblaze, stored on Backblaze B2. $10,000 in prizes.

    Enter the hackathon

    Loading star history...

    Use Cases & Benefits

    • Atuin is a Rust-based tool that replaces traditional shell history with an enriched SQLite database for bash, zsh, fish, nushell, and xonsh shells.
    • Key features include encrypted history synchronization across machines, a full-screen search UI, logging of exit codes, durations, and command context.
    • Strengths are strong encryption for privacy, multi-shell support, and advanced search/filter capabilities; limitations may include bash-preexec dependency quirks.
    • With over 25k stars and active maintenance since 2020, Atuin shows strong community adoption and ongoing development.
    • Ideal for developers seeking secure, searchable, and synchronized shell history across multiple devices and sessions.

    About atuin

    Text changing depending on mode. Light: 'So light!' Dark: 'So dark!'

    magical shell history


    English | 简体中文

    Atuin replaces your existing shell history with a SQLite database, and records additional context for your commands. Additionally, it provides optional and fully encrypted synchronisation of your history between machines, via an Atuin server.

    animated

    exit code, duration, time and command shown

    As well as the search UI, it can do things like this:

    # search for all successful `make` commands, recorded after 3pm yesterday
    atuin search --exit 0 --after "yesterday 3pm" make
    

    You may use either the server I host, or host your own! Or just don't use sync at all. As all history sync is encrypted, I couldn't access your data even if I wanted to. And I really don't want to.

    Features

    • rebind ctrl-r and up (configurable) to a full screen history search UI
    • store shell history in a sqlite database
    • back up and sync encrypted shell history
    • the same history across terminals, across sessions, and across machines
    • log exit code, cwd, hostname, session, command duration, etc
    • calculate statistics such as "most used command"
    • old history file is not replaced
    • quick-jump to previous items with Alt-<num>
    • switch filter modes via ctrl-r; search history just from the current session, directory, or globally
    • enter to execute a command, tab to edit

    Documentation

    Supported Shells

    • zsh
    • bash
    • fish
    • nushell
    • xonsh

    Community

    Forum

    Atuin has a community forum, please ask here for help and support: https://forum.atuin.sh/

    Discord

    Atuin also has a community Discord, available here

    Quickstart

    This will sign you up for the Atuin Cloud sync server. Everything is end-to-end encrypted, so your secrets are safe!

    Read more in the docs for an offline setup, self hosted server, and more.

    curl --proto '=https' --tlsv1.2 -LsSf https://setup.atuin.sh | sh
    
    atuin register -u <USERNAME> -e <EMAIL>
    atuin import auto
    atuin sync
    

    Then restart your shell!

    [!NOTE]

    For Bash users: The above sets up bash-preexec for necessary hooks, but bash-preexec has limitations. For details, please see the Bash section of the shell plugin documentation.

    Security

    If you find any security issues, we'd appreciate it if you could alert [email protected]

    Contributors

    Made with contrib.rocks.

    Discover Repositories

    Search across tracked repositories by name or description