mirror of
				https://github.com/paperless-ngx/paperless-ngx.git
				synced 2025-10-26 00:02:35 -04:00 
			
		
		
		
	Merge pull request #50 from tikitu/docker-tweaks
Some small tweaks to the Docker setup and documentation
This commit is contained in:
		
						commit
						5c6aa201be
					
				
							
								
								
									
										1
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										1
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							| @ -69,6 +69,7 @@ db.sqlite3 | |||||||
| virtualenv | virtualenv | ||||||
| .vagrant | .vagrant | ||||||
| docker-compose.yml | docker-compose.yml | ||||||
|  | docker-compose.env | ||||||
| 
 | 
 | ||||||
| # Used for development | # Used for development | ||||||
| scripts/import-for-development | scripts/import-for-development | ||||||
|  | |||||||
| @ -23,6 +23,12 @@ services: | |||||||
|             # You have to adapt the local path you want the consumption |             # You have to adapt the local path you want the consumption | ||||||
|             # directory to mount to by modifying the part before the ':'. |             # directory to mount to by modifying the part before the ':'. | ||||||
|             - /path/to/arbitrary/place:/consume |             - /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 |         env_file: docker-compose.env | ||||||
|         command: ["document_consumer"] |         command: ["document_consumer"] | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -74,57 +74,37 @@ as JSON is almost as easy: | |||||||
| 
 | 
 | ||||||
|     $ docker-compose run --rm webserver dumpdata documents.Tag > /path/to/arbitrary/place/tags.json |     $ 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 | To export the documents you can either use ``docker run`` directly, specifying all | ||||||
| doesn't support mounting additional volumes with the ``run`` command. You have | the commandline options by hand, or (more simply) mount a second volume for export. | ||||||
| three general options: |  | ||||||
| 
 | 
 | ||||||
| 1. Use the consumption directory if you happen to already have it mounted to a | To mount a volume for exports, follow the instructions in the | ||||||
|    host directory. | ``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 run --rm consumer document_exporter /export | ||||||
|        $ docker-compose stop consumer |  | ||||||
|        $ # Export into the consumption directory |  | ||||||
|        $ docker-compose run --rm consumer document_exporter /consume |  | ||||||
| 
 | 
 | ||||||
| 2. Add another volume to ``docker-compose.yml`` for exports and use | If you prefer to use ``docker run`` directly, supplying the necessary commandline | ||||||
|    ``docker-compose run``: | options: | ||||||
| 
 | 
 | ||||||
|    .. code-block:: diff | .. code-block:: shell-session | ||||||
| 
 | 
 | ||||||
|       diff --git a/docker-compose.yml b/docker-compose.yml |    $ # Identify your containers | ||||||
|       --- a/docker-compose.yml |    $ docker-compose ps | ||||||
|       +++ b/docker-compose.yml |            Name                       Command                State     Ports | ||||||
|       @@ -17,9 +18,8 @@ services: |    ------------------------------------------------------------------------- | ||||||
|                volumes: |    paperless_consumer_1    /sbin/docker-entrypoint.sh ...   Exit 0 | ||||||
|                    - paperless-data:/usr/src/paperless/data |    paperless_webserver_1   /sbin/docker-entrypoint.sh ...   Exit 0 | ||||||
|                    - paperless-media:/usr/src/paperless/media |  | ||||||
|                    - /consume |  | ||||||
|       +            - /path/to/arbitrary/place:/export |  | ||||||
| 
 | 
 | ||||||
|    .. code-block:: shell-session |    $ # Make sure to replace your passphrase and remove or adapt the id mapping | ||||||
| 
 |    $ docker run --rm \ | ||||||
|        $ docker-compose run --rm consumer document_exporter /export |        --volumes-from paperless_data_1 \ | ||||||
| 
 |        --volume /path/to/arbitrary/place:/export \ | ||||||
| 3. Use ``docker run`` directly, supplying the necessary commandline options: |        -e PAPERLESS_PASSPHRASE=YOUR_PASSPHRASE \ | ||||||
| 
 |        -e USERMAP_UID=1000 -e USERMAP_GID=1000 \ | ||||||
|    .. code-block:: shell-session |        paperless document_exporter /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 |  | ||||||
| 
 |  | ||||||
|        $ # 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: | .. _migrating-restoring: | ||||||
|  | |||||||
| @ -156,8 +156,15 @@ Docker Method | |||||||
|        .. _Docker installation guide: https://docs.docker.com/engine/installation/ |        .. _Docker installation guide: https://docs.docker.com/engine/installation/ | ||||||
|        .. _docker-compose installation guide: https://docs.docker.com/compose/install/ |        .. _docker-compose installation guide: https://docs.docker.com/compose/install/ | ||||||
| 
 | 
 | ||||||
| 3. Create a copy of ``docker-compose.yml.example`` as ``docker-compose.yml``. | 3. Create a copy of ``docker-compose.yml.example`` as ``docker-compose.yml`` and | ||||||
| 4. Modify ``docker-compose.env`` and adapt the following environment variables: |    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`` |    ``PAPERLESS_PASSPHRASE`` | ||||||
|      This is the passphrase Paperless uses to encrypt/decrypt the original |      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 |      and thus the one of the consumption directory. Furthermore, you can change | ||||||
|      the id of the default user as well using ``USERMAP_UID``. |      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. |    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: |    following command: | ||||||
| 
 | 
 | ||||||
|    .. code-block:: shell-session |    .. code-block:: shell-session | ||||||
| @ -197,11 +204,11 @@ Docker Method | |||||||
| 
 | 
 | ||||||
|    This will prompt you to set a username (default ``paperless``), an optional |    This will prompt you to set a username (default ``paperless``), an optional | ||||||
|    e-mail address and finally a password. |    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 |    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 |    `Paperless webserver`_ at ``http://127.0.0.1:8000``. You can login with the | ||||||
|    user and password you just created. |    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: |    possible options: | ||||||
| 
 | 
 | ||||||
|    1. Mount the consumption directory to a local host path by modifying your |    1. Mount the consumption directory to a local host path by modifying your | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user