mirror of
https://github.com/paperless-ngx/paperless-ngx.git
synced 2025-04-02 13:45:10 -05:00

This commit adds a `Dockerfile` to the root of the project, accompanied by a `docker-compose.yml.example` for simplified deployment. The `Dockerfile` is agnostic to whether it will be the webserver, the consumer, or if it is run for a one-off command (i.e. creation of a superuser, migration of the database, document export, ...). The containers entrypoint is the `scripts/docker-entrypoint.sh` script. This script verifies that the required permissions are set, remaps the default users and/or groups id if required and installs additional languages if the user wishes to. After initialization, it analyzes the command the user supplied: - If the command starts with a slash, it is expected that the user wants to execute a binary file and the command will be executed without further intervention. (Using `exec` to effectively replace the started shell-script and not have any reaping-issues.) - If the command does not start with a slash, the command will be passed directly to the `manage.py` script without further modification. (Again using `exec`.) The default command is set to `--help`. If the user wants to execute a command that is not meant for `manage.py` but doesn't start with a slash, the Docker `--entrypoint` parameter can be used to circumvent the mechanics of `docker-entrypoint.sh`. Further information can be found in `docs/setup.rst` and in `docs/migrating.rst`. For additional convenience, a `Dockerfile` has been added to the `docs/` directory which allows for easy building and serving of the documentation. This is documented in `docs/requirements.rst`.
32 lines
981 B
Plaintext
32 lines
981 B
Plaintext
version: '2'
|
|
|
|
services:
|
|
webserver:
|
|
image: paperless
|
|
ports:
|
|
# You can adapt the port you want Paperless to listen on by
|
|
# modifying the part before the `:`.
|
|
- "8000:8000"
|
|
volumes:
|
|
- paperless-data:/usr/src/paperless/data
|
|
- paperless-media:/usr/src/paperless/media
|
|
env_file: docker-compose.env
|
|
environment:
|
|
- PAPERLESS_OCR_LANGUAGES=
|
|
command: ["runserver", "0.0.0.0:8000"]
|
|
|
|
consumer:
|
|
image: paperless
|
|
volumes:
|
|
- paperless-data:/usr/src/paperless/data
|
|
- paperless-media:/usr/src/paperless/media
|
|
# You have to adapt the local path you want the consumption
|
|
# directory to mount to by modifying the part before the ':'.
|
|
- /path/to/arbitrary/place:/consume
|
|
env_file: docker-compose.env
|
|
command: ["document_consumer"]
|
|
|
|
volumes:
|
|
paperless-data:
|
|
paperless-media:
|