2020-06-20 04:48:07 +03:00
|
|
|
# Importing the Database
|
2018-08-24 00:12:10 +03:00
|
|
|
|
2016-06-07 01:17:15 +03:00
|
|
|
The following instructions explain how to create a Nominatim database
|
2021-02-01 19:27:01 +03:00
|
|
|
from an OSM planet file. It is assumed that you have already successfully
|
2021-02-10 13:15:21 +03:00
|
|
|
installed the Nominatim software itself and the `nominatim` tool can be found
|
|
|
|
in your `PATH`. If this is not the case, return to the
|
2021-02-01 19:27:01 +03:00
|
|
|
[installation page](Installation.md).
|
2016-06-07 01:17:15 +03:00
|
|
|
|
2021-02-01 19:27:01 +03:00
|
|
|
## Creating the project directory
|
2018-01-15 01:43:15 +03:00
|
|
|
|
2021-02-01 19:27:01 +03:00
|
|
|
Before you start the import, you should create a project directory for your
|
|
|
|
new database installation. This directory receives all data that is related
|
|
|
|
to a single Nominatim setup: configuration, extra data, etc. Create a project
|
2021-02-10 13:15:21 +03:00
|
|
|
directory apart from the Nominatim software and change into the directory:
|
2021-02-01 19:27:01 +03:00
|
|
|
|
|
|
|
```
|
|
|
|
mkdir ~/nominatim-planet
|
2021-02-10 13:15:21 +03:00
|
|
|
cd ~/nominatim-planet
|
2021-02-01 19:27:01 +03:00
|
|
|
```
|
|
|
|
|
|
|
|
In the following, we refer to the project directory as `$PROJECT_DIR`. To be
|
|
|
|
able to copy&paste instructions, you can export the appropriate variable:
|
|
|
|
|
|
|
|
```
|
|
|
|
export PROJECT_DIR=~/nominatim-planet
|
|
|
|
```
|
|
|
|
|
|
|
|
The Nominatim tool assumes per default that the current working directory is
|
|
|
|
the project directory but you may explicitly state a different directory using
|
2021-02-10 13:15:21 +03:00
|
|
|
the `--project-dir` parameter. The following instructions assume that you run
|
|
|
|
all commands from the project directory.
|
2021-02-02 12:51:03 +03:00
|
|
|
|
2021-02-01 19:27:01 +03:00
|
|
|
!!! tip "Migration Tip"
|
|
|
|
|
|
|
|
Nominatim used to be run directly from the build directory until version 3.6.
|
|
|
|
Essentially, the build directory functioned as the project directory
|
|
|
|
for the database installation. This setup still works and can be useful for
|
|
|
|
development purposes. It is not recommended anymore for production setups.
|
|
|
|
Create a project directory that is separate from the Nominatim software.
|
|
|
|
|
|
|
|
### Configuration setup in `.env`
|
|
|
|
|
|
|
|
The Nominatim server can be customized via a `.env` in the project directory.
|
2021-01-14 20:31:18 +03:00
|
|
|
This is a file in [dotenv](https://github.com/theskumar/python-dotenv) format
|
2020-12-20 14:09:27 +03:00
|
|
|
which looks the same as variable settings in a standard shell environment.
|
|
|
|
You can also set the same configuration via environment variables. All
|
|
|
|
settings have a `NOMINATIM_` prefix to avoid conflicts with other environment
|
|
|
|
variables.
|
2016-06-07 01:17:15 +03:00
|
|
|
|
|
|
|
There are lots of configuration settings you can tweak. Have a look
|
2020-12-20 14:09:27 +03:00
|
|
|
at `settings/env.default` for a full list. Most should have a sensible default.
|
2018-01-15 01:43:15 +03:00
|
|
|
|
2018-08-24 00:12:10 +03:00
|
|
|
#### Flatnode files
|
2018-01-15 01:43:15 +03:00
|
|
|
|
2016-06-07 01:17:15 +03:00
|
|
|
If you plan to import a large dataset (e.g. Europe, North America, planet),
|
|
|
|
you should also enable flatnode storage of node locations. With this
|
|
|
|
setting enabled, node coordinates are stored in a simple file instead
|
|
|
|
of the database. This will save you import time and disk storage.
|
2020-12-20 14:09:27 +03:00
|
|
|
Add to your `.env`:
|
2016-06-07 01:17:15 +03:00
|
|
|
|
2020-12-20 14:09:27 +03:00
|
|
|
NOMINATIM_FLATNODE_FILE="/path/to/flatnode.file"
|
2016-06-07 01:17:15 +03:00
|
|
|
|
2016-08-10 23:02:10 +03:00
|
|
|
Replace the second part with a suitable path on your system and make sure
|
2020-12-06 19:28:33 +03:00
|
|
|
the directory exists. There should be at least 75GB of free space.
|
2016-06-07 01:17:15 +03:00
|
|
|
|
2018-08-24 00:12:10 +03:00
|
|
|
## Downloading additional data
|
2016-06-07 01:17:15 +03:00
|
|
|
|
2019-11-01 12:07:04 +03:00
|
|
|
### Wikipedia/Wikidata rankings
|
2016-06-07 01:17:15 +03:00
|
|
|
|
|
|
|
Wikipedia can be used as an optional auxiliary data source to help indicate
|
2019-05-21 14:55:16 +03:00
|
|
|
the importance of OSM features. Nominatim will work without this information
|
2016-06-07 01:17:15 +03:00
|
|
|
but it will improve the quality of the results if this is installed.
|
2021-02-01 19:27:01 +03:00
|
|
|
This data is available as a binary download. Put it into your project directory:
|
2016-06-07 01:17:15 +03:00
|
|
|
|
2021-02-01 19:27:01 +03:00
|
|
|
cd $PROJECT_DIR
|
2019-11-17 12:09:31 +03:00
|
|
|
wget https://www.nominatim.org/data/wikimedia-importance.sql.gz
|
2016-06-07 01:17:15 +03:00
|
|
|
|
2020-12-06 19:28:33 +03:00
|
|
|
The file is about 400MB and adds around 4GB to the Nominatim database.
|
2016-06-07 01:17:15 +03:00
|
|
|
|
2020-01-22 13:44:05 +03:00
|
|
|
!!! tip
|
|
|
|
If you forgot to download the wikipedia rankings, you can also add
|
|
|
|
importances after the import. Download the files, then run
|
2021-02-01 19:27:01 +03:00
|
|
|
`nominatim refresh --wiki-data --importance`. Updating importances for
|
|
|
|
a planet can take a couple of hours.
|
2017-07-15 04:52:54 +03:00
|
|
|
|
2019-07-22 02:11:06 +03:00
|
|
|
### Great Britain, USA postcodes
|
2016-06-07 01:17:15 +03:00
|
|
|
|
2019-07-22 02:11:06 +03:00
|
|
|
Nominatim can use postcodes from an external source to improve searches that
|
2021-02-01 19:27:01 +03:00
|
|
|
involve a GB or US postcode. This data can be optionally downloaded into the
|
|
|
|
project directory:
|
2016-06-07 01:17:15 +03:00
|
|
|
|
2021-02-01 19:27:01 +03:00
|
|
|
cd $PROJECT_DIR
|
2018-01-11 01:21:21 +03:00
|
|
|
wget https://www.nominatim.org/data/gb_postcode_data.sql.gz
|
2019-07-22 02:11:06 +03:00
|
|
|
wget https://www.nominatim.org/data/us_postcode_data.sql.gz
|
2016-06-07 01:17:15 +03:00
|
|
|
|
2020-12-06 19:28:33 +03:00
|
|
|
## Choosing the data to import
|
2018-12-05 00:22:19 +03:00
|
|
|
|
2019-01-03 23:08:38 +03:00
|
|
|
In its default setup Nominatim is configured to import the full OSM data
|
2018-12-05 00:22:19 +03:00
|
|
|
set for the entire planet. Such a setup requires a powerful machine with
|
2020-12-08 10:57:46 +03:00
|
|
|
at least 64GB of RAM and around 900GB of SSD hard disks. Depending on your
|
2018-12-05 00:22:19 +03:00
|
|
|
use case there are various ways to reduce the amount of data imported. This
|
|
|
|
section discusses these methods. They can also be combined.
|
|
|
|
|
|
|
|
### Using an extract
|
|
|
|
|
2020-12-06 19:28:33 +03:00
|
|
|
If you only need geocoding for a smaller region, then precomputed OSM extracts
|
2019-01-03 23:08:38 +03:00
|
|
|
are a good way to reduce the database size and import time.
|
|
|
|
[Geofabrik](https://download.geofabrik.de) offers extracts for most countries.
|
|
|
|
They even have daily updates which can be used with the update process described
|
2020-12-06 19:28:33 +03:00
|
|
|
[in the next section](../Update). There are also
|
2019-01-03 23:08:38 +03:00
|
|
|
[other providers for extracts](https://wiki.openstreetmap.org/wiki/Planet.osm#Downloading).
|
2018-12-05 00:22:19 +03:00
|
|
|
|
2019-01-03 23:08:38 +03:00
|
|
|
Please be aware that some extracts are not cut exactly along the country
|
|
|
|
boundaries. As a result some parts of the boundary may be missing which means
|
2019-05-21 14:55:16 +03:00
|
|
|
that Nominatim cannot compute the areas for some administrative areas.
|
2019-01-03 23:08:38 +03:00
|
|
|
|
|
|
|
### Dropping Data Required for Dynamic Updates
|
|
|
|
|
|
|
|
About half of the data in Nominatim's database is not really used for serving
|
|
|
|
the API. It is only there to allow the data to be updated from the latest
|
|
|
|
changes from OSM. For many uses these dynamic updates are not really required.
|
2021-01-14 14:04:08 +03:00
|
|
|
If you don't plan to apply updates, you can run the import with the
|
|
|
|
`--no-updates` parameter. This will drop the dynamic part of the database as
|
|
|
|
soon as it is not required anymore.
|
|
|
|
|
|
|
|
You can also drop the dynamic part later using the following command:
|
2019-01-03 23:08:38 +03:00
|
|
|
|
|
|
|
```
|
2021-02-01 19:27:01 +03:00
|
|
|
nominatim freeze
|
2019-01-03 23:08:38 +03:00
|
|
|
```
|
|
|
|
|
|
|
|
Note that you still need to provide for sufficient disk space for the initial
|
|
|
|
import. So this option is particularly interesting if you plan to transfer the
|
|
|
|
database or reuse the space later.
|
2018-12-05 00:22:19 +03:00
|
|
|
|
|
|
|
### Reverse-only Imports
|
|
|
|
|
|
|
|
If you only want to use the Nominatim database for reverse lookups or
|
|
|
|
if you plan to use the installation only for exports to a
|
2019-05-21 14:55:16 +03:00
|
|
|
[photon](https://photon.komoot.de/) database, then you can set up a database
|
2018-12-05 00:22:19 +03:00
|
|
|
without search indexes. Add `--reverse-only` to your setup command above.
|
|
|
|
|
|
|
|
This saves about 5% of disk space.
|
|
|
|
|
|
|
|
### Filtering Imported Data
|
|
|
|
|
|
|
|
Nominatim normally sets up a full search database containing administrative
|
|
|
|
boundaries, places, streets, addresses and POI data. There are also other
|
|
|
|
import styles available which only read selected data:
|
|
|
|
|
2019-01-03 23:08:38 +03:00
|
|
|
* **settings/import-admin.style**
|
|
|
|
Only import administrative boundaries and places.
|
|
|
|
* **settings/import-street.style**
|
|
|
|
Like the admin style but also adds streets.
|
|
|
|
* **settings/import-address.style**
|
|
|
|
Import all data necessary to compute addresses down to house number level.
|
|
|
|
* **settings/import-full.style**
|
|
|
|
Default style that also includes points of interest.
|
2019-12-29 13:47:10 +03:00
|
|
|
* **settings/import-extratags.style**
|
|
|
|
Like the full style but also adds most of the OSM tags into the extratags
|
|
|
|
column.
|
2019-01-03 23:08:38 +03:00
|
|
|
|
2020-12-20 14:09:27 +03:00
|
|
|
The style can be changed with the configuration `NOMINATIM_IMPORT_STYLE`.
|
2019-01-03 23:08:38 +03:00
|
|
|
|
2019-05-21 14:55:16 +03:00
|
|
|
To give you an idea of the impact of using the different styles, the table
|
2019-01-03 23:08:38 +03:00
|
|
|
below gives rough estimates of the final database size after import of a
|
2020-12-06 19:28:33 +03:00
|
|
|
2020 planet and after using the `--drop` option. It also shows the time
|
|
|
|
needed for the import on a machine with 64GB RAM, 4 CPUS and NVME disks.
|
|
|
|
Note that the given sizes are just an estimate meant for comparison of
|
|
|
|
style requirements. Your planet import is likely to be larger as the
|
|
|
|
OSM data grows with time.
|
2019-01-03 23:08:38 +03:00
|
|
|
|
|
|
|
style | Import time | DB size | after drop
|
|
|
|
----------|--------------|------------|------------
|
2020-12-06 19:28:33 +03:00
|
|
|
admin | 4h | 215 GB | 20 GB
|
2020-12-08 10:57:46 +03:00
|
|
|
street | 22h | 440 GB | 185 GB
|
|
|
|
address | 36h | 545 GB | 260 GB
|
|
|
|
full | 54h | 640 GB | 330 GB
|
|
|
|
extratags | 54h | 650 GB | 340 GB
|
2018-12-05 00:22:19 +03:00
|
|
|
|
2020-12-06 19:28:33 +03:00
|
|
|
You can also customize the styles further.
|
|
|
|
A [description of the style format](../develop/Import.md#configuring-the-import)
|
|
|
|
can be found in the development section.
|
2016-06-07 01:17:15 +03:00
|
|
|
|
2018-08-24 00:12:10 +03:00
|
|
|
## Initial import of the data
|
2016-06-07 01:17:15 +03:00
|
|
|
|
2020-01-22 13:44:05 +03:00
|
|
|
!!! danger "Important"
|
|
|
|
First try the import with a small extract, for example from
|
|
|
|
[Geofabrik](https://download.geofabrik.de).
|
2016-06-07 01:17:15 +03:00
|
|
|
|
2020-12-06 19:28:33 +03:00
|
|
|
Download the data to import. Then issue the following command
|
|
|
|
from the **build directory** to start the import:
|
2016-06-07 01:17:15 +03:00
|
|
|
|
2018-01-15 01:43:15 +03:00
|
|
|
```sh
|
2021-02-01 19:27:01 +03:00
|
|
|
nominatim import --osm-file <data file> 2>&1 | tee setup.log
|
2018-01-15 01:43:15 +03:00
|
|
|
```
|
2016-06-07 01:17:15 +03:00
|
|
|
|
2020-12-06 19:28:33 +03:00
|
|
|
### Notes on full planet imports
|
|
|
|
|
|
|
|
Even on a perfectly configured machine
|
|
|
|
the import of a full planet takes around 2 days. Once you see messages
|
2019-11-24 12:31:34 +03:00
|
|
|
with `Rank .. ETA` appear, the indexing process has started. This part takes
|
|
|
|
the most time. There are 30 ranks to process. Rank 26 and 30 are the most complex.
|
|
|
|
They take each about a third of the total import time. If you have not reached
|
|
|
|
rank 26 after two days of import, it is worth revisiting your system
|
|
|
|
configuration as it may not be optimal for the import.
|
|
|
|
|
|
|
|
### Notes on memory usage
|
|
|
|
|
2020-12-06 19:28:33 +03:00
|
|
|
In the first step of the import Nominatim uses [osm2pgsql](https://osm2pgsql.org)
|
|
|
|
to load the OSM data into the PostgreSQL database. This step is very demanding
|
|
|
|
in terms of RAM usage. osm2pgsql and PostgreSQL are running in parallel at
|
|
|
|
this point. PostgreSQL blocks at least the part of RAM that has been configured
|
|
|
|
with the `shared_buffers` parameter during
|
|
|
|
[PostgreSQL tuning](Installation#postgresql-tuning)
|
2019-11-24 12:31:34 +03:00
|
|
|
and needs some memory on top of that. osm2pgsql needs at least 2GB of RAM for
|
|
|
|
its internal data structures, potentially more when it has to process very large
|
|
|
|
relations. In addition it needs to maintain a cache for node locations. The size
|
|
|
|
of this cache can be configured with the parameter `--osm2pgsql-cache`.
|
|
|
|
|
|
|
|
When importing with a flatnode file, it is best to disable the node cache
|
|
|
|
completely and leave the memory for the flatnode file. Nominatim will do this
|
|
|
|
by default, so you do not need to configure anything in this case.
|
|
|
|
|
|
|
|
For imports without a flatnode file, set `--osm2pgsql-cache` approximately to
|
2020-12-06 19:28:33 +03:00
|
|
|
the size of the OSM pbf file you are importing. The size needs to be given in
|
|
|
|
MB. Make sure you leave enough RAM for PostgreSQL and osm2pgsql as mentioned
|
|
|
|
above. If the system starts swapping or you are getting out-of-memory errors,
|
|
|
|
reduce the cache size or even consider using a flatnode file.
|
2019-11-24 12:31:34 +03:00
|
|
|
|
2021-02-03 18:17:46 +03:00
|
|
|
|
|
|
|
### Testing the installation
|
2019-12-23 23:25:06 +03:00
|
|
|
|
|
|
|
Run this script to verify all required tables and indices got created successfully.
|
|
|
|
|
|
|
|
```sh
|
2021-02-10 23:55:04 +03:00
|
|
|
nominatim admin --check-database
|
2019-12-23 23:25:06 +03:00
|
|
|
```
|
|
|
|
|
2020-09-16 00:51:25 +03:00
|
|
|
Now you can try out your installation by running:
|
|
|
|
|
|
|
|
```sh
|
2021-02-03 18:17:46 +03:00
|
|
|
nominatim serve
|
2020-09-16 00:51:25 +03:00
|
|
|
```
|
|
|
|
|
|
|
|
This runs a small test server normally used for development. You can use it
|
|
|
|
to verify that your installation is working. Go to
|
|
|
|
`http://localhost:8088/status.php` and you should see the message `OK`.
|
|
|
|
You can also run a search query, e.g. `http://localhost:8088/search.php?q=Berlin`.
|
|
|
|
|
|
|
|
To run Nominatim via webservers like Apache or nginx, please read the
|
|
|
|
[Deployment chapter](Deployment.md).
|
|
|
|
|
2019-11-24 12:31:34 +03:00
|
|
|
## Tuning the database
|
|
|
|
|
|
|
|
Accurate word frequency information for search terms helps PostgreSQL's query
|
|
|
|
planner to make the right decisions. Recomputing them can improve the performance
|
|
|
|
of forward geocoding in particular under high load. To recompute word counts run:
|
2017-12-16 18:13:39 +03:00
|
|
|
|
2018-01-15 01:43:15 +03:00
|
|
|
```sh
|
2021-02-01 19:27:01 +03:00
|
|
|
nominatim refresh --word-counts
|
2018-01-15 01:43:15 +03:00
|
|
|
```
|
2017-12-16 18:13:39 +03:00
|
|
|
|
|
|
|
This will take a couple of hours for a full planet installation. You can
|
|
|
|
also defer that step to a later point in time when you realise that
|
|
|
|
performance becomes an issue. Just make sure that updates are stopped before
|
|
|
|
running this function.
|
|
|
|
|
2018-01-15 01:43:15 +03:00
|
|
|
If you want to be able to search for places by their type through
|
|
|
|
[special key phrases](https://wiki.openstreetmap.org/wiki/Nominatim/Special_Phrases)
|
2021-03-20 20:55:08 +03:00
|
|
|
you also need to import these key phrases like this:
|
2016-06-07 01:17:15 +03:00
|
|
|
|
2021-03-26 03:57:51 +03:00
|
|
|
nominatim special-phrases --import-from-wiki
|
2016-06-07 01:17:15 +03:00
|
|
|
|
2019-11-24 12:31:34 +03:00
|
|
|
Note that this command downloads the phrases from the wiki link above. You
|
|
|
|
need internet access for the step.
|
2018-01-15 01:43:15 +03:00
|
|
|
|
2016-06-07 23:47:57 +03:00
|
|
|
|
2018-08-24 00:12:10 +03:00
|
|
|
## Installing Tiger housenumber data for the US
|
2016-06-07 23:47:57 +03:00
|
|
|
|
2020-03-27 17:50:05 +03:00
|
|
|
Nominatim is able to use the official [TIGER](https://www.census.gov/geographies/mapping-files/time-series/geo/tiger-line-file.html)
|
2018-09-28 21:17:02 +03:00
|
|
|
address set to complement the OSM house number data in the US. You can add
|
|
|
|
TIGER data to your own Nominatim instance by following these steps. The
|
|
|
|
entire US adds about 10GB to your database.
|
2016-06-07 23:47:57 +03:00
|
|
|
|
2021-02-03 18:42:31 +03:00
|
|
|
1. Get preprocessed TIGER 2020 data and unpack it into your project
|
2021-02-01 19:27:01 +03:00
|
|
|
directory:
|
2016-06-07 23:47:57 +03:00
|
|
|
|
2021-02-01 19:27:01 +03:00
|
|
|
cd $PROJECT_DIR
|
2021-02-03 18:42:31 +03:00
|
|
|
wget https://nominatim.org/data/tiger2020-nominatim-preprocessed.tar.gz
|
|
|
|
tar xf tiger2020-nominatim-preprocessed.tar.gz
|
2018-09-28 21:17:02 +03:00
|
|
|
|
2019-05-21 14:55:16 +03:00
|
|
|
2. Import the data into your Nominatim database:
|
2016-06-07 23:47:57 +03:00
|
|
|
|
2021-02-01 19:27:01 +03:00
|
|
|
nominatim add-data --tiger-data tiger
|
2016-06-07 23:47:57 +03:00
|
|
|
|
2020-12-20 14:09:27 +03:00
|
|
|
3. Enable use of the Tiger data in your `.env` by adding:
|
2018-01-15 01:43:15 +03:00
|
|
|
|
2021-02-01 19:27:01 +03:00
|
|
|
echo NOMINATIM_USE_US_TIGER_DATA=yes >> .env
|
2016-06-07 23:47:57 +03:00
|
|
|
|
2018-09-28 21:17:02 +03:00
|
|
|
4. Apply the new settings:
|
2016-06-07 23:47:57 +03:00
|
|
|
|
2021-02-01 19:27:01 +03:00
|
|
|
nominatim refresh --functions
|
2016-06-07 23:47:57 +03:00
|
|
|
|
|
|
|
|
2020-09-16 00:51:25 +03:00
|
|
|
See the [developer's guide](../develop/data-sources.md#us-census-tiger) for more
|
|
|
|
information on how the data got preprocessed.
|
|
|
|
|