Requirements:
- Fresh Ubuntu 18.04 installation
- At least 16GB RAM for the installation phase. 32GB minimum is recommended for production.
- 450GB disk space (tested: 350GB disk space was not enough)
The full planet import should be done in a dedicated Hetzner server.
This package will:
-
Install Mapnik and tile serving plugins
-
Install Postgres 10 with Postgis extension
-
Install Mapnik & OSM data related tools
-
Download latest planet OSM data
-
Download necessary shapefiles required by openstreetmap-carto and our themes
All Mapnik stylesheets should be modified to reference to following files:
$ALVAR_MAP_SERVER_DATA_DIR/land-polygons-split-3857/land_polygons.shp
$ALVAR_MAP_SERVER_DATA_DIR/simplified-land-polygons-complete-3857/simplified_land_polygons.shp
$ALVAR_MAP_SERVER_DATA_DIR/ne_10m_admin_0_boundary_lines_land/ne_10m_admin_0_boundary_lines_land.shp
$ALVAR_MAP_SERVER_DATA_DIR/ne_110m_admin_0_countries/ne_110m_admin_0_countries.shp
Where
$ALVAR_MAP_SERVER_DATA_DIR
is the directory specified in install.sh variables. The default is/home/alvar/data
. Note that changing this may require to change this path in render/tile service code. -
Install Google Fonts
-
Simplify downloaded .shp files using
shapeindex
. -
Import latest OSM data to Postgis server using osm2psql. imposm3 was an alternative but openstreetmap style worked better.
WARNING: Docker container is unsafe for production, sudo commands without password are allowed
Requirements: At least 8GB RAM for Docker.
Run command below to start postgres with map data from Finland loaded:
docker-compose build
docker-compose up postgres
Note: you need to comment or lines or rename .env
with docker-compose version <1.26.0. See docker/compose#6511.
docker-compose down && docker-compose rm && docker system prune
docker-compose build --no-cache
docker-compose up postgres
The process has been automated to a CI task. See .circleci/config.yml.
Idea is that we have two servers, which are switched between "production" and "reserve". We automatically re-install the server and deploy new version to production with Circle CI cron trigger. The process is:
- Order a reinstall to the reserve server via Hetzner API
- Wait until server is responsive
- Initial setup of the machine
- Copy this repo into the server and run install.sh inside a screen
- Wait for the server installation to finish
- Restrict security after installation (sudo needs password etc)
- Reboot server to verify all services start after reboot
- Wait until server is responsive
- Run snapshot tool to verify differences between production and new installation
- Warm tile caches inside the server
- Wait for developer approval
- If approval is give, point the freshly installed server to tile-api.alvarcarto.com
- Invalidate everything from CloudFlare cache
If automatic install has failed, the previous production server can be brought back
live by launching switch_production
job in Circle CI:
source .env
bash .circleci/launch-switch-production.sh
This script will switch the DNS entries back as they were before deployment.
Diagram tries to capture the process in an overview. See Circle CI config for exact details.
Open the PNG in draw.io to edit
nvm use 10
pm2 stop all
pm2 delete all
cd $HOME/alvarcarto-map-server
pm2 start confs/pm2.json
# Check that everything went allright
pm2 logs --lines 1000
# Then save the startup:
sudo env PATH=$PATH:/home/alvar/.nvm/versions/node/v10.20.1/bin /home/alvar/.nvm/versions/node/v10.20.1/lib/node_modules/pm2/bin/pm2 startup systemd -u alvar --hp /home/alvar
pm2 save
HTTP Access logs:
cat /var/log/access.log
Caddy errors:
sudo cat /var/log/syslog
or sudo journalctl -u caddy | tail -n 300
Edit Caddyfile:
sudo nano /etc/caddy/Caddyfile
sudo systemctl restart caddy
Edit /etc/systemd/system/caddy.service
sudo nano /etc/systemd/system/caddy.service
sudo systemctl daemon-reload
sudo systemctl restart caddy
-
Mapnik project timeline is a mess, so we are stuck at 3.0.x version.
No release plan for 3.1 mapnik/mapnik#3747
3.0 -> 3.1 upgrade docs are not done: mapnik/mapnik#3919
Incomplete upgrade docs: https://github.com/mapnik/mapnik/wiki/API-changes-between-v3.0-and-v3.1
Nothing new at CHANGELOG either: https://github.com/mapnik/mapnik/blob/master/CHANGELOG.md
Milestones only have 4.0.0, 3.1 seems to have disappeared: https://github.com/mapnik/mapnik/milestones
-
Since the Mapnik 3.0 -> 3.1 upgrade path is undocumented, we don't know what to change in the Mapnik style XML.
The style we are based on supports only Mapnik 3.0.22: gravitystorm/openstreetmap-carto#4046
-
node-mapnik@3.x is required for Mapnik 3.0.x, node-mapnik@4.x version requires Mapnik 3.1
-
node-mapnik@3.x doesn't support Node 8+ versions, so we are stuck at Node 8
-
pm2 doesn't support different node versions when clustering, so we should run all our services at node version 8..
-
The only solution seems to be to do clustering manually in render and tile apis (the services that require node 8)
First it may fail to: Postgis Plugin: FATAL: role "alvar" does not exist
.
Fix:
sudo su postgres
psql
CREATE USER alvar;
ALTER USER alvar CREATEDB;
Then it may fail to: ERROR (Postgis Plugin: FATAL: database "template_postgis" does not exist
.
Fix, create postgis_template:
sudo su postgres
createdb template_postgis -E UTF-8
createlang plpgsql template_postgis # may say this is already done
psql -d template_postgis -f /usr/share/postgresql/9.5/contrib/postgis-2.2/postgis.sql
psql -d template_postgis -f /usr/share/postgresql/9.5/contrib/postgis-2.2/spatial_ref_sys.sql
psql
UPDATE pg_database SET datistemplate = TRUE WHERE datname = 'template_postgis';
Or read more how to create template_postgis: https://wiki.archlinux.org/index.php/PostGIS
https://askubuntu.com/questions/574569/apt-get-stuck-at-0-connecting-to-us-archive-ubuntu-com
sudo nano /etc/gai.conf
and change line ~54 to uncomment the following:
precedence ::ffff:0:0/96 100
Note: NOT THIS LINE: precedence ::ffff:0:0/96 10