This repository automates the build of QGIS and QGIS server Docker images.
A simple QGIS desktop Docker image
The Docker image is built using Ubuntu 20.04 (focal) and 22.04 (jammy) and official QGIS DEBs from https://qgis.org/. It includes Nginx and Xvfb and can be used as a standalone service (via HTTP TCP port 80) or as FCGI backend (via TCP port 9993).
You need Docker >= 18.04 with seccomp
. Support for the statx
syscall, required by Qt 5.10+, may be made necessary in the future. This is generally included in libseccomp >= 2.3.3;
a kernel with statx
support is also required; any kernel newer than 4.11 should be ok. Please check with your vendor.
Known good configurations are:
- Ubuntu 18.04.2+
- CentOS 8
- Fedora 29+
See https://github.com/gem/oq-qgis-server/issues/1 for further details.
Containers are not tested on hosts running OSes other than Linux.
This Docker container exposes HTTP on port 80
via Nginx and a direct FastCGI on port 9993
that can be used directly by an external HTTP proxy (like the provided docker-compose.yml
does).
A sample Nginx configuration for using it as a FastCGI backend is also provided.
Image name: opengisch/qgis-server
stable
|stable-ubuntu
ltr
|ltr-ubuntu
Example:
$ docker pull opengisch/qgis-server:ltr
$ docker build -t opengisch/qgis-server:stable .
$ docker build --build-arg repo=ubuntu-ltr -t opengisch/qgis-server:ltr .
You may skip this step. The container will be downloaded from the Docker Hub.
$ docker run -v $(pwd)/data:/io/data --name qgis-server -d -p 8010:80 opengisch/qgis-server:ltr
WMS
and WFS
for a specific project will be published at http://localhost:8010/ogc/<project_name>
.
An /ows/
endpoint is also available for direct access to the fcgi
(bypassing the map=<project_name>
rewrite).
Direct access to WFS3
is accessible via http://localhost:8010/wfs3/
.
The connection service file allows connection parameters to be associated with a single service name and thus to be able to use the same QGIS projects in different environments. This could also be achieved with QGIS authentications. To use a pg_service file you need to bind mount it as shown in the docker-compose or on run:
-v $(pwd)/conf/pg_service.conf:/etc/postgresql-common/pg_service.conf:ro
Plugins, custom fonts and SVG can be optionally exposed from host to the containers:
-v $(pwd)/plugins:/io/plugins
-v $(pwd)/fonts:/usr/share/fonts
-v $(pwd)/svg:/var/lib/qgis/.local/share/QGIS/QGIS3/profiles/default/svg
Example:
$ docker run -v $(pwd)/data:/io/data -v $(pwd)/plugins:/io/plugins -v $(pwd)/fonts:/usr/share/fonts --name qgis-server -d -p 8010:80 openquake/qgis-server:ltr
$ docker exec -ti qgis-server /bin/bash
where qgis-server
is the name of the container.
QGIS server log can retreived via docker logs
$ docker logs [-f] qgis-server
where qgis-server
is the name of the container.
Default log level is set to warning
. Log level can be increased during container deployment passing the -e QGIS_SERVER_LOG_LEVEL=0
option:
$ docker run -e QGIS_SERVER_LOG_LEVEL=0 -v $(pwd)/data:/io/data -v $(pwd)/plugins:/io/plugins --name qgis-server -d -p 8010:80 openquake/qgis-server:ltr
Adjust first the configuration in conf/nginx.conf
with the proper number of expected workers
and docker-compose.yml
with the path of data folder on the host.
Then:
$ docker-compose up -d --scale qgis-server=N
Where N is the number of expected QGIS server workers.
$(pwd)/data
must have the following structure:
data
|
|-- <project_name>
|-- <project_name>.qgs
oq-consolidate may helps you in exporting data suitable for QGIS server (consolidating project and layers).
$(pwd)/plugins
must have the following structure:
plugins
|
|-- <plugin_name>
|-- <plugin_code>.py
|-- metadata.txt
|-- __init__.py
Custom fonts are loaded into /usr/share/fonts
. fc-cache
is run when container is started.
The following variables can be customized during container deployment:
When SKIP_NGINX
is set to a different value than 0
or false
the embedded copy of Nginx will not be started and an external reverse proxy is then required to access the FastCGI QGIS backend.
SKIP_NGINX
: default is unset (do not skip Nginx startup)
QGIS_SERVER_LOG_LEVEL
: default is1
QGIS_SERVER_PARALLEL_RENDERING
: default istrue
QGIS_SERVER_MAX_THREADS
: default is2
QGIS_SERVER_WMS_MAX_WIDTH
: not set by defaultQGIS_SERVER_WMS_MAX_WIDTH
: not set by default
See QGIS server documentation for further details.
It is also possible to customized the ID of the user running QGIS server processes when it is required to write to host volumes (see notes):
QGIS_USER
: default isnginx
, a numerical id must be proivided
Example: docker run -e QGIS_USER=1000
or docker run -e QGIS_USER=$(id -u qgis)
GeoPackages do not play well with multiple processes having gpkg files opened in rw
mode. By default QGIS server processes lack write permission on /io/data
.
If it is required to let QGIS server write data to /io/data
make sure that either you are using a process-safe datastore (i.e. a Postgres backend) or you are
limiting horizontal scaling to one container only. QGIS server user can be customized via the QGIS_USER
environment variable.