5.13. Procédure d’exploitation suite a la création ou la modification d’une ontologie

Au préalable à la création ou à la modification d’une ontologie, les index Elasticsearch correspondant aux ontologies doivent être créés ou mis à jour.

5.13.1. Création d’une ontologie

Suite à la création d’une nouvelle ontologie les index Elasticsearch doivent être mis à jour selon la procédure suivante:

  • Dans le cas d’une création, il suffit de créer un nouveau mapping dans les index concernés.

Ex : Ajout d’une propriété Licence dans tous les index unit (unit* signifiant tous les index unit unit_0, unit_1 etc …)

curl -XPUT "http://localhost:9200/unit*/_mapping/typeunique?update_all_types" -d'
{
      "properties": {
        "Licence": {
          "type": "text"
        }
      }
}'

Pour verifier sur un ou tous les index unit :

curl -XGET "http://localhost:9200/unit_0/_mapping/?pretty=true"
curl -XGET "http://localhost:9200/unit*/_mapping/?pretty=true"

5.13.2. Changement de type d’une ontologie existante

Dans ce cas, le changement de type dans elasticsearch n’est pas possible. Il faut créer un nouvel index ES avec un nouveau mapping et reindexer l’ancien index dans ce dernier.

On récupère d’abord l’ancien index

curl -XGET 'localhost:9200/unit_1/_mapping?pretty=true'

On créé un fichier json et on y copie les données obtenues ( ne conserver que la balise « mappings » : { …} et son contenu). On modifie le mapping en changeant le type des propriétés choisies. On créé un nouvel index on lui passant en paramètre le fichier du nouveau mapping .

curl -XPUT "http://localhost:9200/new_unit_1" -H 'Content-Type: application/json' -d  @newmapping.json

Verifier l’index :

curl -XGET 'localhost:9200/new_unit_1/_mapping/'

On reindexe unit_1 vers le nouvel index new_unit_1

curl -XPOST 'localhost:9200/_reindex' -H 'Content-Type:application/json' -d '{
        "source" : {
                "index" : "unit_1"
        },
        "dest" : {
                "index" : "new_unit_1",
                "version_type": "external"
        }
}'

On efface l’alias de l’ancien index unit_1

curl -XDELETE 'localhost:9200/unit_1/_alias/unit_1'

et on l’affecte au nouvel index new_unit_1

curl -XPUT 'localhost:9200/new_unit_1/_alias/unit_1'

Avertissement

les index elasticsearch de VITAM sont créés par tenant. Il faudra refaire l’opération ci-dessus pour chaque tenant.

Avertissement

en cas de reindexation des index elasticsearch par le service REST de VITAM, les données sont réindexées suivant le mapping initial. Les nouveaux mappings ne seront donc pas pris en compte. Ce comportement sera modifié dans le futur.