From 147f8f72a2b76f3118d7f28fe316a2c7e49412fe Mon Sep 17 00:00:00 2001 From: Tikitu de Jager Date: Fri, 19 Feb 2016 09:48:43 +0200 Subject: [PATCH 1/2] Simplify instructions for exporting with docker The export workflow reusing the `/consume` volume is complex and error- prone, and not at all necessary if the `docker-compose.yml` file has a volume for `/export` from the beginning. --- docker-compose.yml.example | 6 ++++ docs/migrating.rst | 68 ++++++++++++++------------------------ 2 files changed, 30 insertions(+), 44 deletions(-) diff --git a/docker-compose.yml.example b/docker-compose.yml.example index f8e9b5b93..7e3557aa8 100644 --- a/docker-compose.yml.example +++ b/docker-compose.yml.example @@ -23,6 +23,12 @@ services: # 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 + # Likewise, you can add a local path to mount a directory for + # exporting. This is not strictly needed for paperless to + # function, only if you're exporting your files: uncomment + # it and fill in a local path if you know you're going to + # want to export your documents. + # - /path/to/another/arbitrary/place:/export env_file: docker-compose.env command: ["document_consumer"] diff --git a/docs/migrating.rst b/docs/migrating.rst index 1e03bb3cb..491eeace4 100644 --- a/docs/migrating.rst +++ b/docs/migrating.rst @@ -74,57 +74,37 @@ as JSON is almost as easy: $ docker-compose run --rm webserver dumpdata documents.Tag > /path/to/arbitrary/place/tags.json -Exporting the documents though is a little more involved, since docker-compose -doesn't support mounting additional volumes with the ``run`` command. You have -three general options: +To export the documents you can either use ``docker run`` directly, specifying all +the commandline options by hand, or (more simply) mount a second volume for export. -1. Use the consumption directory if you happen to already have it mounted to a - host directory. +To mount a volume for exports, follow the instructions in the +``docker-compose.yml.example`` file for the ``/export`` volume (making the changes +in your own ``docker-compose.yml`` file, of course). Once you have the +volume mounted, the command to run an export is: - .. code-block:: console +.. code-block:: console - $ # Stop the consumer so that it doesn't consume the exported documents - $ docker-compose stop consumer - $ # Export into the consumption directory - $ docker-compose run --rm consumer document_exporter /consume + $ docker-compose run --rm consumer document_exporter /export -2. Add another volume to ``docker-compose.yml`` for exports and use - ``docker-compose run``: +If you prefer to use ``docker run`` directly, supplying the necessary commandline +options: - .. code-block:: diff +.. code-block:: shell-session - diff --git a/docker-compose.yml b/docker-compose.yml - --- a/docker-compose.yml - +++ b/docker-compose.yml - @@ -17,9 +18,8 @@ services: - volumes: - - paperless-data:/usr/src/paperless/data - - paperless-media:/usr/src/paperless/media - - /consume - + - /path/to/arbitrary/place:/export + $ # Identify your containers + $ docker-compose ps + Name Command State Ports + ------------------------------------------------------------------------- + paperless_consumer_1 /sbin/docker-entrypoint.sh ... Exit 0 + paperless_webserver_1 /sbin/docker-entrypoint.sh ... Exit 0 - .. code-block:: shell-session - - $ docker-compose run --rm consumer document_exporter /export - -3. Use ``docker run`` directly, supplying the necessary commandline options: - - .. code-block:: shell-session - - $ # Identify your containers - $ docker-compose ps - Name Command State Ports - ------------------------------------------------------------------------- - paperless_consumer_1 /sbin/docker-entrypoint.sh ... Exit 0 - paperless_webserver_1 /sbin/docker-entrypoint.sh ... Exit 0 - - $ # Make sure to replace your passphrase and remove or adapt the id mapping - $ docker run --rm \ - --volumes-from paperless_data_1 \ - --volume /path/to/arbitrary/place:/export \ - -e PAPERLESS_PASSPHRASE=YOUR_PASSPHRASE \ - -e USERMAP_UID=1000 -e USERMAP_GID=1000 \ - paperless document_exporter /export + $ # Make sure to replace your passphrase and remove or adapt the id mapping + $ docker run --rm \ + --volumes-from paperless_data_1 \ + --volume /path/to/arbitrary/place:/export \ + -e PAPERLESS_PASSPHRASE=YOUR_PASSPHRASE \ + -e USERMAP_UID=1000 -e USERMAP_GID=1000 \ + paperless document_exporter /export .. _migrating-restoring: From 438b161a25d6d26fd8c5bc0b3aa9d20ea2f6376a Mon Sep 17 00:00:00 2001 From: Tikitu de Jager Date: Fri, 19 Feb 2016 22:51:49 +0200 Subject: [PATCH 2/2] Move `docker-compose.env` to `docker-compose.env.example` & adjust docs This file, like `docker-compose.yml`, should be edited by the user. To avoid merge conflicts when pulling updates, the edited version should not be committed to the repository. --- .gitignore | 1 + ...-compose.env => docker-compose.env.example | 0 docs/setup.rst | 19 +++++++++++++------ 3 files changed, 14 insertions(+), 6 deletions(-) rename docker-compose.env => docker-compose.env.example (100%) diff --git a/.gitignore b/.gitignore index 2c65f8dcd..d4c3fe38e 100644 --- a/.gitignore +++ b/.gitignore @@ -69,6 +69,7 @@ db.sqlite3 virtualenv .vagrant docker-compose.yml +docker-compose.env # Used for development scripts/import-for-development diff --git a/docker-compose.env b/docker-compose.env.example similarity index 100% rename from docker-compose.env rename to docker-compose.env.example diff --git a/docs/setup.rst b/docs/setup.rst index 796de88e6..be8a349d8 100644 --- a/docs/setup.rst +++ b/docs/setup.rst @@ -156,8 +156,15 @@ Docker Method .. _Docker installation guide: https://docs.docker.com/engine/installation/ .. _docker-compose installation guide: https://docs.docker.com/compose/install/ -3. Create a copy of ``docker-compose.yml.example`` as ``docker-compose.yml``. -4. Modify ``docker-compose.env`` and adapt the following environment variables: +3. Create a copy of ``docker-compose.yml.example`` as ``docker-compose.yml`` and + a copy of ``docker-compose.env.example`` as ``docker-compose.env``. You'll be + editing both these files: taking a copy ensures that you can ``git pull`` to + receive updates without risking merge conflicts with your modified versions + of the configuration files. +4. Modify ``docker-compose.yml`` to your preferences, following the instructions + in comments in the file. The only change that is a hard requirement is to + specify where the consumption directory should mount. +5. Modify ``docker-compose.env`` and adapt the following environment variables: ``PAPERLESS_PASSPHRASE`` This is the passphrase Paperless uses to encrypt/decrypt the original @@ -186,9 +193,9 @@ Docker Method and thus the one of the consumption directory. Furthermore, you can change the id of the default user as well using ``USERMAP_UID``. -5. Run ``docker-compose up -d``. This will create and start the necessary +6. Run ``docker-compose up -d``. This will create and start the necessary containers. -6. To be able to login, you will need a super user. To create it, execute the +7. To be able to login, you will need a super user. To create it, execute the following command: .. code-block:: shell-session @@ -197,11 +204,11 @@ Docker Method This will prompt you to set a username (default ``paperless``), an optional e-mail address and finally a password. -7. The default ``docker-compose.yml`` exports the webserver on your local port +8. The default ``docker-compose.yml`` exports the webserver on your local port 8000. If you haven't adapted this, you should now be able to visit your `Paperless webserver`_ at ``http://127.0.0.1:8000``. You can login with the user and password you just created. -8. Add files to consumption directory the way you prefer to. Following are two +9. Add files to consumption directory the way you prefer to. Following are two possible options: 1. Mount the consumption directory to a local host path by modifying your