使用ElasticSearch,可以将各种语言的脚本放在ElasticSearch的/config/scripts目录中,它们将被自动加载以用于更新请求和其他类型的操作。在我的生产环境中,我能够做到这一点,并使用脚本成功地运行了Update。
然而,到目前为止,在本地模式下运行节点以进行集成测试时,我没有成功地让这个特性工作。我假设,由于可以配置ElasticSearch节点,在类路径上配置一个elasticsearch.yml,还应该能够添加一个scripts目录并将她想要的脚本放在那里,从而将其加载到本地节点中。情况似乎并非如此,因为当我试图使用该脚本执行更新时,就找不到它了。
Caused by: org.elasticsearch.ElasticsearchIllegalArgumentException: Unable to find on disk script scripts.my_script
at org.elasticsearch.script.ScriptService.compile(ScriptService.java:269)
at org.elasticsearch.script.ScriptService.executable(ScriptService.java:417)
at org.elasticsearch.action.update.UpdateHelper.prepare(UpdateHelper.java:194)
... 6 more有人知道如何正确地将自动脚本加载到本地ElasticSearch节点进行测试吗?
我使用的是包含在“org.弹性搜索: ElasticSearch :1.5.2”中的基本elasticsearch客户机。
发布于 2015-07-25 01:39:29
在仔细阅读了源代码之后,我发现我的脚本没有被Elasticsearch的目录监视器选中的原因是因为它在监视user.dir,这是默认的配置目录。scripts/子目录必须位于该目录下,节点才能获取我的脚本并将其加载到ScriptService中,以便在更新时使用它。
配置目录可以在您的elasticsearch.yml中用键path.conf覆盖。将其设置到项目的某个位置将允许您在测试期间加载脚本,并将这些脚本添加到版本控制中。确保该目录下的是一个scripts/目录;这是加载脚本的地方。
https://stackoverflow.com/questions/31621132
复制相似问题