当前位置: 首页 > article >正文

谷粒商城项目125-spring整合high-level-client

新年快乐! 致2025年还在努力学习的你!
你已经很努力了,今晚就让自己好好休息一晚吧!

在后端中选用哪种elasticsearch客户端?

elasticsearch可以通过9200或者9300端口进行操作

1)9300:TCP

  • spring-data-elasticsearch:transport-api.jar

    • springboot版本不同,transport-api.jar不同,不能适配es版本

    • 7.x已经不建议使用,8以后就要废弃

2)9200:HTTP

  • JestClient:非官方,更新慢

  • RestTemplate:模拟发HTTP请求,ES很多操作需要自己封装,麻烦

  • HttpClient:同上

  • high-level-client:官方(推荐)

综上,使用官方推荐的high-level-client。

以下为在idea中配置high-level-client的详细操作步骤:

①:在gulimall模块下创建子模块gulimall-search
image-20241231204030501

image-20241230213435632

gulimall父模块的pom下添加gulimall-search作为子模块

image-20241230213602531

②导入相关依赖

<dependency>
<groupId>org.elasticsearch.client</groupId>
<artifactId>elasticsearch-rest-high-level-client</artifactId>
<version>7.13.0</version>
</dependency>

刷新依赖,可以发现其中的elasticsearch依赖和elasticsearch-rest-client依赖的版本是7.15.2

image-20241231204806030

elasticsearch和elasticsearch-rest-client这两个依赖是elasticsearch-rest-high-level-client的传递依赖,就是说elasticsearch-rest-high-level-client依赖着elasticsearch和elasticsearch-rest-client这两个依赖。

我们点开elasticsearch-rest-high-level-client-7.13.0.pom,可以看到elasticsearchelasticsearch-rest-client这两个依赖的版本是7.13.0

image-20241231205324014

那么为什么项目实际引入的版本实际是7.15.2

原因在于该项目pom文件下的的内容

image-20241231232127568

查看spring-boot-dependencies-2.6.13.pom下的内容

image-20241231232250320

可以看到spring-boot-dependencies-2.6.13.pom中也指定了elasticsearch的版本,并且版本号为7.15.2,是不是和前面实际引入的版本号对应上了~

至于为什么dependencyManager会影响到elasticsearch-rest-high-level-client的传递依赖版本,具体可以参考博客:maven的dependencyManagement中定义的依赖声明优先级高于传递依赖

总之结论就是:maven的dependencyManagement中定义的依赖声明优先级高于传递依赖。

所以,我们把elasticsearch-rest-high-level-client里面的两个依赖,elasticsearchelasticsearch-rest-client`排除,然后显示导入这两个依赖,如下

		<dependency>
            <groupId>org.elasticsearch.client</groupId>
            <artifactId>elasticsearch-rest-high-level-client</artifactId>
            <version>7.13.0</version>
            <exclusions>
                <exclusion>
                    <artifactId>elasticsearch</artifactId>
                    <groupId>org.elasticsearch</groupId>
                </exclusion>
                <exclusion>
                    <artifactId>elasticsearch-rest-client</artifactId>
                    <groupId>org.elasticsearch.client</groupId>
                </exclusion>
            </exclusions>
        </dependency>
        <dependency>
            <groupId>org.elasticsearch</groupId>
            <artifactId>elasticsearch</artifactId>
            <version>7.13.0</version>
        </dependency>
        <dependency>
            <artifactId>elasticsearch-rest-client</artifactId>
            <groupId>org.elasticsearch.client</groupId>
            <version>7.13.0</version>
        </dependency>

③编写配置类

image-20241231233858360

配置类编写如下:

@Configuration
public class GulimallElasticSearchConfig {
    @Bean
    public RestHighLevelClient client() {
        RestHighLevelClient client = new RestHighLevelClient(
                RestClient.builder(
                        new HttpHost("192.168.206.134", 9200, "http")
                )
        );
        return client;
    }
}

④单元测试

image-20241231234137583

@SpringBootTest
class GulimallSearchApplicationTests {
    @Autowired
    private RestHighLevelClient client;

    @Test
    void contextLoads() {
        System.out.println(client);
    }
}

输出结果如下:

image-20241231234227698

说明配置成功!

ps:这里没有引入common模块,因为我在引入入common模块后出现了could not find class [org.springframework.cloud.client.loadbalancer.reactive.onnoribbondefaultcondition]报错,所以我暂时忽略common依赖的引入。如果需要引入common依赖,在运行测试类的时候会出现无法找到数据源的错误,需要在如下启动类上添加exclude = DataSourceAutoConfiguration.class.由于配置了mybatis等与数据库相关的类,spring boot在启动时会自动加载数据源,具体可以参考我写的博客:报错:Failed to determine a suitable driver class 让spring boot项目启动时不连接数据库

image-20241231234408820


http://www.kler.cn/a/464553.html

相关文章:

  • 数据安全防护
  • CG顶会论文阅读|《科技论文写作》硕士课程报告
  • 【开源项目】数字孪生立交~东湖高新区互通式立交数字孪生可视化项目——开源工程及源码
  • 在 macOS 上,你可以使用系统自带的 终端(Terminal) 工具,通过 SSH 协议远程连接服务器
  • Ubuntu Server安装谷歌浏览器
  • net core介绍
  • C++简明教程(14)动态库和静态库的内存共享机制
  • 在基于Centos7的服务器上启用【Gateway】的【Clion Nova】(即 ReSharper C++ 引擎)
  • 文件查找工具locate和find
  • 【ShuQiHere】 集成学习:提升模型性能的有效策略
  • [Qt] 常用控件 | QWidget | “表白程序2.0”
  • 按字段拆分多个工作表到独立的工作簿并增加合计-Excel易用宝
  • 2024年社区高光时刻总结!
  • 【git】git stash相关指令
  • Spring 中的 @ExceptionHandler 注解详解与应用
  • Docker- Unable to find image “hello-world“locally
  • 去除el-tabs 下面的灰色横线,并修改每一项的左右间距,和字体颜色
  • 无人机快速巡检、森林、电力、水利大大节省人力成本,降低风险事故
  • 【文献精读笔记】Explainability for Large Language Models: A Survey (大语言模型的可解释性综述)(五)
  • GJB软件需求规格说明模板及详解
  • C# 设计模式(创建型模式):单例模式
  • 大型概念模型:在句子表示空间中的语言建模
  • CSS疑难记录
  • 基于通义千问2-VL-7B-Instruct模型的微调技术指南
  • 性能测试中如何设计真实的负载呢?
  • PyTorch快速入门教程【小土堆】之卷积层