elasticsearch - 休眠搜索和Elasticsearch:找不到字段[…]的mapper_parsing_exception +分析器[…]

标签 elasticsearch hibernate-search aws-elasticsearch elasticsearch-analyzers

我正在使用休眠搜索自动为特定实体创建索引

@Entity
@Indexed
public class Entity extends BaseEntity {

    private static final long serialVersionUID = -6465422564073923433L;

    @Id
    @GeneratedValue(strategy = GenerationType.IDENTITY)
    private Long id;

    @OneToMany(fetch = FetchType.LAZY, cascade = CascadeType.ALL, orphanRemoval = true)
    @Field(bridge = @FieldBridge(impl = PropertyFieldBridge.class))
    private List<PropertyValue> properties = new ArrayList<>(); // PropertyValue is an abstract

}

字段桥正在创建格式为pt_ [a-zA-Z0-9] + _ i18n的字符串字段。

之后,我将创建一个动态模板来处理翻译后的字段:
PUT {{elasticsearch}}/com.orm.entity.entity.entity/com.orm.entity.entity.Entity/_mapping
{
  "com.gamila.api.orm.entity.entity.Entity": {
    "dynamic_templates": [
      {
        "my_analyzer": {
          "match_mapping_type": "string",
          "match_pattern": "regex",
          "match": "^pt_[a-zA-Z0-9]+_i18n",
          "mapping": {
            "type": "text",
            "analyzer": "portugueseAnalyzer"
          }
        }
      }
    ]
  }
}

但是当我创建一个实体时,它总是返回一个错误:
Response: 400 'Bad Request' with body 
{
  "error": {
    "root_cause": [
      {
        "type": "mapper_parsing_exception",
        "reason": "analyzer [portugueseAnalyzer] not found for field [pt_name_i18n]"
      }
    ],
    "type": "mapper_parsing_exception",
    "reason": "analyzer [portugueseAnalyzer] not found for field [pt_name_i18n]"
  },
  "status": 400
}

通过以下方法定义portugueseAnalyser:
public class Analyzer implements ElasticsearchAnalysisDefinitionProvider {

    @Override
    public void register(ElasticsearchAnalysisDefinitionRegistryBuilder builder) {
        builder.analyzer("portugueseAnalyzer")
                .withTokenizer("standard")
                .withTokenFilters("lowercase", "portugueseStemmer", "portugueseStop", "edge_ngram_3");

        builder.tokenFilter("portugueseStemmer")
                .type("stemmer").param("language", "portuguese");
        builder.tokenFilter("portugueseStop")
                .type("stop").param("stopwords", "_portuguese_");
    }

}

有人可以告诉我我在做什么错吗?我已经在stackoverflow中浏览了一些问题,但没有成功。

PS:我正在使用来自AWS的elasticsearch(5.6)

提前致谢

最佳答案

当Hibernate Search 5将映射推送到Elasticsearch时,它将仅包含映射中某处实际使用的分析器的分析器定义。在您的情况下,就Hibernate Search而言,没有使用分析器,因此将其忽略。

作为Hibernate Search 5中的一种解决方法,您可以声明一个使用您的分析器的伪字段,但永远不要填充它。您可以找到有关如何执行here的示例。

关于elasticsearch - 休眠搜索和Elasticsearch:找不到字段[…]的mapper_parsing_exception +分析器[…],我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/60928554/

相关文章:

elasticsearch - Ubuntu 16.10:作为守护程序运行Elasticsearch或仅在系统启动时启动它

java - 将 EntityGraph 与 Hibernate 搜索 ORM 结合使用

java - 向 AWS ElasticSearch 添加 5000 万条记录的最快方法

elasticsearch - 无法将节点添加到集群(elasticsearch)

java - 如何诊断 ElasticSearch 搜索队列增长

java - JPA和Hibernate Search的方法是什么?

java - Hibernate-search:通过在 hibernate-search 中以编程方式注册字段,基类字段未在 elastic-search 中注册

amazon-web-services - 我如何从AWS控制台了解Elasticsearch存储使用情况

amazon-web-services - AWS Elastic Search Domain 的 Route53 给出证书错误

elasticsearch - 如何从 Elasticsearch 中过滤特定字段