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.