--- title: Setup Introduction --- ## Introduction InvenTree can be self-hosted with minimal system requirements. Multiple database back-ends are supported, allowing for flexibility where required. The InvenTree server ecosystem consists of the following components: ### Database A persistent database is required to store stock information. The database backend must be installed and configured separately to the InvenTree application. InvenTree can be used with any of the following database backends: * SQLite * PostgreSQL * MariaDB * MySQL Database selection should be determined by your particular installation requirements. ### Media Files Uploaded media files (images, attachments, reports, etc) are stored to a persistent storage volume. ### Web Server The bulk of the InvenTree code base supports the custom web server application. The web server application services user requests and facilitates database access. The webserver code also provides a first-party API for performing database query actions. Once a database is setup, you need a way of accessing the data. InvenTree provides a "server" application out of the box, but this may not scale particularly well with multiple users. Instead, InvenTree can be served using a webserver such as [Gunicorn](https://gunicorn.org/). For more information see the [deployment documentation](./production.md). ### Background Tasks A separate application handles management of [background tasks](../admin/tasks.md), separate to user-facing web requests. ## OS Requirements The InvenTree documentation assumes that the operating system is a debian based Linux OS. Some installation steps may differ for different systems. !!! warning "Installing on Windows" Installation on Windows is *not guaranteed* to work (at all). To install on a Windows system, it is highly recommended that you [install WSL](https://docs.microsoft.com/en-us/windows/wsl/install-win10#manual-installation-steps), and then follow installation procedure from within the WSL environment. ## Python Requirements InvenTree runs on [Python](https://python.org). !!! warning "Python Version" InvenTree requrires Python 3.7 (or newer). If your system has an older version of Python installed, you will need to follow the update instructions for your OS. ### Invoke InvenTree makes use of the [invoke](https://www.pyinvoke.org/) python toolkit for performing various administrative actions. !!! warning "Invoke Version" InvenTree requires invoke version 1.4.0 or newer. Some platforms may be shipped with older versions of invoke! To display a list of the available InvenTree administration actions, run the following commands from the top level source directory: ``` inv --list ``` ### Virtual Environment Installing the required Python packages inside a virtual environment allows a local install separate to the system-wide Python installation. While not strictly necessary, using a virtual environment is **highly recommended** as it prevents conflicts between the different Python installations. You can read more about Python virtual environments [here](https://docs.python.org/3/tutorial/venv.html). !!! info "Virtual Environment" The installation intstruction assume that a virtual environment is configured `cd` into the InvenTree directory, and create a virtual environment with the following command: ``` python3 -m venv env ``` ### Activating a Virtual Environment The virtual environment needs to be activated to ensure the correct python binaries and libraries are used. The InvenTree instructions assume that the virtual environment is always correctly activated. To configure Inventree inside a virtual environment, ``cd`` into the inventree base directory and run the following command: ``` source env/bin/activate ``` !!! info "Activate Virtual Environment" if ``` source env/bin/activate ``` is not working try ``` . env/bin/activate ``` This will place the current shell session inside a virtual environment - the terminal should display the ``(env)`` prefix. ## Downloading Source Code InvenTree source code is distributed on [GitHub](https://github.com/inventree/inventree/), and the latest version can be downloaded (using Git) with the following command: ``` git clone https://github.com/inventree/inventree/ ``` Alternatively, the source can be downloaded as a [.zip archive](https://github.com/inventree/InvenTree/archive/master.zip). !!! info "Updating via Git" Downloading the source code using Git is recommended, as it allows for simple updates when a new version of InvenTree is released. ## Installation Guides There are multiple ways to get an InvenTree server up and running, of various complexity (and robustness)! ### Docker The recommended method of installing InvenTree is to use [docker](https://www.docker.com). InvenTree provides out-of-the-box support for docker and docker-compose, which provides a simple, reliable and repeatable pipeline for integration into your production environment. Refer to the [docker setup instructions](./docker.md) for further information. ### Bare Metal If you do not wish to use the docker container, you will need to manually install the required packages and follow through the installation guide. Refer to the [InvenTree installation instructions](../install) for more details.