# docker-compose file for running paperless from the Docker Hub. # This file contains everything paperless needs to run. # Paperless supports amd64, arm and arm64 hardware. # # All compose files of paperless configure paperless in the following way: # # - Paperless is (re)started on system boot, if it was running before shutdown. # - Docker volumes for storing data are managed by Docker. # - Folders for importing and exporting files are created in the same directory # as this file and mounted to the correct folders inside the container. # - Paperless listens on port 8000. # # SQLite is used as the database. The SQLite file is stored in the data volume. # # To install and update paperless with this file, do the following: # # - Copy this file as 'docker-compose.yml' and the files 'docker-compose.env' # and '.env' into a folder. # - Run 'docker-compose pull'. # - Run 'docker-compose run --rm webserver createsuperuser' to create a user. # - Run 'docker-compose up -d'. # # For more extensive installation and update instructions, refer to the # documentation. version: "3.4" services: pa_broker: image: docker.io/library/redis:7 restart: unless-stopped container_name: pa_redis deploy: resources: limits: cpus: '0.50' memory: 128M volumes: - data_pa_redisdata:/data networks: internal_traffic: ipv4_address: 192.168.4.10 pa_webserver: image: ghcr.io/paperless-ngx/paperless-ngx:2.12.1 restart: unless-stopped container_name: pa_webserver deploy: resources: limits: cpus: '1' memory: 1G depends_on: - pa_broker ports: - "8000:8000" healthcheck: test: ["CMD", "curl", "-fs", "-S", "--max-time", "2", "http://localhost:8000"] interval: 30s timeout: 10s retries: 5 volumes: - data_pa:/usr/src/paperless/data - data_pa_media:/usr/src/paperless/media - ./export:/usr/src/paperless/export - ./consume:/usr/src/paperless/consume networks: internal_traffic: ipv4_address: 192.168.4.15 env_file: .env environment: PAPERLESS_REDIS: redis://pa_broker:6379 PAPERLESS_USE_X_FORWARD_HOST: true PAPERLESS_USE_X_FORWARD_PORT: true PAPERLESS_OCR_USER_ARGS: '{"invalidate_digital_signatures": true}' #PAPERLESS_PROXY_SSL_HEADER: '{"HTTP_X_FORWARDED_PROTO", "https"]' volumes: data_pa: external: true data_pa_media: external: true data_pa_redisdata: external: true networks: internal_traffic: external: true