Как настроить запрос через JSON на Elasticsearch SearchRequest?

Elasticsearch: 6.1.2.

У меня есть входной запрос через JSON, и я хотел бы использовать Java API высокого уровня для создания поискового запроса с использованием данных этого запроса.

String jsonQuery = "..."
SearchRequest searchRequest = new SearchRequest()
SearchSourceBuilder builder = ?
searchRequest.source(builder);

Я попытался построить конструктор через:

SearchSourceBuilder.fromXContent(XContentType.JSON.xContent().createParser(NamedXContentRegistry.EMPTY, query));

но это дает:

Причина: org.elasticsearch.ElasticsearchException: namedObject не поддерживается для этого парсера в org.elasticsearch.common.xcontent.NamedXContentRegistry.parseNamedObject(NamedXContentRegistry.java:129) ~[elasticsearch-6.1.2.jar:6.1.2] в org.elasticsearch.common.xcontent.support.AbstractXContentParser.namedObject(AbstractXContentParser.java:402) ~[elasticsearch-6.1.2.jar:6.1.2] в org.elasticsearch.index.query.AbstractQueryBuilder.parseInnerQueryBuilder(AbstractQueryBuilder.java :313) ~[elasticsearch-6.1.2.jar:6.1.2] в org.elasticsearch.search.builder.SearchSourceBuilder.parseXContent(SearchSourceBuilder.java:1003) ~[elasticsearch-6.1.2.jar:6.1.2] в org.elasticsearch.search.builder.SearchSourceBuilder.fromXContent(SearchSourceBuilder.java:115) ~[elasticsearch-6.1.2.jar:6.1.2]


person Jotschi    schedule 23.01.2018    source источник


Ответы (3)


Теперь я создаю SearchSourceBuilder следующим образом:

String query = "..."
SearchSourceBuilder searchSourceBuilder = new SearchSourceBuilder();
SearchModule searchModule = new SearchModule(Settings.EMPTY, false, Collections.emptyList());
try (XContentParser parser = XContentFactory.xContent(XContentType.JSON).createParser(new NamedXContentRegistry(searchModule
            .getNamedXContents()), query)) {
    searchSourceBuilder.parseXContent(parser);
}
person Jotschi    schedule 23.01.2018
comment
TFFY @Jotschi Ты только что сделал мою пятницу. - person ndtreviv; 15.06.2018
comment
@ndtreviv Я больше не использую этот подход. Использование простого JSON и REST гораздо более гибко. - person Jotschi; 15.06.2018
comment
О, конечно, если вы хотите реорганизовать мир. Ведь это пятница. - person ndtreviv; 15.06.2018
comment
Я вижу много примеров использования new NamedXContentRegistry(ClusterModule.getNamedXWriteables()) в качестве реестра, но у меня это не работает. Это работает. Большое спасибо. - person nonzaprej; 10.06.2019

Я тоже столкнулся с той же проблемой. Мы обновлялись с ES 1.4.4 до ES 6.4.2, и я использовал Java High Level Rest Client, предоставленный ES, для выполнения операций создания/обновления/удаления в ES. Я не смог найти простой способ преобразовать запрос JSON, использовавшийся в предыдущей версии ES, в соответствующий searchRequest с помощью высокоуровневого клиента Rest. Ниже показано, что я в итоге использовал.

import org.elasticsearch.client.Response;
import org.elasticsearch.client.RestHighLevelClient;
import org.elasticsearch.client.Request;

public static Response executeGetRequest(RestHighLevelClient client,
            String api, String body) throws Exception {

            Request request = new Request("GET", api);
            if(body != null && !body.isEmpty()) {
                request.setJsonEntity(body);
            }            
            Response response = client.getLowLevelClient()
                    .performRequest(request);
            if (response == null) {
                throw new Exception(
                        "Get request have failed");
            }
            return response;        
    }
person Rahul Kosambi    schedule 16.01.2019

В методе createParser замените первый параметр NamedXContentRegistry.EMPTY на JsonXContent.jsonXContent

person Aman B    schedule 23.01.2018
comment
createParser принимает только NamedXContentRegistry — ваше предложение не компилируется, поскольку значение равно JsonXContent - person Jotschi; 23.01.2018
comment
Похоже, он доступен в версии 6.2 github.com/elastic/elasticsearch/blob/6.2/server/src/main/java/ - person Aman B; 23.01.2018
comment
Вы можете просмотреть тестовые примеры здесь github.com/elastic/elasticsearch/blob/6.2/server/src/test/java/ - person Aman B; 23.01.2018
comment
Это совершенно другой метод createParser, отличный от ESTestCase. - person Jaap; 14.03.2018