Le géocodeur multi-thématique de la Géoplateforme est une API permettant d'interroger simultanément 3 grandes typologies de données :
- les adresses, voies et lieux-dits de la Base Adresse Nationale ;
- les points d’intérêt issus de la BD TOPO ;
- les parcelles cadastrales de la base Parcellaire Express.
Chacune de ces typologies est incarnée par un composant logiciel fortement couplé aux données que l’on appelera index
. Ces composants peuvent scaler indépendamment en fonction de la charge et de l’intérêt des utilisateurs pour telle ou telle thématique.
Ces composants prennent la forme d’un service HTTP.
Le géocodeur à proprement parler est une API dont la responsabilité est de valider la requête de l’utilisateur, d’interroger les indexes
concernés, et de retourner une réponse consolidée.
flowchart TB
C((Client)) -- "HTTP GET" --> G[api]
G -- "HTTP POST" --> IA[index-address]
G -- "HTTP POST" --> IP[index-parcel]
G -- "HTTP POST" --> IPO[index-poi]
linkStyle 0 stroke:#2ecd71,stroke-width:2px;
linkStyle 1 stroke:#2ecd71,stroke-width:2px;
linkStyle 2 stroke:#2ecd71,stroke-width:2px;
linkStyle 3 stroke:#2ecd71,stroke-width:2px;
3 fonctionnalités principales sont proposées par le service :
- la recherche textuelle ou géocodage simple (avec ou sans auto-complétion) ;
- la recherche spatiale ou géocodage inversé
- la recherche structurée (sur la base de critères multiples)
Chaque typologie de données ne dispose pas des mêmes fonctionnalités.
Index | Recherche textuelle | Recherche spatiale | Recherche structurée |
---|---|---|---|
address |
✅ | ✅ | ❌ |
poi |
✅ | ✅ | ❌ |
parcel |
❌ | ✅ | ✅ |
Pour la recherche textuelle, c'est le logiciel addok qui est utilisé. Il s'appuie sur une base de données Redis qui doit être localisée au plus prêt du moteur afin d’optimiser le temps de réponse.
Pour les recherches spatiales et structurée, le moteur fait partie du composant et s'appuie sur LMDB, une base de données clé-valeur embarquée haute performance, et sur une structure R-Tree implémentée grâce à la bibliothèque Flatbush.
flowchart TB
C((Client)) -- "HTTP GET" --> G[api]
G -- "HTTP POST" --> IA[index-address]
G -- "HTTP POST" --> IP[index-parcel]
G -- "HTTP POST" --> IPO[index-poi]
IA --> IAP{addok} --> IAR[(Redis)]
IA ---> IADB[(LMDB)]
IA ---> IART[(R-Tree)]
IP ---> IPDB[(LMDB)]
IP ---> IPRT[(R-Tree)]
IPO --> IPOP{addok} -->IPOR[(Redis)]
IPO ---> IPODB[(LMDB)]
IPO ---> IPORT[(R-Tree)]
subgraph " "
IA
IAP
IAR
IADB
IART
end
subgraph " "
IP
IPDB
IPRT
end
subgraph " "
IPO
IPOP
IPOR
IPODB
IPORT
end
linkStyle 0 stroke:#2ecd71,stroke-width:2px;
linkStyle 1 stroke:#2ecd71,stroke-width:2px;
linkStyle 2 stroke:#2ecd71,stroke-width:2px;
linkStyle 3 stroke:#2ecd71,stroke-width:2px;
Les composants index-address
, index-poi
et index-parcel
doivent être exécutés sur des machines disposant de processeurs rapides afin d’optimiser le temps de réponse.
Les données (en particulier les fichiers LMDB) devront être hébergées sur un disque SSD local, idéalement de type NVMe. En effet LMDB s’appuie sur une technologie appellée memory-mapping (MMAP) qui nécessite des temps de réponse très bas pour des accès aléatoires très fréquents. Une quantité non négligeable de mémoire vive sera aussi requise pour faire tenir les bases Redis et les structures R-Tree en RAM. Concernant LMDB, plus la quantité de RAM allouée sera importante, plus les pages mémoires seront fréquemment disponibles en RAM, et plus les performances seront bonnes.
Composant | Exigence CPU | Exigence RAM | Exigence disque |
---|---|---|---|
api |
Moyen à rapide | 1 Go | N/A |
index-address |
Rapide | >= 8 Go | 10 Go SSD |
index-poi |
Rapide | >= 8 Go | 6 Go SSD |
index-parcel |
Rapide | >= 5 Go | 40 Go SSD |