返回顶部
首页 > 资讯 > 精选 >ElasticSearch整合SpringBoot搭建配置的方法是什么
  • 455
分享到

ElasticSearch整合SpringBoot搭建配置的方法是什么

2023-07-05 05:07:18 455人浏览 安东尼
摘要

本文小编为大家详细介绍“elasticsearch整合SpringBoot搭建配置的方法是什么”,内容详细,步骤清晰,细节处理妥当,希望这篇“ElasticSearch整合springBoot搭建配置的方法是什么”文章能帮助大家解决疑惑,下

本文小编为大家详细介绍“elasticsearch整合SpringBoot搭建配置的方法是什么”,内容详细,步骤清晰,细节处理妥当,希望这篇“ElasticSearch整合springBoot搭建配置的方法是什么”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。

    项目搭建

    老规矩,先建Maven项目,下面是我的pom.xml

    <?xml version="1.0" encoding="UTF-8"?><project xmlns="Http://maven.apache.org/POM/4.0.0"         xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"         xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">    <modelVersion>4.0.0</modelVersion>    <groupId>org.example</groupId>    <artifactId>springboot-es-all</artifactId>    <version>1.0-SNAPSHOT</version>    <properties>        <java.version>1.8</java.version>    </properties>    <parent>        <groupId>org.springframework.boot</groupId>        <artifactId>spring-boot-starter-parent</artifactId>        <version>2.1.3.RELEASE</version>    </parent>    <dependencies>        <!--test-->        <dependency>            <groupId>org.springframework.boot</groupId>            <artifactId>spring-boot-starter-test</artifactId>        </dependency>        <!--ElasticSearch 客户端依赖-->        <dependency>            <groupId>org.elasticsearch.client</groupId>            <artifactId>elasticsearch-rest-client</artifactId>            <version>7.8.0</version>        </dependency>        <dependency>            <groupId>org.elasticsearch</groupId>            <artifactId>elasticsearch</artifactId>            <version>7.8.0</version>        </dependency>        <dependency>            <groupId>org.elasticsearch.client</groupId>            <artifactId>elasticsearch-rest-high-level-client</artifactId>            <version>7.8.0</version>        </dependency>        <!--Hutool依赖-->        <dependency>            <groupId>cn.hutool</groupId>            <artifactId>hutool-all</artifactId>            <version>5.8.4</version>        </dependency>        <!--fast-JSON-->        <dependency>            <groupId>com.alibaba</groupId>            <artifactId>fastjson</artifactId>            <version>1.2.58</version>        </dependency>        <dependency>            <groupId> org.slf4j </groupId>            <artifactId> slf4j-api </artifactId>            <version> 1.6.4 </version>        </dependency>        <dependency>            <groupId>org.slf4j</groupId>            <artifactId>slf4j-simple</artifactId>            <version>1.7.25</version>            <scope>compile</scope>        </dependency>        <dependency>            <groupId>org.projectlombok</groupId>            <artifactId>lombok</artifactId>        </dependency>    </dependencies>    <build>        <plugins>            <plugin>                <groupId>org.springframework.boot</groupId>                <artifactId>spring-boot-maven-plugin</artifactId>                <version>2.1.3.RELEASE</version>            </plugin>        </plugins>    </build></project>

    这里我使用的是elasticsearch-rest-high-level-client官方客户端,建议大家尽量用官方的,因为随着es的不断升级,很多api都过时了,如果你使用spring-boot-starter-data-elasticsearch这个要依赖社区去维护,很多新特性你没法使用到,也会存在安全性问题。

    配置客户端

    启动类:

    @SpringBootApplicationpublic class EsStudyApplication {    public static void main(String[] args) {        SpringApplication.run(EsStudyApplication.class, args);    }}

    配置文件 application.yml:

    server:  port: 9000elasticsearch:  host: 0.0.0.0  port: 9200  username:  passWord:

    客户端配置 config.EsClientConfig:

    @Configurationpublic class EsClientConfig {    @Value("${elasticsearch.host}")    private String host;    @Value("${elasticsearch.port}")    private int port;    @Value("${elasticsearch.username}")    private String userName;    @Value("${elasticsearch.password}")    private String password;    @Bean    public RestHighLevelClient restHighLevelClient() {        final CredentialsProvider credentialsProvider = new BasicCredentialsProvider();        credentialsProvider.setCredentials(AuthScope.ANY, new UsernamePasswordCredentials(userName, password));        RestHighLevelClient restHighLevelClient = new RestHighLevelClient(                RestClient.builder(new HttpHost( host, port, "http")).setHttpClientConfiGCallback(httpClientBuilder -&gt; {                    httpClientBuilder.setMaxConnTotal(500);                    httpClientBuilder.setMaxConnPerRoute(300);                    return httpClientBuilder.setDefaultCredentialsProvider(credentialsProvider);                })        );        return restHighLevelClient;    }}

    然后客户端我们就配好了,客户端的配置其实还有很多,感兴趣的同学自行查阅。后续使用的时候,直接导入RestHighLevelClient实例就好了

    接着启动它,如果控制没有报错,说明配置没啥问题了, 记得要开启es服务~

    索引API初探 & Index API

    下面我们写一点测试用例,来验证我们是否可以操作es,为了方便演示,这里直接使用SpringBootTest来测试,大家平时在写springboot项目,类测试的时候也可以这么做

    ping

    新建api.IndexApi,调用ping()方法来测试是否链接成功:

    @Slf4j@SpringBootTestpublic class IndexApi {        public static final String index = "study";    @Autowired    private RestHighLevelClient client;    @Test    public void ping() throws IOException {        if(client.ping(RequestOptions.DEFAULT)) {            log.info("链接成功");        }else {            log.info("链接失败 !");        }    }}

    点击IndexApi左上角的绿色箭头启动测试用例, 如果报错,尝试添加以下 注解

    @RunWith(SpringRunner.class)@SpringBootTest(classes = { EsStudyApplication.class })public class IndexApi {....}

    返回:

    链接成功

    说明客户端es服务端是通的

    创建索引 & create

    通过前面的学习,有了一定的基础之后,回到代码中其实就是调调方法,因为你知道了这个代码的逻辑做了什么操作。下面来看下如何创建索引:

        @Test    public void createIndex() throws IOException {        CreateIndexRequest request = new CreateIndexRequest(index);        CreateIndexResponse createIndexResponse = client.indices().create(request, RequestOptions.DEFAULT);        log.info("创建索引 ===> "+ JSONObject.toJSONString(createIndexResponse)); // 创建索引 ===> {"acknowledged":true,"fragment":false,"shardsAcknowledged":true}    }

    大家可以返回到kibana中查看索引是否被创建,从而验证代码执行是否成功

    添加别名:

    // aliasrequest.alias(new Alias("study_alias"));

    索引设置settings:

    // index settingsrequest.settings(        Settings.builder()                .put("index.number_of_shards", 3)                .put("index.number_of_replicas", 2));

    索引映射mapping:

     // index mappings//        {//            "mapping": {//            "_doc": {//                "properties": {//                    "name": {//                        "type": "text"//                    }//                }//            }//        }//        }XContentBuilder builder = XContentFactory.jsonBuilder();builder.startObject();{    builder.startObject("properties");    {        builder.startObject("name");        {            builder.field("type", "text");        }        builder.endObject();    }    builder.endObject();}builder.endObject();request.mapping(builder);

    设置请求超时时间:

    // 请求设置request.setTimeout(TimeValue.timeValueMinutes(1));

    索引是否存在 & exist

     @Testpublic void existIndex() throws IOException {    GetIndexRequest request = new GetIndexRequest(index);    boolean exists = client.indices().exists(request, RequestOptions.DEFAULT);    log.info("索引{}存在 ===> {}", index, exists);}

    删除索引

     @Testpublic void delIndex() throws IOException {    DeleteIndexRequest request = new DeleteIndexRequest(index);    AcknowledgedResponse delete = client.indices().delete(request, RequestOptions.DEFAULT);    log.info("删除索引 ===> {}", JSONObject.toJSONString(delete)); // 删除索引 ===> {"acknowledged":true,"fragment":false}}

    读到这里,这篇“ElasticSearch整合SpringBoot搭建配置的方法是什么”文章已经介绍完毕,想要掌握这篇文章的知识点还需要大家自己动手实践使用过才能领会,如果想了解更多相关内容的文章,欢迎关注编程网精选频道。

    --结束END--

    本文标题: ElasticSearch整合SpringBoot搭建配置的方法是什么

    本文链接: https://lsjlt.com/news/349747.html(转载时请注明来源链接)

    有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

    猜你喜欢
    • ElasticSearch整合SpringBoot搭建配置的方法是什么
      本文小编为大家详细介绍“ElasticSearch整合SpringBoot搭建配置的方法是什么”,内容详细,步骤清晰,细节处理妥当,希望这篇“ElasticSearch整合SpringBoot搭建配置的方法是什么”文章能帮助大家解决疑惑,下...
      99+
      2023-07-05
    • ElasticSearch整合SpringBoot搭建配置
      目录前言项目搭建配置客户端索引API初探 & Index APIping创建索引 & create索引是否存在 & exist删除索引结束语前言 目前正在出...
      99+
      2023-02-22
      ElasticSearch整合SpringBoot ElasticSearch SpringBoot
    • springboot整合druid及配置依赖的方法是什么
      本篇内容主要讲解“springboot整合druid及配置依赖的方法是什么”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“springboot整合druid及配置依赖的方法是什么”吧!Druid简...
      99+
      2023-06-22
    • Springboot redis整合配置的方法
      本文小编为大家详细介绍“Springboot redis整合配置的方法”,内容详细,步骤清晰,细节处理妥当,希望这篇“Springboot redis整合配置的方法”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。1...
      99+
      2023-06-19
    • SpringBoot整合aws的方法是什么
      这篇文章主要讲解了“SpringBoot整合aws的方法是什么”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“SpringBoot整合aws的方法是什么”吧!引入依赖  &...
      99+
      2023-06-21
    • SpringBoot整合Jackson的方法是什么
      这篇文章主要介绍了SpringBoot整合Jackson的方法是什么的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇SpringBoot整合Jackson的方法是什么文章都会有所收获,下面我们一起来看看吧。一、J...
      99+
      2023-07-05
    • springboot整合mongodb的方法是什么
      这篇文章主要介绍“springboot整合mongodb的方法是什么”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“springboot整合mongodb的方法是什么”文章能帮助大家解决问题。1.mo...
      99+
      2023-07-05
    • SpringBoot整合Swagger的方法是什么
      本文小编为大家详细介绍“SpringBoot整合Swagger的方法是什么”,内容详细,步骤清晰,细节处理妥当,希望这篇“SpringBoot整合Swagger的方法是什么”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知...
      99+
      2023-07-06
    • SpringBoot整合RocketMQ的方法是什么
      这篇文章主要介绍了SpringBoot整合RocketMQ的方法是什么的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇SpringBoot整合RocketMQ的方法是什么文章都会有所收获,下面我们一起来看看吧。1...
      99+
      2023-07-05
    • springboot整合多数据源配置的方式是什么
      这篇文章将为大家详细讲解有关springboot整合多数据源配置的方式是什么,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。简介主要介绍两种整合方式,分别是 springboot+mybati...
      99+
      2023-06-22
    • springboot hutool整合email的方法是什么
      本篇内容主要讲解“springboot hutool整合email的方法是什么”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“springboot hutool整合email的...
      99+
      2023-07-05
    • SpringBoot整合Lettuce redis的方法是什么
      这篇文章主要介绍了SpringBoot整合Lettuce redis的方法是什么的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇SpringBoot整合Lettuce redis的方法是什么文章都会有所收获,下面...
      99+
      2023-07-06
    • SpringBoot整合Thymeleaf视图的方法是什么
      这篇文章主要介绍了SpringBoot整合Thymeleaf视图的方法是什么的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇SpringBoot整合Thymeleaf视图的方法是...
      99+
      2024-04-02
    • SpringBoot整合JPA方法及配置解析
      目录JPA与Hibernate及Spring Data JPA的关系整合JPApom.xmlapplication.ymlPerson实体类PersonRepository接口Tes...
      99+
      2023-05-20
      Springboot整合JPA SpringBoot整合Java Persistence API
    • SpringBoot整合MybatisPlus配置多数据源增强插件的方法是什么
      本篇内容介绍了“SpringBoot整合MybatisPlus配置多数据源增强插件的方法是什么”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!...
      99+
      2023-06-02
    • SpringBoot整合Nacos自动刷新配置的方法
      本篇内容主要讲解“SpringBoot整合Nacos自动刷新配置的方法”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“SpringBoot整合Nacos自动刷新配置的方法”吧!目的Nacos作为S...
      99+
      2023-06-29
    • Springboot整合多数据源配置流程是什么
      这篇文章主要讲解了“Springboot整合多数据源配置流程是什么”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Springboot整合多数据源配置流程是什么”吧!主要介绍两种整合方式,分别...
      99+
      2023-07-05
    • Java springboot整合Shiro框架的方法是什么
      本篇内容主要讲解“Java springboot整合Shiro框架的方法是什么”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Java springboot整合Shiro框架的...
      99+
      2023-06-26
    • java SpringBoot项目整合Redis的方法是什么
      这篇文章主要介绍了java SpringBoot项目整合Redis的方法是什么的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇java SpringBoot项目整合Redis的方法是什么文章都会有所收获,下面我们...
      99+
      2023-07-05
    • Java SpringBoot整合JSP和MyBatis的方法是什么
      这篇文章主要介绍“Java SpringBoot整合JSP和MyBatis的方法是什么”,在日常操作中,相信很多人在Java SpringBoot整合JSP和MyBatis的方法是什么问题上存在疑惑,小编查阅了各式资料,...
      99+
      2023-07-05
    软考高级职称资格查询
    编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
    • 官方手机版

    • 微信公众号

    • 商务合作