Spring Data访问Elasticsearch----路由值Routing values

Spring Data访问Elasticsearch----路由值Routing values

当Elasticsearch将文档存储在具有多个分片的索引中时,它会根据文档的id确定要使用的分片。有时有必要预先定义多个文档应该在同一个shard上建立索引(join-types,更快地搜索相关数据)。为此,Elasticsearch提供了定义路由的可能性,路由是用于计算shard的值,而不是id。
Spring Data Elasticsearch通过以下方式支持存储和检索数据的路由定义:

一、join-types的路由

当使用联接类型(请参阅联接类型实现)时,Spring Data Elasticsearch将自动使用实体的JoinField属性的parent属性作为路由的值。

这对于parent-child关系只有一个级别的所有用例都是正确的。如果是更深层次的,比如child-parent-grandparent的关系------比如之前的例子vote → answer → question-然后需要使用下一节中描述的技术明确指定路由(投票需要question.id作为路由值)。

二、自定义路由值

为了定义一个实体的自定义路由,Spring Data Elasticsearch提供了一个@Routing注解(重用之前的Statement类):

java 复制代码
@Document(indexName = "statements")
@Routing("routing")         --------1         
public class Statement {
    @Id
    private String id;

    @Field(type = FieldType.Text)
    private String text;

    @JoinTypeRelations(
        relations =
            {
                @JoinTypeRelation(parent = "question", children = {"answer", "comment"}),
                @JoinTypeRelation(parent = "answer", children = "vote")
            }
    )
    private JoinField<String> relation;

    @Nullable
    @Field(type = FieldType.Keyword)
    private String routing; --------2         

    // getter/setter...
}

1. 这将"路由"定义为路由规范
2. 具有名称routing的属性

如果注解的路由定义是纯字符串而不是SpEL表达式,则它被解析为实体的属性的名称,在本例中,它是routing属性。然后,此属性的值将用作使用该实体的所有请求的路由值。

我们也可以在@Document注解中使用SpEL表达式,如下所示:

java 复制代码
@Document(indexName = "statements")
@Routing("@myBean.getRouting(#entity)")
public class Statement{
    // all the needed stuff
}

在这种情况下,用户需要提供一个名为myBean的bean,该bean具有String getRouting(Object)方法。要引用实体,必须在SpEL表达式中使用"#entity",并且返回值必须为null或路由值为String。

如果普通属性的名称和SpEL表达式不足以自定义路由定义,则可以定义并提供RoutingResolver接口的实现。然后可以在ElasticOperations实例上设置:

java 复制代码
RoutingResolver resolver = ...;

ElasticsearchOperations customOperations= operations.withRouting(resolver);

withRouting()函数返回带有自定义路由集的原始ElasticsearchOperations实例的副本。

当路由存储在Elasticsearch中时,在实体上定义了路由时,在执行get或delete操作时必须提供相同的值。对于不使用实体(如get(ID)或delete(ID))的方法,ElasticsearchOperations.withRouting(RoutingResolver)方法可以这样使用:

java 复制代码
String id = "someId";
String routing = "theRoutingValue";

// get an entity
Statement s = operations
                .withRouting(RoutingResolver.just(routing))  --------1     
                .get(id, Statement.class);

// delete an entity
operations.withRouting(RoutingResolver.just(routing)).delete(id);

1. RoutingResolver.just(s)返回一个只会返回给定字符串的解析器。
相关推荐
云烟成雨TD21 小时前
Spring AI Alibaba 1.x 系列【6】ReactAgent 同步执行 & 流式执行
java·人工智能·spring
Java成神之路-1 天前
SpringMVC 响应实战指南:页面、文本、JSON 返回全流程(Spring系列13)
java·spring·json
砍材农夫1 天前
spring-ai 第六模型介绍-聊天模型
java·人工智能·spring
云烟成雨TD1 天前
Spring AI Alibaba 1.x 系列【5】ReactAgent 构建器深度源码解析
java·人工智能·spring
Flittly1 天前
【SpringAIAlibaba新手村系列】(15)MCP Client 调用本地服务
java·笔记·spring·ai·springboot
Flittly1 天前
【SpringAIAlibaba新手村系列】(14)MCP 本地服务与工具集成
java·spring boot·笔记·spring·ai
mfxcyh1 天前
基于xml、注解、JavaConfig实现spring的ioc
xml·java·spring
Flittly1 天前
【SpringAIAlibaba新手村系列】(13)Tool Calling 函数工具调用技术
java·spring boot·spring·ai
xdscode1 天前
Spring 依赖注入方式全景解析
java·后端·spring