# Install ArchiveBox is primarily distributed as a Python package via `pip`, but it also depends on some system packages that can be installed manually or automatically with Docker. It usually takes less than ~10min to get ArchiveBox set up and running. - *[Supported Systems](#supported-systems)* - Install Instructions - **[Option A. Docker / Docker Compose ⭐️](#option-a-docker--docker-compose-setup-%EF%B8%8F)** - [Option B. Automatic Setup Script](#option-b-automatic-setup-script) - [Option C. System Package Manager Setup](#option-c-bare-metal-setup) - *[Upgrading ArchiveBox to a new version](#upgrading-archivebox-to-a-new-version)* - *[Next Steps](#next-steps)* ## Supported Systems **CPU Architectures:** `amd64` (`x86_64`), `arm64` (`aarch64`), `arm7` *(Including 64-bit Intel/AMD, M1/M2/etc. Macs, Raspberry Pi >= 3)* * [**macOS:**](#macos) >=10.12 (with `pip`) * [**Linux:**](#ubuntudebian) Ubuntu (>= 18.04), Debian (>= 10), etc. (with `apt`) * [**BSD:**](#bsd) FreeBSD, OpenBSD, NetBSD etc (with `pkg`) Other systems are not officially supported but may work with degraded functionality: * **Windows:** Via [[Docker]], Docker in WSL2, or WSL2 without Docker (not recommended) * [Other UNIX systems:](https://github.com/ArchiveBox/ArchiveBox#-package-manager-setup) Arch, Nix, Guix, Fedora, SUSE, Arch, CentOS, etc. Note: On `arm7` the `playwright` package is not available, so `chromium` must be installed manually if needed.
You will also need at least 500MB of RAM (bare minimum), 2GB or greater is recommended. You may be able to reduce the RAM requirements if you disable all the chrome-based archiving methods with [`CHROME_ENABLED=False`](https://archivebox.github.io/abx-plugins/#chrome) (or its `USE_CHROME` alias). It's also recommended to use a filesystem with compression and/or [deduplication](https://www.ixsystems.com/blog/ixsystems-and-klara-systems-celebrate-valentines-day-with-a-heartfelt-donation-of-fast-dedupe-to-openzfs-and-truenas/) (e.g. [ZFS](https://openzfs.github.io/openzfs-docs/Getting%20Started/index.html) or BTRFS) for maximum efficiency.
---
## Option A. Docker / Docker Compose Setup ⭐️ *Docker Compose is the recommended way to get ArchiveBox, as it includes all the extras out-of-the-box and provides the best security and upgrade UX.* 1. If you don't already have docker installed, follow the official instructions to get Docker on Linux, macOS, or Windows: https://docs.docker.com/install/#supported-platforms ➡️ 2. Then follow the [Quickstart](https://github.com/ArchiveBox/ArchiveBox#quickstart) guide and read the [[Docker]] wiki page for next steps. ➡️ > You can also run Dockerized ArchiveBox using [UNRAID/TrueNAS/Proxmox/etc.](https://github.com/ArchiveBox/ArchiveBox#-other-options) or [Kubernetes](https://github.com/ArchiveBox/docker-archivebox/blob/master/archivebox.yml). **More info:** - [`Dockerfile`](https://github.com/ArchiveBox/ArchiveBox/blob/dev/Dockerfile) - [`docker-compose.yml`](https://github.com/ArchiveBox/ArchiveBox/blob/dev/docker-compose.yml) - [`archivebox-kubernetes.yml`](https://github.com/ArchiveBox/docker-archivebox/blob/master/archivebox.yml) - [ArchiveBox Docker Quickstart](https://github.com/ArchiveBox/ArchiveBox#quickstart) + [Usage](https://github.com/ArchiveBox/ArchiveBox/wiki/Docker) + [Configuration](https://github.com/ArchiveBox/ArchiveBox/wiki/Docker#configuration) + [Upgrading](https://github.com/ArchiveBox/ArchiveBox/wiki/Upgrading-or-Merging-Archives) documentation
---
## Option B. Automatic Setup Script If you're on Linux with `apt` or FreeBSD with `pkg` there is an optional auto-setup script provided. *(or scroll further down for manual install instructions)* ```bash curl -fsSL 'https://get.archivebox.io' | bash # shortcut to run https://raw.githubusercontent.com/ArchiveBox/ArchiveBox/stable/bin/setup.sh ``` The script explains what it installs beforehand, and will prompt for user confirmation before making any changes to your system. The script uses Docker if already installed, but you can decline and it will attempt to auto-install everything using `apt`/`brew`/`pkg` + `pip` instead. After running the setup script, continue with the [Quickstart](https://github.com/ArchiveBox/ArchiveBox#%EF%B8%8F-next-steps) guide... ➡️ > *See here for our thoughts on the [inherent limitations of `curl | sh`](https://docs.monadical.com/s/against-curl-sh) as an install method...*
---
## Option C. Bare Metal Setup If you'd rather not use [Docker](https://github.com/ArchiveBox/ArchiveBox#%EF%B8%8F-easy-setup) or our [auto-install script](https://github.com/ArchiveBox/ArchiveBox#%EF%B8%8F-easy-setup), you can follow these manual setup instructions to install ArchiveBox and its dependencies using `pip` & your system package manager of choice (e.g. `apt`, `brew`, `pkg`, `nix`, etc.). See our [Dependencies](https://github.com/ArchiveBox/ArchiveBox#dependencies) documentation to see the full list of dependencies and how they're used. Not all the dependencies are required for all modes. If you disable some archive methods you can skip installing those dependencies — for example, if you set [`MEDIA_ENABLED=False`](https://archivebox.github.io/abx-plugins/#media) you don't need to install `yt-dlp`, and if you set [`PDF_ENABLED=False`](https://archivebox.github.io/abx-plugins/#pdf), [`SCREENSHOT_ENABLED=False`](https://archivebox.github.io/abx-plugins/#screenshot), and [`DOM_ENABLED=False`](https://archivebox.github.io/abx-plugins/#dom) you don't need `chromium`. **More info:** - For help installing these, see the [Manual Setup](#manual-setup), [[Troubleshooting]] and [[Chromium Install]] pages. - For per-plugin binary and enable/disable options (CHROME_BINARY, RIPGREP_BINARY, `_ENABLED`, etc.) see the [abx-plugins config reference](https://archivebox.github.io/abx-plugins/).
### 1. Install base system dependencies needed for your OS *Be aware, you'll need to keep all these packages up-to-date yourself over time!* #### macOS Make sure you have [Homebrew](https://brew.sh/) installed first. ```bash # Install ArchiveBox's dependencies manually (instead of using the all-in-one brew package) brew install python3 node git wget curl ffmpeg yt-dlp ripgrep sonic pip install archivebox archivebox install # Optional: get FFMPEG with the AAC addon # brew tap homebrew-ffmpeg/ffmpeg # brew uninstall ffmpeg; brew install homebrew-ffmpeg/ffmpeg/ffmpeg --with-fdk-aac # Optional: get Chromium with brew (not needed if you already have /Applications/{Google Chrome,Chromium}.app) # brew install --cask chromium ``` #### Ubuntu/Debian-based Systems Use the third-party ArchiveBox apt repo for the simplest bare-metal install: ```bash echo 'deb [trusted=yes] https://archivebox.github.io/debian-archivebox dev main' | sudo tee /etc/apt/sources.list.d/archivebox.list sudo apt update sudo apt install archivebox mkdir -p ~/archivebox/data && cd ~/archivebox/data archivebox init sudo archivebox install archivebox add 'https://example.com' ``` The apt package installs the ArchiveBox Python application. Runtime extractor dependencies such as Chromium, yt-dlp, SingleFile, and other plugin-managed tools are installed by `sudo archivebox install`. #### FreeBSD ```bash sudo pkg install python git wget curl youtube_dl ripgrep py311-pip py311-sqlite3 npm ffmpeg sudo pkg install chromium # or for older versions: # sudo pkg install python node wget curl git yt-dlp ffmpeg ripgrep chromium-browser ``` #### OpenBSD ```bash sudo pkg_add python3 node wget git curl yt-dlp ffmpeg ripgrep chromium ``` #### Arch Linux / Nix / Guix / etc. Other OSs See the [Quickstart](https://github.com/ArchiveBox/ArchiveBox#-package-manager-setup) instructions for other operating systems and release channels. ➡️
### 2. Install the Python dependencies using `pip` If you are not using the apt package above, install ArchiveBox with `pip`. ```bash # get the latest version of archivebox from PyPI pip install --upgrade --ignore-installed archivebox[ldap,sonic] # if you see errors about ldap, install the C++ build tools + ldap headers and retry (only needed on some OSs + if you want ldap) # apt install build-essensial python3-ldap ```
### 3. Install runtime dependencies using `archivebox install` Finish installing runtime dependencies for the enabled ArchiveBox plugins. ```bash # create a new empty folder anywhere to hold your collection, and cd into it mkdir -p ~/archivebox/data && cd ~/archivebox/data # instantiate the directory as an archivebox collection dir archivebox init # auto-install runtime dependencies such as Chromium, yt-dlp, SingleFile, etc. sudo archivebox install # archive a first URL archivebox add 'https://example.com' # ✅ see a final detailed breakdown of all the installed dependencies and commands available archivebox version archivebox help ```
### Troubleshooting Make sure the `pip`-installed version of `archivebox` is available in your `$PATH`. ```bash pip show archivebox # show info about the pip-installed version of archivebox echo $PATH # show the directories your system is searching for binaries which -a archivebox # show all installed archivebox binaries available which archivebox # show which archivebox binary is being called cd ~/archivebox/data archivebox version # ⭐️ show lots of useful info about installed dependencies and more archivebox status archivebox help ``` (ensure the version shown is the most recent available from [Releases](https://github.com/ArchiveBox/ArchiveBox/releases)) Make sure to run `archivebox` **as an unprivileged user** (i.e. without `sudo` / not logged in as `root`). Make sure to run all commands, including `archivebox version`, `archivebox help`, etc. **inside a data directory** (or a new empty dir that will become a data dir). If you have issues getting Chromium / Google Chrome or other dependencies working with ArchiveBox, see the [[Chromium Install]] and [[Troubleshooting]] pages for more detailed instructions.
### Next Steps: Add some URLs to archive and try out CLI / Web UI For guides on how to import URLs from different sources into ArchiveBox, check out [Input Formats](https://github.com/ArchiveBox/ArchiveBox#input-formats) and [Preparing URLs](https://github.com/ArchiveBox/ArchiveBox/wiki/Quickstart#2-get-your-list-of-urls-to-archive). ➡️ ```bash cd ~/archivebox/data ``` ```bash # feed in your URLs to start archiving! archivebox add --help archivebox add < ~/Downloads/bookmarks_export.html ``` ```bash # inspect the newly added Snapshots via the CLI archivebox list archivebox status ``` ```bash # OR start the webserver and view them in the Web UI archivebox server 0.0.0.0:8000 open http://localhost:8000 ``` See our [[Usage]] Wiki documentation page for more examples.
### Next Steps: *Upgrading Archivebox to a new version* Make sure all apt/brew/pkg/etc. dependencies from above are installed & up-to-date first. ```bash # get the latest archivebox version from PyPI pip install --upgrade --ignore-installed archivebox # run init inside any data directories to migrate the index to the latest version cd ~/archivebox/data archivebox init # update collection index & apply any migrations sudo archivebox install # update runtime dependencies to latest versions ``` Check our more detailed [Upgrading](https://github.com/ArchiveBox/ArchiveBox/wiki/Upgrading-or-Merging-Archives) documentation and [Release Notes](https://github.com/ArchiveBox/ArchiveBox/releases) if you run into any problems. ➡️
---
### Further Reading - Read [[Usage]] to learn how to use the ArchiveBox CLI and HTML output - Read [[Configuration]] to learn about the various archive method options - Read [[Scheduled Archiving]] to learn how to set up automatic daily archiving - Read [[Publishing Your Archive]] if you want to host your archive for others to access online - Read [[Troubleshooting]] if you encounter any problems