Skip to content

Latest commit

 

History

History
103 lines (82 loc) · 4.5 KB

architecture.md

File metadata and controls

103 lines (82 loc) · 4.5 KB

Architecture du service

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.

Schéma simplifié

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;
Loading

Fonctionnalités et index

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.

Schéma détaillé

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;
Loading

Exigences techniques

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.

⚠️ On évitera à tout prix d’héberger les fichiers LMDB sur des stockages distants, à moins d’utiliser des technologies de pointe garantissant un grand nombre d’IOPS ainsi que des temps de réponse extrèmement bas.

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