mirror of
https://github.com/paperless-ngx/paperless-ngx.git
synced 2025-04-02 13:45:10 -05:00
611 lines
23 KiB
ReStructuredText
611 lines
23 KiB
ReStructuredText
.. _setup:
|
|
|
|
Setup
|
|
=====
|
|
|
|
Paperless isn't a very complicated app, but there are a few components, so some
|
|
basic documentation is in order. If you follow along in this document and
|
|
still have trouble, please open an `issue on GitHub`_ so I can fill in the
|
|
gaps.
|
|
|
|
.. _issue on GitHub: https://github.com/danielquinn/paperless/issues
|
|
|
|
|
|
.. _setup-download:
|
|
|
|
Download
|
|
--------
|
|
|
|
The source is currently only available via GitHub, so grab it from there,
|
|
either by using ``git``:
|
|
|
|
.. code:: bash
|
|
|
|
$ git clone https://github.com/danielquinn/paperless.git
|
|
$ cd paperless
|
|
|
|
or just download the tarball and go that route:
|
|
|
|
.. code:: bash
|
|
|
|
$ cd to the directory where you want to run Paperless
|
|
$ wget https://github.com/danielquinn/paperless/archive/master.zip
|
|
$ unzip master.zip
|
|
$ cd paperless-master
|
|
|
|
|
|
.. _setup-installation:
|
|
|
|
Installation & Configuration
|
|
----------------------------
|
|
|
|
You can go multiple routes with setting up and running Paperless. The `Vagrant
|
|
route`_ is quick & easy, but means you're running a VM which comes with memory
|
|
consumption etc. We also `support Docker`_, which you can use natively under
|
|
Linux and in a VM with `Docker Machine`_ (this guide was written for native
|
|
Docker usage under Linux, you might have to adapt it for Docker Machine.)
|
|
Not to forget the virtualenv, this is similar to `bare metal`_ with the
|
|
exception that you have to activate the virtualenv first.
|
|
Last but not least, the standard `bare metal`_ approach is a little more
|
|
complicated, but worth it because it makes it easier should you want to
|
|
contribute some code back.
|
|
|
|
.. _Vagrant route: setup-installation-vagrant_
|
|
.. _support Docker: setup-installation-docker_
|
|
.. _bare metal: setup-installation-standard_
|
|
.. _Docker Machine: https://docs.docker.com/machine/
|
|
|
|
|
|
.. _setup-installation-standard:
|
|
|
|
Standard (Bare Metal)
|
|
.....................
|
|
|
|
1. Install the requirements as per the :ref:`requirements <requirements>` page.
|
|
2. Within the extract of master.zip go to the ``src`` directory.
|
|
3. Copy ``paperless.conf.example`` to ``/etc/paperless.conf`` also the virtual
|
|
envrionment look there for it and open it in your favourite editor.
|
|
Because this file contains passwords it should only be readable by user root
|
|
and paperless ! Set the values for:
|
|
|
|
* ``PAPERLESS_CONSUMPTION_DIR``: this is where your documents will be
|
|
dumped to be consumed by Paperless.
|
|
* ``PAPERLESS_PASSPHRASE``: this is the passphrase Paperless uses to
|
|
encrypt/decrypt the original document.
|
|
* ``PAPERLESS_OCR_THREADS``: this is the number of threads the OCR process
|
|
will spawn to process document pages in parallel.
|
|
|
|
4. Initialise the SQLite database with ``./manage.py migrate``.
|
|
5. Create a user for your Paperless instance with
|
|
``./manage.py createsuperuser``. Follow the prompts to create your user.
|
|
6. Start the webserver with ``./manage.py runserver <IP>:<PORT>``.
|
|
If no specifc IP or port are given, the default is ``127.0.0.1:8000``
|
|
also known as http://localhost:8000/.
|
|
You should now be able to visit your (empty) at `Paperless webserver`_ or
|
|
whatever you chose before. You can login with the user/pass you created in
|
|
#5.
|
|
7. In a separate window, change to the ``src`` directory in this repo again,
|
|
but this time, you should start the consumer script with
|
|
``./manage.py document_consumer``.
|
|
8. Scan something or put a file into the ``CONSUMPTION_DIR``.
|
|
9. Wait a few minutes
|
|
10. Visit the document list on your webserver, and it should be there, indexed
|
|
and downloadable.
|
|
|
|
.. _Paperless webserver: http://127.0.0.1:8000
|
|
|
|
|
|
.. _setup-installation-docker:
|
|
|
|
Docker Method
|
|
.............
|
|
|
|
1. Install `Docker`_.
|
|
|
|
.. caution::
|
|
|
|
As mentioned earlier, this guide assumes that you use Docker natively
|
|
under Linux. If you are using `Docker Machine`_ under Mac OS X or
|
|
Windows, you will have to adapt IP addresses, volume-mounting, command
|
|
execution and maybe more.
|
|
|
|
2. Install `docker-compose`_. [#compose]_
|
|
|
|
.. caution::
|
|
|
|
If you want to use the included ``docker-compose.yml.example`` file, you
|
|
need to have at least Docker version **1.10.0** and docker-compose
|
|
version **1.6.0**.
|
|
|
|
See the `Docker installation guide`_ on how to install the current
|
|
version of Docker for your operating system or Linux distribution of
|
|
choice. To get an up-to-date version of docker-compose, follow the
|
|
`docker-compose installation guide`_ if your package repository doesn't
|
|
include it.
|
|
|
|
.. _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``
|
|
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.[#dockercomposeyml]_
|
|
5. Modify ``docker-compose.env`` and adapt the following environment variables:
|
|
|
|
``PAPERLESS_PASSPHRASE``
|
|
This is the passphrase Paperless uses to encrypt/decrypt the original
|
|
document.
|
|
|
|
``PAPERLESS_OCR_THREADS``
|
|
This is the number of threads the OCR process will spawn to process
|
|
document pages in parallel. If the variable is not set, Python determines
|
|
the core-count of your CPU and uses that value.
|
|
|
|
``PAPERLESS_OCR_LANGUAGES``
|
|
If you want the OCR to recognize other languages in addition to the
|
|
default English, set this parameter to a space separated list of
|
|
three-letter language-codes after `ISO 639-2/T`_. For a list of available
|
|
languages -- including their three letter codes -- see the
|
|
`Alpine packagelist`_.
|
|
|
|
``USERMAP_UID`` and ``USERMAP_GID``
|
|
If you want to mount the consumption volume (directory ``/consume`` within
|
|
the containers) to a host-directory -- which you probably want to do --
|
|
access rights might be an issue. The default user and group ``paperless``
|
|
in the containers have an id of 1000. The containers will enforce that the
|
|
owning group of the consumption directory will be ``paperless`` to be able
|
|
to delete consumed documents. If your host-system has a group with an ID
|
|
of 1000 and you don't want this group to have access rights to the
|
|
consumption directory, you can use ``USERMAP_GID`` to change the id in the
|
|
container and thus the one of the consumption directory. Furthermore, you
|
|
can change the id of the default user as well using ``USERMAP_UID``.
|
|
|
|
6. Run ``docker-compose up -d``. This will create and start the necessary
|
|
containers.
|
|
7. To be able to login, you will need a super user. To create it, execute the
|
|
following command:
|
|
|
|
.. code-block:: shell-session
|
|
|
|
$ docker-compose run --rm webserver createsuperuser
|
|
|
|
This will prompt you to set a username (default ``paperless``), an optional
|
|
e-mail address and finally a password.
|
|
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.
|
|
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
|
|
``docker-compose.yml``:
|
|
|
|
.. code-block:: diff
|
|
|
|
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
|
|
+ - /local/path/you/choose:/consume
|
|
|
|
.. danger::
|
|
|
|
While the consumption container will ensure at startup that it can
|
|
**delete** a consumed file from a host-mounted directory, it might
|
|
not be able to **read** the document in the first place if the access
|
|
rights to the file are incorrect.
|
|
|
|
Make sure that the documents you put into the consumption directory
|
|
will either be readable by everyone (``chmod o+r file.pdf``) or
|
|
readable by the default user or group id 1000 (or the one you have
|
|
set with ``USERMAP_UID`` or ``USERMAP_GID`` respectively).
|
|
|
|
2. Use ``docker cp`` to copy your files directly into the container:
|
|
|
|
.. 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
|
|
|
|
$ docker cp /path/to/your/file.pdf paperless_consumer_1:/consume
|
|
|
|
``docker cp`` is a one-shot-command, just like ``cp``. This means that
|
|
every time you want to consume a new document, you will have to execute
|
|
``docker cp`` again. You can of course automate this process, but option
|
|
1 is generally the preferred one.
|
|
|
|
.. danger::
|
|
|
|
``docker cp`` will change the owning user and group of a copied file
|
|
to the acting user at the destination, which will be ``root``.
|
|
|
|
You therefore need to ensure that the documents you want to copy into
|
|
the container are readable by everyone (``chmod o+r file.pdf``)
|
|
before copying them.
|
|
|
|
|
|
.. _Docker: https://www.docker.com/
|
|
.. _docker-compose: https://docs.docker.com/compose/install/
|
|
.. _ISO 639-2/T: https://en.wikipedia.org/wiki/List_of_ISO_639-1_codes
|
|
.. _Alpine packagelist: https://pkgs.alpinelinux.org/packages?name=tesseract-ocr-data*&arch=x86_64
|
|
|
|
.. [#compose] You of course don't have to use docker-compose, but it
|
|
simplifies deployment immensely. If you know your way around Docker, feel
|
|
free to tinker around without using compose!
|
|
|
|
.. [#dockercomposeyml] If you're upgrading your docker-compose images from
|
|
version 1.1.0 or earlier, you might need to change in the
|
|
``docker-compose.yml`` file the ``image: pitkley/paperless`` directive in
|
|
both the ``webserver`` and ``consumer`` sections to ``build: ./`` as per the
|
|
newer ``docker-compose.yml.example`` file
|
|
|
|
|
|
.. _setup-installation-vagrant:
|
|
|
|
Vagrant Method
|
|
..............
|
|
|
|
1. Install `Vagrant`_. How you do that is really between you and your OS.
|
|
2. Run ``vagrant up``. An instance will start up for you. When it's ready and
|
|
provisioned...
|
|
3. Run ``vagrant ssh`` and once inside your new vagrant box, edit
|
|
``/etc/paperless.conf`` and set the values for:
|
|
|
|
* ``PAPERLESS_CONSUMPTION_DIR``: this is where your documents will be
|
|
dumped to be consumed by Paperless.
|
|
* ``PAPERLESS_PASSPHRASE``: this is the passphrase Paperless uses to
|
|
encrypt/decrypt the original document.
|
|
* ``PAPERLESS_SHARED_SECRET``: this is the "magic word" used when consuming
|
|
documents from mail or via the API. If you don't use either, leaving it
|
|
blank is just fine.
|
|
|
|
4. Exit the vagrant box and re-enter it with ``vagrant ssh`` again. This
|
|
updates the environment to make use of the changes you made to the config
|
|
file.
|
|
5. Initialise the database with ``/opt/paperless/src/manage.py migrate``.
|
|
6. Still inside your vagrant box, create a user for your Paperless instance
|
|
with ``/opt/paperless/src/manage.py createsuperuser``. Follow the prompts to
|
|
create your user.
|
|
7. Start the webserver with
|
|
``/opt/paperless/src/manage.py runserver 0.0.0.0:8000``. You should now be
|
|
able to visit your (empty) `Paperless webserver`_ at ``172.28.128.4:8000``.
|
|
You can login with the user/pass you created in #6.
|
|
8. In a separate window, run ``vagrant ssh`` again, but this time once inside
|
|
your vagrant instance, you should start the consumer script with
|
|
``/opt/paperless/src/manage.py document_consumer``.
|
|
9. Scan something. Put it in the ``CONSUMPTION_DIR``.
|
|
10. Wait a few minutes
|
|
11. Visit the document list on your webserver, and it should be there, indexed
|
|
and downloadable.
|
|
|
|
.. _Vagrant: https://vagrantup.com/
|
|
.. _Paperless server: http://172.28.128.4:8000
|
|
|
|
|
|
.. _setup-permanent:
|
|
|
|
Making Things a Little more Permanent
|
|
-------------------------------------
|
|
|
|
Once you've tested things and are happy with the work flow, you can automate
|
|
the process of starting the webserver and consumer automatically.
|
|
|
|
|
|
.. _setup-permanent-standard-systemd:
|
|
|
|
Standard (Bare Metal, Systemd)
|
|
..............................
|
|
|
|
If you're running on a bare metal system that's using Systemd, you can use the
|
|
service unit files in the ``scripts`` directory to set this up. You'll need to
|
|
create a user called ``paperless`` (without login (if not already done so #5))
|
|
and setup Paperless to be in a place that this new user can read and write to.
|
|
Be sure to edit the service scripts to point to the proper location of your
|
|
paperless install, referencing the appropriate Python binary. For example:
|
|
``ExecStart=/path/to/python3 /path/to/paperless/src/manage.py document_consumer``.
|
|
If you don't want to make a new user, you can change the ``Group`` and ``User``
|
|
variables accordingly.
|
|
|
|
Then, as ``root`` (or using ``sudo``) you can just copy the ``.service`` files
|
|
to the Systemd directory and tell it to enable the two services::
|
|
|
|
# cp /path/to/paperless/scripts/paperless-consumer.service /etc/systemd/system/
|
|
# cp /path/to/paperless/scripts/paperless-webserver.service /etc/systemd/system/
|
|
# systemctl enable paperless-consumer
|
|
# systemctl enable paperless-webserver
|
|
# systemctl start paperless-consumer
|
|
# systemctl start paperless-webserver
|
|
|
|
|
|
.. _setup-permanent-standard-ubuntu14:
|
|
|
|
Ubuntu 14.04 (Bare Metal, Upstart)
|
|
..................................
|
|
|
|
Ubuntu 14.04 and earlier use the `Upstart`_ init system to start services
|
|
during the boot process. To configure Upstart to run Paperless automatically
|
|
after restarting your system:
|
|
|
|
1. Change to the directory where Upstart's configuration files are kept:
|
|
``cd /etc/init``
|
|
2. Create a new file: ``sudo nano paperless-server.conf``
|
|
3. In the newly-created file enter::
|
|
|
|
start on (local-filesystems and net-device-up IFACE=eth0)
|
|
stop on shutdown
|
|
|
|
respawn
|
|
respawn limit 10 5
|
|
|
|
script
|
|
exec /srv/paperless/src/manage.py runserver 0.0.0.0:80
|
|
end script
|
|
|
|
Note that you'll need to replace ``/srv/paperless/src/manage.py`` with the
|
|
path to the ``manage.py`` script in your installation directory.
|
|
|
|
If you are using a network interface other than ``eth0``, you will have to
|
|
change ``IFACE=eth0``. For example, if you are connected via WiFi, you will
|
|
likely need to replace ``eth0`` above with ``wlan0``. To see all interfaces,
|
|
run ``ifconfig -a``.
|
|
|
|
Save the file.
|
|
|
|
4. Create a new file: ``sudo nano paperless-consumer.conf``
|
|
|
|
5. In the newly-created file enter::
|
|
|
|
start on (local-filesystems and net-device-up IFACE=eth0)
|
|
stop on shutdown
|
|
|
|
respawn
|
|
respawn limit 10 5
|
|
|
|
script
|
|
exec /srv/paperless/src/manage.py document_consumer
|
|
end script
|
|
|
|
Replace ``/srv/paperless/src/manage.py`` with the same values as in step 3
|
|
above and replace ``eth0`` with the appropriate value, if necessary. Save the
|
|
file.
|
|
|
|
These two configuration files together will start both the Paperless webserver
|
|
and document consumer processes when the file system and network interface
|
|
specified is available after boot. Furthermore, if either process ever exits
|
|
unexpectedly, Upstart will try to restart it a maximum of 10 times within a 5
|
|
second period.
|
|
|
|
.. _Upstart: http://upstart.ubuntu.com/
|
|
|
|
|
|
.. _setup-permanent-vagrant:
|
|
|
|
|
|
Using a Real Webserver
|
|
......................
|
|
|
|
The default is to use Django's development server, as that's easy and does the
|
|
job well enough on a home network. However, if you want to do things right,
|
|
it's probably a good idea to use a webserver capable of handling more than one
|
|
thread. You will also have to let the webserver serve the static files (CSS,
|
|
JavaScript) from the directory configured in ``PAPERLESS_STATICDIR``. For that,
|
|
you need to run ``./manage.py collectstatic`` in the ``src`` directory. The
|
|
default static files directory is ``../static``.
|
|
|
|
Apache
|
|
~~~~~~
|
|
|
|
This is a configuration supplied by `steckerhalter`_ on GitHub. It uses Apache
|
|
and mod_wsgi, with a Paperless installation in /home/paperless/:
|
|
|
|
.. code:: apache
|
|
|
|
<VirtualHost *:80>
|
|
ServerName example.com
|
|
|
|
Alias /static/ /home/paperless/paperless/static/
|
|
<Directory /home/paperless/paperless/static>
|
|
Require all granted
|
|
</Directory>
|
|
|
|
WSGIScriptAlias / /home/paperless/paperless/src/paperless/wsgi.py
|
|
WSGIDaemonProcess example.com user=paperless group=paperless threads=5 python-path=/home/paperless/paperless/src:/home/paperless/.env/lib/python3.4/site-packages
|
|
WSGIProcessGroup example.com
|
|
|
|
<Directory /home/paperless/paperless/src/paperless>
|
|
<Files wsgi.py>
|
|
Require all granted
|
|
</Files>
|
|
</Directory>
|
|
</VirtualHost>
|
|
|
|
.. _steckerhalter: https://github.com/steckerhalter
|
|
|
|
|
|
Nginx + Gunicorn
|
|
~~~~~~~~~~~~~~~~
|
|
|
|
If you're using Nginx, the most common setup is to combine it with a
|
|
Python-based server like Gunicorn so that Nginx is acting as a proxy. Below is
|
|
a copy of a simple Nginx configuration fragment making use of SSL and IPv6 to
|
|
refer to a gunicorn instance listening on a local Unix socket:
|
|
|
|
.. code:: nginx
|
|
|
|
upstream transfer_server {
|
|
server unix:/run/example.com/gunicorn.sock fail_timeout=0;
|
|
}
|
|
|
|
# Redirect requests on port 80 to 443
|
|
server {
|
|
listen 80;
|
|
listen [::]:80;
|
|
server_name example.com;
|
|
rewrite ^ https://$server_name$request_uri? permanent;
|
|
}
|
|
|
|
server {
|
|
|
|
listen 443 ssl;
|
|
listen [::]:443;
|
|
client_max_body_size 4G;
|
|
server_name example.com;
|
|
keepalive_timeout 5;
|
|
root /var/www/example.com;
|
|
|
|
ssl on;
|
|
|
|
ssl_certificate /etc/letsencrypt/live/example.com/fullchain.pem;
|
|
ssl_certificate_key /etc/letsencrypt/live/example.com/privkey.pem;
|
|
ssl_trusted_certificate /etc/letsencrypt/live/example.com/fullchain.pem;
|
|
ssl_session_timeout 1d;
|
|
ssl_session_cache shared:SSL:50m;
|
|
|
|
# Diffie-Hellman parameter for DHE ciphersuites, recommended 2048 bits
|
|
# Generate with:
|
|
# openssl dhparam -out /etc/nginx/dhparam.pem 2048
|
|
ssl_dhparam /etc/nginx/dhparam.pem;
|
|
|
|
# What Mozilla calls "Intermediate configuration"
|
|
# Copied from https://mozilla.github.io/server-side-tls/ssl-config-generator/
|
|
ssl_protocols TLSv1 TLSv1.1 TLSv1.2;
|
|
ssl_ciphers 'ECDHE-ECDSA-CHACHA20-POLY1305:ECDHE-RSA-CHACHA20-POLY1305:ECDHE-ECDSA-AES128-GCM-SHA256:ECDHE-RSA-AES128-GCM-SHA256:ECDHE-ECDSA-AES256-GCM-SHA384:ECDHE-RSA-AES256-GCM-SHA384:DHE-RSA-AES128-GCM-SHA256:DHE-RSA-AES256-GCM-SHA384:ECDHE-ECDSA-AES128-SHA256:ECDHE-RSA-AES128-SHA256:ECDHE-ECDSA-AES128-SHA:ECDHE-RSA-AES256-SHA384:ECDHE-RSA-AES128-SHA:ECDHE-ECDSA-AES256-SHA384:ECDHE-ECDSA-AES256-SHA:ECDHE-RSA-AES256-SHA:DHE-RSA-AES128-SHA256:DHE-RSA-AES128-SHA:DHE-RSA-AES256-SHA256:DHE-RSA-AES256-SHA:ECDHE-ECDSA-DES-CBC3-SHA:ECDHE-RSA-DES-CBC3-SHA:EDH-RSA-DES-CBC3-SHA:AES128-GCM-SHA256:AES256-GCM-SHA384:AES128-SHA256:AES256-SHA256:AES128-SHA:AES256-SHA:DES-CBC3-SHA:!DSS';
|
|
ssl_prefer_server_ciphers on;
|
|
|
|
add_header Strict-Transport-Security max-age=15768000;
|
|
|
|
ssl_stapling on;
|
|
ssl_stapling_verify on;
|
|
|
|
access_log /var/log/nginx/example.com.log main;
|
|
error_log /var/log/nginx/example.com.err info;
|
|
|
|
location / {
|
|
try_files $uri @proxy_to_app;
|
|
}
|
|
|
|
location @proxy_to_app {
|
|
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
|
|
proxy_set_header X-Forwarded-Proto https;
|
|
proxy_set_header Host $host;
|
|
proxy_redirect off;
|
|
proxy_pass http://transfer_server;
|
|
}
|
|
|
|
}
|
|
|
|
Once you've got Nginx configured, you'll want to have a configuration file for
|
|
your gunicorn instance. This should do the trick:
|
|
|
|
.. code:: python
|
|
|
|
import os
|
|
|
|
bind = 'unix:/run/example.com/gunicorn.sock'
|
|
backlog = 2048
|
|
workers = 6
|
|
worker_class = 'sync'
|
|
worker_connections = 1000
|
|
timeout = 30
|
|
keepalive = 2
|
|
debug = False
|
|
spew = False
|
|
daemon = False
|
|
pidfile = None
|
|
umask = 0
|
|
user = None
|
|
group = None
|
|
tmp_upload_dir = None
|
|
errorlog = '/var/log/example.com/gunicorn.err'
|
|
loglevel = 'warning'
|
|
accesslog = '/var/log/example.com/gunicorn.log'
|
|
proc_name = None
|
|
|
|
def post_fork(server, worker):
|
|
server.log.info("Worker spawned (pid: %s)", worker.pid)
|
|
|
|
def pre_fork(server, worker):
|
|
pass
|
|
|
|
def pre_exec(server):
|
|
server.log.info("Forked child, re-executing.")
|
|
|
|
def when_ready(server):
|
|
server.log.info("Server is ready. Spawning workers")
|
|
|
|
def worker_int(worker):
|
|
worker.log.info("worker received INT or QUIT signal")
|
|
|
|
## get traceback info
|
|
import threading, sys, traceback
|
|
id2name = dict([(th.ident, th.name) for th in threading.enumerate()])
|
|
code = []
|
|
for threadId, stack in sys._current_frames().items():
|
|
code.append("\n# Thread: %s(%d)" % (id2name.get(threadId,""),
|
|
threadId))
|
|
for filename, lineno, name, line in traceback.extract_stack(stack):
|
|
code.append('File: "%s", line %d, in %s' % (filename,
|
|
lineno, name))
|
|
if line:
|
|
code.append(" %s" % (line.strip()))
|
|
worker.log.debug("\n".join(code))
|
|
|
|
def worker_abort(worker):
|
|
worker.log.info("worker received SIGABRT signal")
|
|
|
|
Vagrant
|
|
.......
|
|
|
|
You may use the Ubuntu explanation above. Replace
|
|
``(local-filesystems and net-device-up IFACE=eth0)`` with ``vagrant-mounted``.
|
|
|
|
.. _setup-permanent-docker:
|
|
|
|
Docker
|
|
......
|
|
|
|
If you're using Docker, you can set a restart-policy_ in the
|
|
``docker-compose.yml`` to have the containers automatically start with the
|
|
Docker daemon.
|
|
|
|
.. _restart-policy: https://docs.docker.com/engine/reference/commandline/run/#restart-policies-restart
|
|
|
|
|
|
.. _setup-subdirectory:
|
|
|
|
Hosting Paperless in a Subdirectory
|
|
-----------------------------------
|
|
|
|
Paperless was designed to run off the root of the hosting domain,
|
|
(ie: ``https://example.com/``) but with a few changes, you can configure
|
|
it to run in a subdirectory on your server
|
|
(ie: ``https://example.com/paperless/``).
|
|
|
|
Thanks to the efforts of `maphy-psd`_ on `Github`_, running Paperless in a
|
|
subdirectory is now as easy as setting a config variable. Simply set
|
|
``PAPERLESS_FORCE_SCRIPT_NAME`` in your environment or
|
|
``/etc/paperless.conf`` to the path you want Paperless hosted at, configure
|
|
Nginx/Apache for your needs and you're done. So, if you want Paperless to live
|
|
at ``https://example.com/arbitrary/path/to/paperless`` then you just set
|
|
``PAPERLESS_FORCE_SCRIPT_NAME`` to ``/arbitrary/path/to/paperless``. Note the
|
|
leading ``/`` there.
|
|
|
|
As to how to configure Nginx or Apache for this, that's on you :-)
|
|
|
|
.. _maphy-psd: https://github.com/maphy-psd
|
|
.. _Github: https://github.com/danielquinn/paperless/pull/255
|