Elasticsearch查询插件

时间:2017-05-24 15:40:45

标签: java elasticsearch elasticsearch-plugin

我将Elasticsearch插件从版本2.4.0升级到5.4.0。这个插件实现了一个自定义查询,但是对Elasticsearch Java Api进行了新的更改,我对如何注册新查询感到有些困惑。我在Elasticsearch网站上搜索,发现我必须实现SearchPlugin接口并覆盖方法getQueries,但我仍然感到困惑,我是如何做到的。有什么帮助吗?

1 个答案:

答案 0 :(得分:1)

你需要这样的东西(java8):

public class MyQueryPlugin extends Plugin implements SearchPlugin {

    @Override public List<QuerySpec<?>> getQueries() {
        return Arrays.asList(
                new QuerySpec<>("my_query", MyQueryBuilder::new, MyQueryBuilder::fromXContent)
        );
    }
}

或者这个(java 7):

public class MyQueryPlugin extends Plugin implements SearchPlugin {

    @Override
    public List<QuerySpec<?>> getQueries() {
        return Arrays.asList(new QuerySpec<>(
                "my_query",
                new Writeable.Reader<MyQueryBuilder>() {
                    @Override
                    public MyQueryBuilder read(StreamInput in) throws IOException {return new MyQueryBuilder(in);}
                },
                new QueryParser<MyQueryBuilder>() {
                    @Override
                    public Optional<MyQueryBuilder> fromXContent(QueryParseContext parseContext) throws IOException {return MyQueryBuilder.fromXContent(parseContext);}
                })
        );
    }
}

MyQueryBuilder可能会延长AbstractQueryBuilder<MyQueryBuilder>。大多数其他ES提供的查询扩展了这一点 - 它们是从中复制的良好来源。

MyQueryBuilder::fromXContent是引起我兴趣的另一个变化 -  它应该与2.x。{/ p>中的org.elasticsearch.index.query.QueryParser#parse(QueryParseContext parseContext)相同

MyQueryPlugin是您在plugin-descriptor.properties中引用的内容:

description=my-query example
version=1.0.0
name=my-query
java.version=1.8
elasticsearch.version=5.4.0
classname=com.example.MyQueryPlugin