Ответ 1
Запрос на обновление получает источник от Elasticsearch, модифицирует его и индексирует обратно в Elasticsearch. Если у вас уже есть копия документа, использовать обновление не имеет смысла. Как правило, было бы быстрее просто индексировать новую версию. Однако, если у вас нет готового документа, но вы знаете, какие изменения вы хотите внести в документ, может быть более эффективно использовать обновление.
Например, если у меня нет копии автомобильного документа, но я хочу добавить нового создателя, я могу сделать что-то вроде этого:
curl -XDELETE localhost:9200/test
curl -XPUT localhost:9200/test -d '{
"settings": {
"index.number_of_shards": 1,
"index.number_of_replicas": 0
},
"mappings": {
"car": {
"properties": {
"creators" : {
"type": "nested",
"properties": {
"name": {"type":"string"}
}
}
}
}
}
}
'
curl -XPOST localhost:9200/test/car/1 -d '{
"creators": [{
"name": "Steve"
}]
}
'
echo
curl -XPOST localhost:9200/test/car/1/_update -d '{
"script" : "ctx._source.creators += new_creator",
"params" : {
"new_creator" : {"name": "John"}
}
}'
echo
curl "localhost:9200/test/car/1?pretty=true"
echo
В скрипте обновления ctx
есть специальная переменная, которая позволяет вам получить доступ к источнику объекта, который вы хотите обновить. ctx._source
является записываемой версией источника. Вы можете изменить этот документ в сценарии, и измененный источник будет сохранен как новая версия документа.