A dynamic tile server for geologic maps
- Python-based instead of Node-based
- A "dynamic tiler" based heavily on TimVT
- Uses a PostgreSQL caching backend (this is the primary simplification)
- Uses Mapnik for legacy image-tile generation
- Optionally, can use Varnish as a "L2" API cache
This module depends on tile utilitiesUW-Macrostrat/postgis-tile-utils. This dependency is packaged as a git submodule. To install it, run:
git submodule update --init
The module can be run locally using Poetry, but there may be problems with Mapnik. We're working on simplifying this process and making Mapnik optional.
To install in Docker (preferred), build the image:
docker build -t macrostrat/tileserver .
Then run it with the appropriate environment variables and port bindings:
docker run macrostrat/tileserver
-e POSTGRES_DB=postgresql://user:password@db.server:5432
-p 8000:8000
To serve tile layers, the fixtures (housed in macrostrat_tileserver/fixtures
) must be created on the database.
There is a bundled tileserver
CLI that will create the layers. In Docker:
docker run macrostrat/tileserver
-e POSTGRES_DB=postgresql://user:password@db.server:5432
tileserver create-fixtures
Or in the running docker container:
docker exec tileserver create-fixtures
Once the tileserver is running, you should be able to access docs:
curl localhost:8000/docs
And tiles:
curl localhost:8000//{z}/{x}/{y}
Macrostrat core layers:
- https://localhost:8000/carto-slim/{z}/{x}/{y}
- https://localhost:8000/carto/{z}/{x}/{y}
- https://localhost:8000/map/{z}/{x}/{y}?source_id=<source_id>
- https://localhost:8000/all-maps/{z}/{x}/{y} (for development purposes only)
- New layers can be defined using SQL or PL/PGSQL functions.
- Currently, layers must be initialized by editing the
macrostrat_tileserver/main.py
file to add the appropriate initialization function. This will be improved in the future.
Testing is done with pytest
. To run the tests, use:
make test
.
To omit legacy raster tests, use
make test-dev
.