SpringBoot+ElasticSearch7.x+JPA配置多数据源


SpringBoot+ElasticSearch7.x+JPA配置多数据源

这里分为测试环境配置和正式环境配置,大体相差无几

ESTestConfig

 1 @Configuration
 2 @ConfigurationProperties(prefix = "es-config")
 3 @EnableElasticsearchRepositories(basePackages = {"com.tingyu.cdssdatatest.modules.test.*.esrepository"},elasticsearchTemplateRef = "testTemplate")
 4 public class ESTestConfig extends AbstractElasticsearchConfiguration {
 5 
 6     @Value("${es-config.hostAndPortTest}")
 7     private String hostAndPortTest;
 8 
 9     /**
10      * @description: 测试环境ES
11      */
12     @Bean("elasticsearchClientTest")
13     @Override
14     public RestHighLevelClient elasticsearchClient() {
15         ClientConfiguration configuration = ClientConfiguration.builder()
16                 .connectedTo(hostAndPortTest).build();
17         return RestClients.create(configuration).rest();
18     }
19 
20     @Override
21     @Bean(name = { "testOperations", "testTemplate" })
22     public ElasticsearchOperations elasticsearchOperations(ElasticsearchConverter elasticsearchConverter,
23                                                            @Qualifier("elasticsearchClientTest") RestHighLevelClient elasticsearchClient) {
24         return new ElasticsearchRestTemplate(elasticsearchClient, elasticsearchConverter);
25     }
26 }

ESOfficialConfig,这里使用了@Primary注解

 1 @Configuration
 2 @ConfigurationProperties(prefix = "es-config")
 3 @EnableElasticsearchRepositories(basePackages = {"com.tingyu.cdssdatatest.modules.official.*.esrepository"},elasticsearchTemplateRef="officialTemplate")
 4 public class ESOfficialConfig extends AbstractElasticsearchConfiguration {
 5     @Value("${es-config.hostAndPortOfficial}")
 6     private String hostAndPortOfficial;
 7 
 8     /**
 9      * @description: 正式环境ES
10      */
11     @Bean("elasticsearchClientOfficial")
12     @Primary
13     @Override
14     public RestHighLevelClient elasticsearchClient() {
15         ClientConfiguration configuration = ClientConfiguration.builder()
16                 .connectedTo(hostAndPortOfficial).build();
17         return RestClients.create(configuration).rest();
18     }
19 
20     @Override
21     @Bean(name = { "officialOperations", "officialTemplate" })
22     public ElasticsearchOperations elasticsearchOperations(ElasticsearchConverter elasticsearchConverter,
23                                                            @Qualifier("elasticsearchClientOfficial") RestHighLevelClient elasticsearchClient) {
24         return new ElasticsearchRestTemplate(elasticsearchClient, elasticsearchConverter);
25     }
26 }

application.yml

image

esrepository

1 public interface RawMessageRepository extends ElasticsearchRepository<RawMessageDto, String> {
2 
3 }

Dto,使用@Document注解进行实体映射,相当于Mysql的@Table注解

image


免责声明!

本站转载的文章为个人学习借鉴使用,本站对版权不负任何法律责任。如果侵犯了您的隐私权益,请联系本站邮箱yoyou2525@163.com删除。



 
粤ICP备18138465号  © 2018-2025 CODEPRJ.COM