elasticsearch,elastic4s,Scala,Groovy,elasticsearch,Elastic4s" /> elasticsearch,elastic4s,Scala,Groovy,elasticsearch,Elastic4s" />

Scala Elasticsearch脚本将元素添加到数组中

Scala Elasticsearch脚本将元素添加到数组中,scala,groovy,elasticsearch,elastic4s,Scala,Groovy,elasticsearch,Elastic4s,我在scala项目中从事ElasticSearch。我使用elastic4s作为客户。我试图从迭代器一个接一个地向文档中添加元素 while (iterator.hasNext) { counter +=1 client.execute { update id reportID in "reports/report" script "ctx._source.elasticData += output" params Map("output" -> iterator.next

我在scala项目中从事ElasticSearch。我使用elastic4s作为客户。我试图从迭代器一个接一个地向文档中添加元素

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

问题在于我假设的脚本,但我找不到任何解决方案。请帮助…

添加groovy依赖项可以解决问题吗?请看:。

添加groovy依赖项是否解决了问题?请看这里:不,我已经尝试过@OpalDoes此帮助(如果使用1.4之前的ES),您使用的ES版本是什么。从1.3.x到1.4.x的情况有所改变,您需要做的是改变以支持脚本和可能的groovy,但根据您的版本有所不同@Opal的第一个链接这次确实起了作用,谢谢大家。要清楚的是,不是elastic4s需要dep,而是任何基于Java的ES客户端,e4s就是其中之一。