Elasticsearch(6.5) Высокоуровневый java rest-клиент, удаляющий индекс по имени, не работает

#java #spring-boot #elasticsearch #elastic-stack

#java #весенняя загрузка #elasticsearch #эластичный стек

Вопрос:

Я могу удалить документ, передав имя индекса, тип и идентификатор следующим образом-

 DeleteRequest deleteRequest = new DeleteRequest(data.getIndexName(),data.getType(),data.getUniqueId());

    DeleteResponse deleteResponse = client.delete(deleteRequest);
  

Но когда я пытаюсь удалить индекс, указав только имя индекса, как показано ниже — (согласно этому документу)

 DeleteRequest deleteRequest = new DeleteRequest(allData.getIndexName());

    DeleteResponse deleteResponse = client.delete(deleteRequest);
  

получение-

 org.elasticsearch.action.ActionRequestValidationException: Validation Failed: 1: type is missing;2: id is missing;
  

Я пробовал другой способ, подобный этому (ссылка)

 DeleteIndexRequest request = new DeleteIndexRequest(allData.getIndexName());
    AcknowledgedResponse deleteIndexResponse = client.indices().delete(request, RequestOptions.DEFAULT);
  

получение:

 java.lang.NoSuchMethodError: 
at org.elasticsearch.client.IndicesClient.delete(IndicesClient.java:93) ~[elasticsearch-rest-high-level-client-6.5.4.jar:6.4.3]
  

Я использую эту зависимость:

 <dependency>
       <groupId>org.elasticsearch.client</groupId>
       <artifactId>elasticsearch-rest-high-level-client</artifactId>
       <version>6.5.4</version>
</dependency>
  

зависимость mvn: дерево

 [INFO] - org.elasticsearch.client:elasticsearch-rest-high-level- 
client:jar:6.5.4:compile
[INFO]     - org.elasticsearch:elasticsearch:jar:6.4.3:compile
[INFO]    |   - org.elasticsearch:elasticsearch-core:jar:6.4.3:compile
[INFO]    |   - org.elasticsearch:elasticsearch-secure- 
sm:jar:6.4.3:compile
[INFO]    |   - org.elasticsearch:elasticsearch-x- 
content:jar:6.4.3:compile
[INFO]    |  |   - com.fasterxml.jackson.dataformat:jackson- 
dataformat-smile:jar:2.9.8:compile
[INFO]    |  |   - com.fasterxml.jackson.dataformat:jackson- 
dataformat-yaml:jar:2.9.8:compile
[INFO]    |  |  - com.fasterxml.jackson.dataformat:jackson- 
dataformat-cbor:jar:2.9.8:compile
[INFO]    |   - org.apache.lucene:lucene-core:jar:7.4.0:compile
[INFO]    |   - org.apache.lucene:lucene-analyzers- 
common:jar:7.4.0:compile
[INFO]    |   - org.apache.lucene:lucene-backward- 
codecs:jar:7.4.0:compile
[INFO]    |   - org.apache.lucene:lucene-grouping:jar:7.4.0:compile
[INFO]    |   - org.apache.lucene:lucene-highlighter:jar:7.4.0:compile
[INFO]    |   - org.apache.lucene:lucene-join:jar:7.4.0:compile
  

Вот мой pom.xml

 <?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0" 
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 
http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<parent>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-parent</artifactId>
    <version>2.1.2.RELEASE</version>
    <relativePath/> <!-- lookup parent from repository -->
</parent>
<groupId>com.example</groupId>
<artifactId>search-service</artifactId>
<version>0.0.1-SNAPSHOT</version>
<name>search-service</name>
<description>Demo project for search-service</description>

<properties>
    <java.version>1.8</java.version>
</properties>

<dependencies>
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-web</artifactId>
    </dependency>
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-thymeleaf</artifactId>
    </dependency>
    <dependency>
        <groupId>org.json</groupId>
        <artifactId>json</artifactId>
        <version>20180813</version><!--$NO-MVN-MAN-VER$-->
    </dependency> 
    <dependency>
       <groupId>com.google.code.gson</groupId>
       <artifactId>gson</artifactId>
       <version>2.8.2</version><!--$NO-MVN-MAN-VER$-->
    </dependency>
    <dependency>
        <groupId>com.google.code.gson</groupId>
        <artifactId>gson</artifactId>
        <version>2.6.2</version><!--$NO-MVN-MAN-VER$ -->
    </dependency>

    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-devtools</artifactId>
        <scope>runtime</scope>
    </dependency>
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-test</artifactId>
        <scope>test</scope>
    </dependency>
    <dependency>
<groupId>org.elasticsearch.client</groupId>
<artifactId>elasticsearch-rest-high-level-client</artifactId>
<version>6.7.0</version><!--$NO-MVN-MAN-VER$-->
  

 <build>
    <plugins>
        <plugin>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-maven-plugin</artifactId>
        </plugin>
    </plugins>
</build>
  

Комментарии:

1. Второй способ является правильным. Странно, что он выдает эту ошибку, хотя, поскольку в версии 6.5.4 уже был delete метод.

2. Похоже, что правильная версия не загружается. Проверьте, не переопределяет ли какая-либо зависимость версию.

3. @NishantSaini Я добавил зависимость, которую я использовал выше. И он показывает одно предупреждение — «Переопределение управляемой версии 6.4.3 для elasticsearch-rest-клиента высокого уровня» в pom.xml . Является ли это причиной того, что удаление индекса не работает

4. В дереве зависимостей проверьте, какая версия elastic search ( org.elasticsearch ) используется. Это должно быть 6.5.4 или выше.

5. @NishantSaini Я добавил зависимость mvn:tree не знаю, почему он показывает 6.4.3? У меня есть только зависимость 6.5.4 в моем pom.xml

Ответ №1:

Выпуск Spring-boot версии v2.1.2 имеет свойство, определенное для версии elasticsearch как

 <elasticsearch.version>6.4.3</elasticsearch.version>
  

и следующая зависимость

 <dependency>
    <groupId>org.elasticsearch</groupId>
    <artifactId>elasticsearch</artifactId>
    <version>${elasticsearch.version}</version>
</dependency>
  

Это причина этого в дереве зависимостей

org.elasticsearch:elasticsearch:jar:6.4.3:компиляция

Чтобы принудительно загрузить elasticsearch 6.5.4, добавьте в свой pom следующее свойство, которое переопределит свойство, определенное в spring-boot-dependencies pom

 <properties>
    <elasticsearch.version>6.5.4</elasticsearch.version>
</properties>
<dependencies>
    ...
    <dependency>
        <groupId>org.elasticsearch.client</groupId>
        <artifactId>elasticsearch-rest-high-level-client</artifactId>
        <version>${elasticsearch.version}</version>
    </dependency>
    ...
</dependencies>
  

Комментарии:

1. Да, он выполняет свою работу. Спасибо