| 
									
										
										
										
											2016-06-21 09:06:44 +01:00
										 |  |  | .. _server_deployment:
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-06-15 09:14:12 +01:00
										 |  |  | **************************
 | 
					
						
							|  |  |  | `Server Deployment`:index:
 | 
					
						
							|  |  |  | **************************
 | 
					
						
							| 
									
										
										
										
											2016-01-14 15:20:53 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | pgAdmin may be deployed as a web application by configuring the app to run in
 | 
					
						
							|  |  |  | server mode and then deploying it either behind a webserver running as a reverse
 | 
					
						
							|  |  |  | proxy, or using the WSGI interface.
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-08-07 10:07:28 +01:00
										 |  |  | When deployed in server mode, there are two notable differences for users:
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | * Users must login before they can use pgAdmin. An initial superuser account
 | 
					
						
							|  |  |  |   is created when server mode is initialised, and this user can add additional
 | 
					
						
							|  |  |  |   superusers and non-superusers as required.
 | 
					
						
							|  |  |  | * File storage is restricted to a virtual root directory for each individual
 | 
					
						
							|  |  |  |   user under the directory configured using the ``STORAGE_DIR`` configuration
 | 
					
						
							|  |  |  |   parameter. Users do not have access to the complete filesystem of the server.
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-01-14 15:20:53 +00:00
										 |  |  | The following instructions demonstrate how pgAdmin may be run as a WSGI 
 | 
					
						
							| 
									
										
										
										
											2019-07-09 14:11:38 +01:00
										 |  |  | application under ``Apache HTTPD``, using ``mod_wsgi``, standalone using ``uWSGI``
 | 
					
						
							| 
									
										
										
										
											2019-03-04 16:29:25 +00:00
										 |  |  | or ``Gunicorn``, or under ``NGINX`` using using ``uWSGI`` or ``Gunicorn``.
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-01-14 15:20:53 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-01-12 13:37:59 +00:00
										 |  |  | .. seealso:: For detailed instructions on building and configuring pgAdmin from
 | 
					
						
							|  |  |  |     scratch, please see the README file in the top level directory of the source code.
 | 
					
						
							|  |  |  |     For convenience, you can find the latest version of the file
 | 
					
						
							| 
									
										
										
										
											2022-09-21 10:56:03 +01:00
										 |  |  |     `here <https://github.com/pgadmin-org/pgadmin4/blob/master/README.md>`_,
 | 
					
						
							| 
									
										
										
										
											2018-01-12 13:37:59 +00:00
										 |  |  |     but be aware that this may differ from the version included with the source code
 | 
					
						
							|  |  |  |     for a specific version of pgAdmin.
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-01-14 15:20:53 +00:00
										 |  |  | Requirements
 | 
					
						
							| 
									
										
										
										
											2016-10-24 14:02:50 +01:00
										 |  |  | ************
 | 
					
						
							| 
									
										
										
										
											2016-01-14 15:20:53 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | **Important**: Some components of pgAdmin require the ability to maintain affinity
 | 
					
						
							|  |  |  | between client sessions and a specific database connection (for example, the 
 | 
					
						
							|  |  |  | Query Tool in which the user might run a BEGIN command followed by a number of
 | 
					
						
							|  |  |  | DML SQL statements, and then a COMMIT). pgAdmin has been designed with built-in
 | 
					
						
							|  |  |  | connection management to handle this, however it requires that only a single
 | 
					
						
							|  |  |  | Python process is used because it is not easily possible to maintain affinity
 | 
					
						
							|  |  |  | between a client session and one of multiple WSGI worker processes.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | On Windows systems, the Apache HTTP server uses a single process, multi-threaded
 | 
					
						
							|  |  |  | architecture. WSGI applications run in ``embedded`` mode, which means that only
 | 
					
						
							|  |  |  | a single process will be present on this platform in all cases.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | On Unix systems, the Apache HTTP server typically uses a multi-process, single
 | 
					
						
							|  |  |  | threaded architecture (this is dependent on the ``MPM`` that is chosen at 
 | 
					
						
							|  |  |  | compile time). If ``embedded`` mode is chosen for the WSGI application, then
 | 
					
						
							|  |  |  | there will be one Python environment for each Apache process, each with it's own
 | 
					
						
							|  |  |  | connection manager which will lead to loss of connection affinity. Therefore
 | 
					
						
							|  |  |  | one should use ``mod_wsgi``'s ``daemon`` mode, configured to use a single
 | 
					
						
							|  |  |  | process. This will launch a single instance of the WSGI application which is 
 | 
					
						
							|  |  |  | utilised by all the Apache worker processes.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | Whilst it is true that this is a potential performance bottleneck, in reality
 | 
					
						
							|  |  |  | pgAdmin is not a web application that's ever likely to see heavy traffic 
 | 
					
						
							|  |  |  | unlike a busy website, so in practice should not be an issue.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | Future versions of pgAdmin may introduce a shared connection manager process to
 | 
					
						
							|  |  |  | overcome this limitation, however that is a significant amount of work for 
 | 
					
						
							|  |  |  | little practical gain.
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-10-24 14:02:50 +01:00
										 |  |  | Configuration
 | 
					
						
							|  |  |  | *************
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-08-25 12:13:03 +01:00
										 |  |  | In order to configure pgAdmin to run in server mode, it may be necessary to
 | 
					
						
							| 
									
										
										
										
											2016-10-24 14:02:50 +01:00
										 |  |  | configure the Python code to run in multi-user mode, and then to configure the
 | 
					
						
							|  |  |  | web server to find and execute the code.
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-08-22 15:24:04 +01:00
										 |  |  | See :ref:`config_py` for more information on configuration settings.
 | 
					
						
							| 
									
										
										
										
											2016-10-24 14:02:50 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | Python
 | 
					
						
							|  |  |  | ------
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-08-25 12:13:03 +01:00
										 |  |  | From pgAdmin 4 v2 onwards, server mode is the default configuration. If running under
 | 
					
						
							|  |  |  | the desktop runtime, this is overridden automatically. There should typically be no
 | 
					
						
							|  |  |  | need to modify the configuration simply to enable server mode to work, however it may
 | 
					
						
							|  |  |  | be desirable to adjust some of the paths used.
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-10-24 14:02:50 +01:00
										 |  |  | In order to configure the Python code, follow these steps:
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 1. Create a ``config_local.py`` file alongside the existing ``config.py`` file.
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-08-25 12:13:03 +01:00
										 |  |  | 2. Edit ``config_local.py`` and add the following settings. In most cases, the default
 | 
					
						
							|  |  |  |    file locations should be appropriate:
 | 
					
						
							| 
									
										
										
										
											2016-10-24 14:02:50 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |    *NOTE: You must ensure the directories specified are writeable by
 | 
					
						
							| 
									
										
										
										
											2022-11-28 11:32:50 +05:30
										 |  |  |    the user that the web server processes will be running as, e.g. apache or www-data.
 | 
					
						
							|  |  |  |    You may specify DATA_DIR in order to create all required directories and files
 | 
					
						
							|  |  |  |    under DATA_DIR folder.*
 | 
					
						
							| 
									
										
										
										
											2016-10-24 14:02:50 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |    .. code-block:: python
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |        LOG_FILE = '/var/log/pgadmin4/pgadmin4.log'
 | 
					
						
							|  |  |  |        SQLITE_PATH = '/var/lib/pgadmin4/pgadmin4.db'
 | 
					
						
							|  |  |  |        SESSION_DB_PATH = '/var/lib/pgadmin4/sessions'
 | 
					
						
							|  |  |  |        STORAGE_DIR = '/var/lib/pgadmin4/storage'
 | 
					
						
							| 
									
										
										
										
											2022-11-28 11:32:50 +05:30
										 |  |  |        AZURE_CREDENTIAL_CACHE_DIR = '/var/lib/pgadmin4/azurecredentialcache'
 | 
					
						
							|  |  |  |        KERBEROS_CCACHE_DIR = '/var/lib/pgadmin4/kerberoscache'
 | 
					
						
							| 
									
										
										
										
											2016-10-24 14:02:50 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | 4. Run the following command to create the configuration database:
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    .. code-block:: bash
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-02-01 14:37:09 +05:30
										 |  |  |        # python setup.py setup-db
 | 
					
						
							| 
									
										
										
										
											2016-10-24 14:02:50 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | 5. Change the ownership of the configuration database to the user that the web server
 | 
					
						
							|  |  |  |    processes will run as, for example, assuming that the web server runs as user
 | 
					
						
							|  |  |  |    www-data in group www-data, and that the SQLite path is ``/var/lib/pgadmin4/pgadmin4.db``:
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    .. code-block:: bash
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |        # chown www-data:www-data /var/lib/pgadmin4/pgadmin4.db
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-08-22 15:24:04 +01:00
										 |  |  | Hosting
 | 
					
						
							|  |  |  | *******
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | There are many possible ways to host pgAdmin in server mode. Some examples are
 | 
					
						
							|  |  |  | given below:
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-01-14 15:20:53 +00:00
										 |  |  | Apache HTTPD Configuration (Windows)
 | 
					
						
							|  |  |  | ------------------------------------
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | Once Apache HTTP has been configured to support ``mod_wsgi``, the pgAdmin
 | 
					
						
							|  |  |  | application may be configured similarly to the example below:
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | .. code-block:: apache
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     <VirtualHost *>
 | 
					
						
							|  |  |  |         ServerName pgadmin.example.com
 | 
					
						
							|  |  |  |         WSGIScriptAlias / "C:\Program Files\pgAdmin4\web\pgAdmin4.wsgi"
 | 
					
						
							|  |  |  |         <Directory "C:\Program Files\pgAdmin4\web">
 | 
					
						
							|  |  |  |                 Order deny,allow
 | 
					
						
							|  |  |  |                 Allow from all
 | 
					
						
							|  |  |  |         </Directory>
 | 
					
						
							|  |  |  |     </VirtualHost>
 | 
					
						
							| 
									
										
										
										
											2017-09-20 16:22:51 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | Now open the file ``C:\Program Files\pgAdmin4\web\pgAdmin4.wsgi`` with your favorite editor and add the code
 | 
					
						
							|  |  |  | below which will activate Python virtual environment when Apache server runs.
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-09-20 16:42:47 +01:00
										 |  |  | .. code-block:: python
 | 
					
						
							| 
									
										
										
										
											2017-09-20 16:22:51 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-09-20 16:42:47 +01:00
										 |  |  |     activate_this = 'C:\Program Files\pgAdmin4\venv\Scripts\activate_this.py'
 | 
					
						
							| 
									
										
										
										
											2019-01-04 09:54:24 +00:00
										 |  |  |     exec(open(activate_this).read())
 | 
					
						
							| 
									
										
										
										
											2017-09-20 16:22:51 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | **Note:** The changes made in ``pgAdmin4.wsgi`` file will revert when pgAdmin4 is either upgraded or downgraded.
 | 
					
						
							| 
									
										
										
										
											2016-01-14 15:20:53 +00:00
										 |  |  |     
 | 
					
						
							|  |  |  | Apache HTTPD Configuration (Linux/Unix)
 | 
					
						
							|  |  |  | ---------------------------------------
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | Once Apache HTTP has been configured to support ``mod_wsgi``, the pgAdmin
 | 
					
						
							|  |  |  | application may be configured similarly to the example below:
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | .. code-block:: apache
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     <VirtualHost *>
 | 
					
						
							|  |  |  |         ServerName pgadmin.example.com
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-09-20 16:42:47 +01:00
										 |  |  |         WSGIDaemonProcess pgadmin processes=1 threads=25 python-home=/path/to/python/virtualenv
 | 
					
						
							| 
									
										
										
										
											2016-01-14 15:20:53 +00:00
										 |  |  |         WSGIScriptAlias / /opt/pgAdmin4/web/pgAdmin4.wsgi
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         <Directory /opt/pgAdmin4/web>
 | 
					
						
							|  |  |  |             WSGIProcessGroup pgadmin
 | 
					
						
							|  |  |  |             WSGIApplicationGroup %{GLOBAL}
 | 
					
						
							|  |  |  |             Order deny,allow
 | 
					
						
							|  |  |  |             Allow from all
 | 
					
						
							|  |  |  |         </Directory>
 | 
					
						
							| 
									
										
										
										
											2016-08-18 13:43:00 +01:00
										 |  |  |     </VirtualHost>
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | **Note:** If you're using Apache HTTPD 2.4 or later, replace the lines:
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | .. code-block:: apache
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             Order deny,allow
 | 
					
						
							|  |  |  |             Allow from all
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | with:
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | .. code-block:: apache
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             Require all granted
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-01-12 13:37:59 +00:00
										 |  |  | Adjust as needed to suit your access control requirements.
 | 
					
						
							| 
									
										
										
										
											2019-03-04 16:29:25 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | Standalone Gunicorn Configuration
 | 
					
						
							|  |  |  | ---------------------------------
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | pgAdmin may be hosted by Gunicorn directly simply by running a command such as
 | 
					
						
							|  |  |  | the one shown below. Note that this example assumes pgAdmin was installed using
 | 
					
						
							|  |  |  | the Python Wheel (you may need to adjust the path to suit your installation):
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | .. code-block:: bash
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     gunicorn  --bind 0.0.0.0:80 \
 | 
					
						
							|  |  |  |               --workers=1 \
 | 
					
						
							|  |  |  |               --threads=25 \
 | 
					
						
							|  |  |  |               --chdir /usr/lib/python3.7/dist-packages/pgadmin4 \
 | 
					
						
							|  |  |  |               pgAdmin4:app
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | Standalone uWSGI Configuration
 | 
					
						
							|  |  |  | ------------------------------
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | pgAdmin may be hosted by uWSGI directly simply by running a command such as
 | 
					
						
							|  |  |  | the one shown below. Note that this example assumes pgAdmin was installed using
 | 
					
						
							|  |  |  | the Python Wheel (you may need to adjust the path to suit your installation):
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | .. code-block:: bash
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     uwsgi --http-socket 0.0.0.0:80 \
 | 
					
						
							|  |  |  |           --processes 1 \
 | 
					
						
							|  |  |  |           --threads 25 \
 | 
					
						
							|  |  |  |           --chdir /usr/lib/python3.7/dist-packages/pgadmin4/ \
 | 
					
						
							|  |  |  |           --mount /=pgAdmin4:app
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | NGINX Configuration with Gunicorn
 | 
					
						
							|  |  |  | ---------------------------------
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | pgAdmin can be hosted by Gunicorn, with NGINX in front of it. Note that these
 | 
					
						
							|  |  |  | examples assume pgAdmin was installed using the Python Wheel (you may need to
 | 
					
						
							|  |  |  | adjust the path to suit your installation).
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | To run with pgAdmin in the root directory of the server, start Gunicorn using a
 | 
					
						
							|  |  |  | command similar to:
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | .. code-block:: bash
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     gunicorn --bind unix:/tmp/pgadmin4.sock \
 | 
					
						
							|  |  |  |              --workers=1 \
 | 
					
						
							|  |  |  |              --threads=25 \
 | 
					
						
							|  |  |  |              --chdir /usr/lib/python3.7/dist-packages/pgadmin4 \
 | 
					
						
							|  |  |  |              pgAdmin4:app
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | And configure NGINX:
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | .. code-block:: nginx
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     location / {
 | 
					
						
							|  |  |  |         include proxy_params;
 | 
					
						
							|  |  |  |         proxy_pass http://unix:/tmp/pgadmin4.sock;
 | 
					
						
							|  |  |  |     }
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | Alternatively, pgAdmin can be hosted in a sub-directory (/pgadmin4 in this case)
 | 
					
						
							|  |  |  | on the server. Start Gunicorn as when using the root directory, but configure
 | 
					
						
							|  |  |  | NGINX as follows:
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | .. code-block:: nginx
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     location /pgadmin4/ {
 | 
					
						
							|  |  |  |         include proxy_params;
 | 
					
						
							|  |  |  |         proxy_pass http://unix:/tmp/pgadmin4.sock;
 | 
					
						
							|  |  |  |         proxy_set_header X-Script-Name /pgadmin4;
 | 
					
						
							|  |  |  |     }
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | NGINX Configuration with uWSGI
 | 
					
						
							|  |  |  | ------------------------------
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | pgAdmin can be hosted by uWSGI, with NGINX in front of it. Note that these
 | 
					
						
							|  |  |  | examples assume pgAdmin was installed using the Python Wheel (you may need to
 | 
					
						
							|  |  |  | adjust the path to suit your installation).
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-12-24 13:20:08 +05:30
										 |  |  | To run with pgAdmin in the root directory of the server, start uWSGI using a
 | 
					
						
							| 
									
										
										
										
											2019-03-04 16:29:25 +00:00
										 |  |  | command similar to:
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | .. code-block:: bash
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     uwsgi --socket /tmp/pgadmin4.sock \
 | 
					
						
							|  |  |  |           --processes 1 \
 | 
					
						
							|  |  |  |           --threads 25 \
 | 
					
						
							|  |  |  |           --chdir /usr/lib/python3.7/dist-packages/pgadmin4/ \
 | 
					
						
							|  |  |  |           --manage-script-name \
 | 
					
						
							|  |  |  |           --mount /=pgAdmin4:app
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | And configure NGINX:
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | .. code-block:: nginx
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     location / { try_files $uri @pgadmin4; }
 | 
					
						
							|  |  |  |     location @pgadmin4 {
 | 
					
						
							|  |  |  |         include uwsgi_params;
 | 
					
						
							|  |  |  |         uwsgi_pass unix:/tmp/pgadmin4.sock;
 | 
					
						
							|  |  |  |     }
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | Alternatively, pgAdmin can be hosted in a sub-directory (/pgadmin4 in this case)
 | 
					
						
							|  |  |  | on the server. Start uWSGI, noting that the directory name is specified in the
 | 
					
						
							|  |  |  | ``mount`` parameter:
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | .. code-block:: bash
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     uwsgi --socket /tmp/pgadmin4.sock \
 | 
					
						
							|  |  |  |           --processes 1 \
 | 
					
						
							|  |  |  |           --threads 25 \
 | 
					
						
							|  |  |  |           --chdir /usr/lib/python3.7/dist-packages/pgadmin4/ \
 | 
					
						
							|  |  |  |           --manage-script-name \
 | 
					
						
							|  |  |  |           --mount /pgadmin4=pgAdmin4:app
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | Then, configure NGINX:
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | .. code-block:: nginx
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     location = /pgadmin4 { rewrite ^ /pgadmin4/; }
 | 
					
						
							|  |  |  |     location /pgadmin4 { try_files $uri @pgadmin4; }
 | 
					
						
							|  |  |  |     location @pgadmin4 {
 | 
					
						
							|  |  |  |       include uwsgi_params;
 | 
					
						
							|  |  |  |       uwsgi_pass unix:/tmp/pgadmin4.sock;
 | 
					
						
							|  |  |  |     }
 | 
					
						
							| 
									
										
										
										
											2022-10-03 13:35:31 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | Additional Information
 | 
					
						
							|  |  |  | ----------------------
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | .. note:: pgAdmin will spawn additional Python processes from time to time, and
 | 
					
						
							|  |  |  |     relies on the *sys.executable* variable in Python to do this. In some cases,
 | 
					
						
							|  |  |  |     you may need to override that value to ensure the correct interpreter is
 | 
					
						
							|  |  |  |     used, instead of the WSGI host process. For example, uWSGI offers the
 | 
					
						
							| 
									
										
										
										
											2024-02-01 14:37:09 +05:30
										 |  |  |     *--py-sys-executable* command line option to achieve this.
 |