#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. Да, он выполняет свою работу. Спасибо