The main Mapfile should be in /etc/mapserver/
.
You can use the image as is and mount a volume in /etc/mapserver/
to customize it.
Only tags for minor releases exist, not tag for bug fixes.
If the container is run as root, apache listens on port 80
. If it is run as
another user, it listens on port 8080
.
You can use the following environment variables (when starting the container) to tune it:
MS_DEBUGLEVEL
: The debug level0
=off5
=verboseMS_ERRORFILE
: If you want the debug to something other than STDOUTMAX_REQUESTS_PER_PROCESS
: To work around memory leaks (defaults to1000
)MIN_PROCESSES
: The minimum number of fcgi processes to keep (defaults to1
)MAX_PROCESSES
: The maximum number of fcgi processes to keep (defaults to5
)MAPSERVER_CATCH_SEGV
: Set to1
to have the stacktraces in case of crashMAPSERVER_BASE_PATH
: To setup which is the base path of mapserver (defaults to/
)BUSY_TIMEOUT
: The maximum time limit for request handling (defaults to300
)IDLE_TIMEOUT
: Application processes which have not handled a request for this period of time will be terminated (defaults to300
)IO_TIMEOUT
: The maximum period of time the module will wait while trying to read from or write to a FastCGI application (defaults to40
)APACHE_LIMIT_REQUEST_LINE
: The maximum size of the HTTP request line in bytes (defaults to8190
)
This section is for if you would like to use more than one Mapfile, or use a Mapfile
that isn't /etc/mapserver/mapserver.map
.
In this example we have two Mapfiles we want to use that both reference data in
different directories. My Mapfiles are wms.map
and wfs.map
and are located
in /mapfiles/
on the host, and the data for these Mapfiles is located in the
host in the directory /mapdata/wms
and /mapdata/wfs
.
docker run -d \
--restart=unless-stopped \
--volume=/mapfiles/wms.map/:/etc/mapserver/wms.map:ro \
--volume=/mapfiles/wfs.map/:/etc/mapserver/wfs.map:ro \
--volume=/mapdata/wms/:/mapdata/wms/:ro \
--volume=/mapdata/wfs/:/mapdata/wfs/:ro \
camptocamp/mapserver
For accessing maps for the WFS service add map=/etc/mapserver/wfs.map
to
your query string. Here is the URL for a GetCapabilities
request:
http://your.mapserver.host/?map=/etc/mapserver/wfs.map&service=WFS&request=GetCapabilities
Similarly, for accessing maps for the WMS service add map=/etc/mapserver/wms.map
to
your query string.
This image can be used to serve OGC API Features and OGC API Tiles.
Some details about the configuration.
You should define the OGCAPI_HTML_TEMPLATE_DIRECTORY
generally to /usr/local/share/mapserver/ogcapi/templates/html-bootstrap4/
.
If you want to serve MapServer on a subpath, you can use the MAPSERVER_BASE_PATH
with the subpath.
If you want to serve multiple MapFiles you should have a Config file with the MAPS
directive.
In the Mapfile metadata you should have the following metadata (MAP
.WEB
.METADATA
):
"ows_enable_request"
or"oga_enable_request"
set to"*"
."oga_onlineresource"
set to the URL (or path) of the OGC API.
The landing page is served by on http://<host>:<port>/<base_path>/<map_name>/ogcapi
.
- The default url path is now at "/" (not "/mapserver" or others anymore).
- The default "APACHE_RUN_DIR" is now "/tmp/apache2" be sure this folder exists or/and can be created.
confd
andentrypoints.d
are removed, you should replace it by avolume_from
a configuration image or an init container.- The
MS_MAPFILE
has no more default value, was/etc/mapserver/mapserver.map
.
Install the pre-commit hooks:
pip install pre-commit
pre-commit install --allow-missing-config