Spring Data访问Elasticsearch----创建存储库实例

Spring Data访问Elasticsearch----创建存储库实例

本文介绍如何为已定义的存储库接口创建实例和bean定义。

一、Java配置

在Java配置类上使用特定于存储的@EnableElasticsearchRepositories注解来定义用于存储库激活的配置。有关基于java的Spring容器配置的介绍,请参阅Spring参考文档中的JavaConfig。启用Spring Data存储库的样例配置如下:
基于注解的存储库配置样例

java 复制代码
@Configuration
@EnableJpaRepositories("com.acme.repositories")
class ApplicationConfiguration {

  @Bean
  EntityManagerFactory entityManagerFactory() {
    // ...
  }
}

前面的示例使用特定于jpa的注解,你可以根据实际使用的存储模块对其进行更改。这同样适用于EntityManagerFactory bean的定义。请参阅介绍特定于存储的配置的部分。

二、XML配置

每个Spring Data模块都包含一个存储库元素,允许你定义Spring扫描的基本包,如下面的示例所示:
通过XML启用Spring Data存储库

xml 复制代码
<?xml version="1.0" encoding="UTF-8"?>
<beans:beans xmlns:beans="http://www.springframework.org/schema/beans"
  xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
  xmlns="http://www.springframework.org/schema/data/jpa"
  xsi:schemaLocation="http://www.springframework.org/schema/beans
    https://www.springframework.org/schema/beans/spring-beans.xsd
    http://www.springframework.org/schema/data/jpa
    https://www.springframework.org/schema/data/jpa/spring-jpa.xsd">

  <jpa:repositories base-package="com.acme.repositories" />

</beans:beans>

在前面的示例中,Spring被指示扫描com.acme.repositories及其所有子包,以查找扩展Repository或其子接口之一的接口。对于找到的每个接口,基础设施都会注册特定于持久性技术的FactoryBean,以创建适当代理,以处理查询方法调用。每个bean都注册在从接口名称派生的bean名称下,因此UserRepository的接口将注册在userRepository下。嵌套存储库接口的Bean名称以其enclosing类型名称为前缀。基础包属性允许使用通配符,以便你可以定义扫描包的pattern。

三、使用过滤器

默认情况下,基础结构会拾取位于配置的基础包下的每个扩展持久性技术特定的Repository子接口的接口,并为其创建一个bean实例。但是,你可能需要更细粒度地控制为哪些接口创建bean实例。为此,请在存储库声明中使用过滤器元素。语义与Spring的组件过滤器中的元素完全等效。有关详细信息,请参阅这些元素的Spring参考文档

例如,要将某些接口从存储库bean实例化中排除,可以使用以下配置:
使用过滤器

java 复制代码
@Configuration
@EnableElasticsearchRepositories(basePackages = "com.acme.repositories",
    includeFilters = { @Filter(type = FilterType.REGEX, pattern = ".*SomeRepository") },
    excludeFilters = { @Filter(type = FilterType.REGEX, pattern = ".*SomeOtherRepository") })
class ApplicationConfiguration {

  @Bean
  EntityManagerFactory entityManagerFactory() {
    // ...
  }
}

前面的示例包括以SomeRepository结尾的所有接口,并从实例化中排除以SomeOtherRepository结尾的接口。

四、独立使用

你还可以在Spring容器之外使用存储库基础结构 --- 例如在CDI环境中。类路径中仍然需要一些Spring库,但通常也可以通过编程设置存储库。提供存储库支持的Spring Data模块附带了一个特定于持久性技术的RepositoryFactory,你可以使用它,如下所示:
存储库工厂的独立使用

java 复制代码
RepositoryFactorySupport factory = ... // Instantiate factory here
UserRepository repository = factory.getRepository(UserRepository.class);
相关推荐
Elastic 中国社区官方博客4 小时前
Simple MCP Client - 连接到 Elasticsearch MCP 并进行自然语言搜索
大数据·人工智能·elasticsearch·搜索引擎·ai·全文检索
会飞的小蛮猪4 小时前
ELK运维之路(Logstash测试案例1)
elasticsearch·kibana·logstash
cxyxiaokui0015 小时前
🔍 为什么我的日志在事务回滚后也没了?——揭秘 REQUIRES_NEW 的陷阱
java·后端·spring
跟着珅聪学java6 小时前
spring boot 整合 activiti 教程
android·java·spring
Java水解6 小时前
Spring JDBC与KingbaseES深度集成:构建高性能国产数据库应用实战
后端·spring
tcwgq6 小时前
Centos Stream 8 搭建Cas Server
linux·elasticsearch·centos
低音钢琴7 小时前
【SpringBoot从初学者到专家的成长15】MVC、Spring MVC与Spring Boot:理解其差异与联系
spring boot·spring·mvc
Nan_Shu_6148 小时前
学习SpringBoot
java·spring boot·后端·学习·spring
JAVA学习通8 小时前
SpringBoot Layui ThymeLeaf 一点点学习心得
java·spring
yumgpkpm8 小时前
CMP (类Cloudera) CDP7.3(400次编译)在华为鲲鹏Aarch64(ARM)信创环境中的性能测试过程及命令
大数据·hive·hadoop·python·elasticsearch·spark·cloudera