2015-03-06 2 views
2

Я работаю над ElasticSearch в проекте scala. Я использую elastic4s как клиент. Я пытаюсь добавить элементы в документ, начиная с итератора один за другим.Elasticsearch Сценарии для добавления элемента в массив

while (iterator.hasNext) { 
    counter +=1 
    client.execute { 
    update id reportID in "reports/report" script "ctx._source.elasticData += output" params Map("output" -> iterator.next().toStringifiedJson) 
    }.await 
} 

Приведенный выше код не работает получая следующее сообщение об ошибке:

[ERROR] [03/06/2015 14:44:23.515] [SparkActorSystem-akka.actor.default-dispatcher-5] [akka://SparkActorSystem/user/spark-actor] failed to execute script 
    org.elasticsearch.ElasticsearchIllegalArgumentException: failed to execute script 
     at org.elasticsearch.action.update.UpdateHelper.prepare(UpdateHelper.java:189) 
     at org.elasticsearch.action.update.TransportUpdateAction.shardOperation(TransportUpdateAction.java:176) 
     at org.elasticsearch.action.update.TransportUpdateAction.shardOperation(TransportUpdateAction.java:170) 
     at org.elasticsearch.action.support.single.instance.TransportInstanceSingleOperationAction$AsyncSingleAction$1.run(TransportInstanceSingleOperationAction.java:187) 
     at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1142) 
     at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:617) 
     at java.lang.Thread.run(Thread.java:745) 
    Caused by: org.elasticsearch.ElasticsearchIllegalArgumentException: script_lang not supported [groovy] 
     at org.elasticsearch.script.ScriptService.dynamicScriptEnabled(ScriptService.java:521) 
     at org.elasticsearch.script.ScriptService.verifyDynamicScripting(ScriptService.java:398) 
     [ERROR] [03/06/2015 14:44:23.515] [SparkActorSystem-akka.actor.default-dispatcher-5] [akka://SparkActorSystem/user/spark-actor] failed to execute script 
    org.elasticsearch.ElasticsearchIllegalArgumentException: failed to execute script 
     at org.elasticsearch.action.update.UpdateHelper.prepare(UpdateHelper.java:189) 
     at org.elasticsearch.action.update.TransportUpdateAction.shardOperation(TransportUpdateAction.java:176) 
     at org.elasticsearch.action.update.TransportUpdateAction.shardOperation(TransportUpdateAction.java:170) 
     at org.elasticsearch.action.support.single.instance.TransportInstanceSingleOperationAction$AsyncSingleAction$1.run(TransportInstanceSingleOperationAction.java:187) 
     at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1142) 
     at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:617) 
     at java.lang.Thread.run(Thread.java:745) 
    Caused by: org.elasticsearch.ElasticsearchIllegalArgumentException: script_lang not supported [groovy] 
     at org.elasticsearch.script.ScriptService.dynamicScriptEnabled(ScriptService.java:521) 
     at org.elasticsearch.script.ScriptService.verifyDynamicScripting(ScriptService.java:398) 
     at org.elasticsearch.script.ScriptService.compile(ScriptService.java:363) 
     at org.elasticsearch.script.ScriptService.executable(ScriptService.java:503) 
     at org.elasticsearch.action.update.UpdateHelper.prepare(UpdateHelper.java:183) 
     ... 6 moreat org.elasticsearch.script.ScriptService.compile(ScriptService.java:363) 
     at org.elasticsearch.script.ScriptService.executable(ScriptService.java:503) 
     at org.elasticsearch. 
action.update.UpdateHelper.prepare(UpdateHelper.java:183) 
    ... 6 more 

Проблемы является сценарием я предполагаю, но я не мог найти какое-либо решение. Пожалуйста, помогите ...

+0

Помогает ли проблема решить проблему, связанную с groovy? См. Здесь: https://gist.github.com/hkorte/6efadb547b55976ae466 – Opal

+0

Нет, я пробовал это @Opal – igalbenardete

+0

Помогает ли это (если использовать ES до 1.4) https://github.com/elasticsearch/elasticsearch/issues/ 9422 –

ответ

3

Помогает ли проблема решить проблему с личными зависимостями? Посмотрите, что: gist.

+1

Чтобы быть ясным, это не эластичный 4s, который нуждается в папке, ее любой клиент ES на основе Java, из которых e4s один. – monkjack

+0

Несомненно, спасибо за разъяснения. – Opal