elasticsearch - 将自定义分析器添加到使用 spring 构建的索引的基础知识

标签 elasticsearch spring-data-elasticsearch

我认为这是一个非常基本的问题,但我一直在房子里转来转去,所以任何帮助我指出正确方向的人都将不胜感激。

我继承了一个 java 应用程序,它使用 spring-data-elasticsearch(目前为 1.2.1.RELEASE)构建和 Elasticsearch 索引。我已经通过各种简单的方式非常成功地修改了它,但现在我想添加一个自定义分析器以在一个字段上使用(字符映射以删除/'s)。

正在构建的索引本质上是 1 个具有各种文档类型的索引。它似乎是开箱即用的。我是 java 和 spring 的新手,但是跟踪所有的配置和自动连接有时仍然会让我不知所措,但据我所知,上下文 XML 文件中的客户端配置直接指向 spring 代码并且没有除了自定义索引名称和存储库接口(interface)和代码的位置之外,添加了很多内容

<elasticsearch:node-client id="esClient" local="true" cluster-name="products"/>
<elasticsearch:repositories base-package="com.warehouse.es.repos"/>

<bean name="elasticsearchTemplate" class="org.springframework.data.elasticsearch.core.ElasticsearchTemplate">
    <constructor-arg name="client" ref="esClient"/>
</bean>

然后代码似乎使用了开箱即用的客户端对象

@Autowired
public void setClient(Client client) throws IOException {
    this.client = client;

然后继续使用这些映射文件设置各种类型映射

createTypeMapping(client, Constants.INDEX_NAME, INDEX_TYPE, "Products.mapping");

如果其中的某些内容太简短(或者对于这个基本问题来说太华夫饼),我深表歉意,但我正在尝试找出/找到一个示例,说明如何以及在何处添加我的自定义分析器。我有文档和示例向我展示如何创建一些 json 来创建自定义分析器 (例如 https://www.elastic.co/guide/en/elasticsearch/reference/current/analysis-mapping-charfilter.html#analysis-mapping-charfilter 和一些以前的 stackoverflow 问答)

但我很难理解我在创建索引的 Java 代码中添加它的位置。

显然,帮助越多越好(!),但实际上在这个阶段,我正在尝试了解是否可以将分析器添加到 yml 文件中,或者是否需要添加一些代码来修改客户端某种方式?或者甚至可能只是将其添加到单个类型映射中。

谢谢。

最佳答案

如果索引/类型是直接在集群上创建的(比如运行 curl 命令),或者索引/类型的创建是由您的 Spring 应用程序处理的。在后一种情况下,我认为您可以按照 this link on github 中的一些代码示例进行操作。 .

如果您有 Products.mapping 文件,其中的内容确实看起来像类型映射。但是,如果您通过添加新的分析器更改类型映射,那么您集群中的任何数据都需要重新编制索引。

使用海报发现进行编辑:它是 not possible将设置放在项目的各个映射文件中,但作为带有 @settings 注释的单独文件。

关于elasticsearch - 将自定义分析器添加到使用 spring 构建的索引的基础知识,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/32995753/

相关文章:

elasticsearch - 如何在elasticsearch中从节点数据到master的连接?

elasticsearch - 将 AWS Kinesis Firehose 回填到 Elasticsearch Service 失败记录

java - 将 ElasticSearch 与 Spring Data 结合使用时自动生成数字 id

elasticsearch - 如果实体索引是基于时间的,如何使用ElasticsearchEntityMapper?

spring - java.lang.AbstractMethodError 与 Spring-data-elasticsearch

用于 Elasticsearch 的 mongodb river

elasticsearch - Elasticsearch 分数计算

http - 如何在ElasticSearch中为两种类型创建映射?

spring - createIndex = true不会在Elasticsearch中创建索引映射

java - 创建加速搜索查询elasticsearch