website/docs/getting-started/installation.md
Get Hermes Agent up and running in under two minutes!
To easily install the command-line and desktop applications, download the Hermes Desktop installer from our website and run it.
For a command-line only install without Hermes Desktop, run:
curl -fsSL https://hermes-agent.nousresearch.com/install.sh | bash
Run in powershell:
iex (irm https://hermes-agent.nousresearch.com/install.ps1)
If you want to install & run Hermes Desktop after a command-line only install, simply run
hermes desktop
The installer handles everything automatically — all dependencies (Python, Node.js, ripgrep, ffmpeg), the repo clone, virtual environment, global hermes command setup, and LLM provider configuration. By the end, you're ready to chat.
Where the installer puts things depends on whether you're installing as a normal user or as root:
| Installer | Code lives at | hermes binary | Data directory |
|---|---|---|---|
| pip install | Python site-packages | ~/.local/bin/hermes (console_scripts) | ~/.hermes/ |
| Per-user (git installer) | ~/.hermes/hermes-agent/ | ~/.local/bin/hermes (symlink) | ~/.hermes/ |
Root-mode (sudo curl … | sudo bash) | /usr/local/lib/hermes-agent/ | /usr/local/bin/hermes | /root/.hermes/ (or $HERMES_HOME) |
The root-mode FHS layout (/usr/local/lib/…, /usr/local/bin/hermes) matches where other system-wide developer tools land on Linux. It's useful for shared-machine deployments where one system install should serve every user. Per-user config (auth, skills, sessions) still lives under each user's ~/.hermes/ or explicit HERMES_HOME.
Reload your shell and start chatting:
source ~/.bashrc # or: source ~/.zshrc
hermes # Start chatting!
To reconfigure individual settings later, use the dedicated commands:
hermes model # Choose your LLM provider and model
hermes tools # Configure which tools are enabled
hermes gateway setup # Set up messaging platforms
hermes config set # Set individual config values
hermes setup # Or run the full setup wizard to configure everything at once
:::tip Fastest path: Nous Portal One subscription covers 300+ models plus the Tool Gateway (web search, image generation, TTS, cloud browser). Skip the per-tool key juggling:
hermes setup --portal
That logs you in, sets Nous as your provider, and turns on the Tool Gateway in one command. :::
Installer: On non-Windows platforms, the only prerequisite is Git. The installer automatically handles everything else:
:::info
You do not need to install Python, Node.js, ripgrep, or ffmpeg manually. The installer detects what's missing and installs it for you. Just make sure git is available (git --version).
:::
:::tip Nix users If you use Nix (on NixOS, macOS, or Linux), there's a dedicated setup path with a Nix flake, declarative NixOS module, and optional container mode. See the Nix & NixOS Setup guide. :::
If you want to clone the repo and install from source — for contributing, running from a specific branch, or having full control over the virtual environment — see the Development Setup section in the Contributing guide.
Running Hermes as a dedicated unprivileged user (e.g. a hermes systemd service account, or any user without sudo access) is supported. The only thing on the install path that genuinely needs root is Playwright's --with-deps step, which apt-installs shared libraries (libnss3, libxkbcommon, etc.) used by Chromium. The installer detects whether sudo is available and gracefully degrades when it isn't — it will install the Chromium binary into the service user's own Playwright cache and print the exact command an administrator needs to run separately.
Recommended split (Debian/Ubuntu):
One time, as an admin user with sudo, install the system libraries Chromium needs:
sudo npx playwright install-deps chromium
(You can run this from anywhere — npx will fetch Playwright on the fly.)
As the unprivileged service user, run the regular installer. It will detect the missing sudo, skip --with-deps, and install Chromium into the user's local Playwright cache:
curl -fsSL https://hermes-agent.nousresearch.com/install.sh | bash
If you want to skip the Playwright step entirely — for example because you're running headless and don't need browser automation — pass --skip-browser:
curl -fsSL https://hermes-agent.nousresearch.com/install.sh | bash -s -- --skip-browser
Make hermes available to the service user's shells. The installer writes the launcher to ~/.local/bin/hermes. System service accounts often have a minimal PATH that doesn't include ~/.local/bin. Either add it to the user's environment, or symlink the launcher into a system location:
# Option A — add to the service user's profile
echo 'export PATH="$HOME/.local/bin:$PATH"' >> ~/.bashrc
# Option B — symlink system-wide (run as an admin)
sudo ln -s /home/hermes/.hermes/hermes-agent/venv/bin/hermes /usr/local/bin/hermes
Verify: hermes doctor should now run cleanly. If you get ModuleNotFoundError: No module named 'dotenv', you're invoking the repo source hermes file (~/.hermes/hermes-agent/hermes) with system Python instead of the venv launcher (~/.hermes/hermes-agent/venv/bin/hermes) — fix step 3.
The same pattern works on Arch (the installer uses pacman with the same sudo-detection logic), Fedora/RHEL, and openSUSE — those distros don't support --with-deps at all, so an administrator always installs the system libraries separately. The relevant dnf/zypper commands are printed by the installer.
| Problem | Solution |
|---|---|
hermes: command not found | Reload your shell (source ~/.bashrc) or check PATH |
API key not set | Run hermes model to configure your provider, or hermes config set OPENROUTER_API_KEY your_key |
| Missing config after update | Run hermes config check then hermes config migrate |
For more diagnostics, run hermes doctor — it will tell you exactly what's missing and how to fix it.
Hermes auto-detects whether it was installed via pip, the git installer, Homebrew, or NixOS, and hermes update prints the matching update command for that path. There's no env var to set — the detection is based on the install layout (Python site-packages, ~/.hermes/hermes-agent/, Homebrew prefix, or Nix store path). hermes doctor also surfaces the detected method under its environment summary.