Files
EOS/docs/develop/install.md
Bobby Noelte 94c4ee2951
Some checks failed
docker-build / platform-excludes (push) Has been cancelled
docker-build / build (push) Has been cancelled
docker-build / merge (push) Has been cancelled
pre-commit / pre-commit (push) Has been cancelled
Run Pytest on Pull Request / test (push) Has been cancelled
feat: improve config backup and update and revert (#737)
Improve the backup of the EOS configuration on configuration migration
from another version. Backup files now get a backup id based on date
and time.

Add the configuration backup listing and the revert to the backup to
the EOS api.

Add revert to backup to the EOSdash admin tab.

Improve documentation about install, update and revert of EOS versions.

Add EOS execution profiling to make commands and to test description in
the development guideline.

Signed-off-by: Bobby Noelte <b0661n0e17e@gmail.com>
2025-11-03 17:40:25 +01:00

5.9 KiB

% SPDX-License-Identifier: Apache-2.0 (install-page)=

Installation Guide

This guide provides different methods to install AkkudoktorEOS:

  • Installation from Source (GitHub)
  • Installation from Release Package (GitHub)
  • Installation with Docker (DockerHub)
  • Installation with Docker (docker-compose)

Choose the method that best suits your needs.

:::{admonition} Tip :class: Note If you need to update instead, see the Update Guideline. For reverting to a previous release see the Revert Guideline. :::

Installation Prerequisites

Before installing, ensure you have the following:

For Source / Release Installation

  • Python 3.10 or higher
  • pip
  • Git (only for source)
  • Tar/Zip (for release package)

For Docker Installation

  • Docker Engine 20.10 or higher
  • Docker Compose (optional, recommended)

Installation from Source (GitHub) (M1)

Recommended for developers or users wanting the latest updates.

1) Clone the Repository (M1)

.. tabs::

  .. tab:: Windows

     .. code-block:: powershell

        git clone https://github.com/Akkudoktor-EOS/EOS.git
        cd EOS

  .. tab:: Linux

     .. code-block:: bash

        git clone https://github.com/Akkudoktor-EOS/EOS.git
        cd EOS

2) Create a Virtual Environment and install dependencies (M1)

.. tabs::

  .. tab:: Windows

     .. code-block:: powershell

        python -m venv .venv
        .venv\Scripts\pip install -r requirements.txt
        .venv\Scripts\pip install -e .

  .. tab:: Linux

     .. code-block:: bash

        python -m venv .venv
        .venv/bin/pip install -r requirements.txt
        .venv/bin/pip install -e .

3) Run EOS (M1)

.. tabs::

  .. tab:: Windows

     .. code-block:: powershell

        .venv\Scripts\python -m akkudoktoreos.server.eos

  .. tab:: Linux

     .. code-block:: bash

        .venv/bin/python -m akkudoktoreos.server.eos

EOS is now available at:

If you want to make EOS and EOSdash accessible from outside of your machine or container at this stage of the installation provide appropriate IP addresses on startup.

.. tabs::

  .. tab:: Windows

     .. code-block:: powershell

        .venv\Scripts\python -m akkudoktoreos.server.eos --host 0.0.0.0 --eosdash-host 0.0.0.0

  .. tab:: Linux

     .. code-block:: bash

        .venv/bin/python -m akkudoktoreos.server.eos --host 0.0.0.0 --eosdash-host 0.0.0.0

4) Configure EOS (M1)

Use EOSdash at http://localhost:8504 to configure EOS.

Installation from Release Package (GitHub) (M2)

This method is recommended for users who want a stable, tested version.

1) Download the Latest Release (M2)

Visit the Releases page and download the latest release package (e.g., akkudoktoreos-v0.1.0.tar.gz or akkudoktoreos-v0.1.0.zip).

2) Extract the Package (M2)

tar -xzf akkudoktoreos-v0.1.0.tar.gz  # For .tar.gz
# or
unzip akkudoktoreos-v0.1.0.zip  # For .zip

cd akkudoktoreos-v0.1.0

3) Create a virtual environment and run and configure EOS (M2)

Follow Step 2), 3) and 4) of method M1. Start at 2) Create a Virtual Environment and install dependencies

4) Update the source code (M2)

To extract a new release to a new directory just proceed with method M2 step 1) for the new release.

You may remove the old release directory afterwards.

Installation with Docker (DockerHub) (M3)

This method is recommended for easy deployment and containerized environments.

1) Pull the Docker Image (M3)

docker pull akkudoktor/eos:latest

For a specific version:

docker pull akkudoktor/eos:v<version>

2) Run the Container (M3)

Basic run:

docker run -d \
  --name akkudoktoreos \
  -p 8503:8503 \
  -p 8504:8504 \
  -e OPENBLAS_NUM_THREADS=1 \
  -e OMP_NUM_THREADS=1 \
  -e MKL_NUM_THREADS=1 \
  -e EOS_SERVER__HOST=0.0.0.0 \
  -e EOS_SERVER__PORT=8503 \
  -e EOS_SERVER__EOSDASH_HOST=0.0.0.0 \
  -e EOS_SERVER__EOSDASH_PORT=8504 \
  --ulimit nproc=65535:65535 \
  --ulimit nofile=65535:65535 \
  --security-opt seccomp=unconfined \
  akkudoktor/eos:latest

3) Verify the Container is Running (M3)

docker ps
docker logs akkudoktoreos

EOS should now be accessible at http://localhost:8503/docs and EOSdash should be available at http://localhost:8504.

4) Configure EOS (M3)

Use EOSdash at http://localhost:8504 to configure EOS.

Installation with Docker (docker-compose) (M4)

1) Get the akkudoktoreos source code (M4)

You may use either method M1 or method M2 to get the source code.

2) Build and run the container (M4)

.. tabs::

  .. tab:: Windows

     .. code-block:: powershell

        docker compose up --build

  .. tab:: Linux

     .. code-block:: bash

        docker compose up --build

3) Verify the Container is Running (M4)

docker ps
docker logs akkudoktoreos

EOS should now be accessible at http://localhost:8503/docs and EOSdash should be available at http://localhost:8504.

4) Configure EOS

Use EOSdash at http://localhost:8504 to configure EOS.

Helpful Docker Commands

View logs:

docker logs -f akkudoktoreos

Stop the container:

docker stop akkudoktoreos

Start the container:

docker start akkudoktoreos

Remove the container:

docker rm -f akkudoktoreos

Update to latest version:

docker pull Akkudoktor-EOS/EOS:latest
docker stop akkudoktoreos
docker rm akkudoktoreos
# Then run the container again with the run command