飞道的博客

SpringBoot整合Elasticsearch 分布式搜索详解

315人阅读  评论(0)

Elasticsearch 是一个分布式、可扩展、实时的搜索与数据分析引擎。 它能从项目一开始就赋予你的数据以搜索、分析和探索的能力,这是通常没有预料到的。 它存在还因为原始数据如果只是躺在磁盘里面根本就毫无用处。
Elasticsearch 不仅仅只是全文搜索,我们还将介绍结构化搜索、数据分析、复杂的人类语言处理、地理位置和对象间关联关系等。 我们还将探讨为了充分利用 Elasticsearch 的水平伸缩性,应当如何建立数据模型,以及在生产环境中如何配置和监控你的集群

1.安装Elasticsearch

Elasticsearch官网安装

如果下载慢点话,请使用网盘下载安装

链接: https://pan.baidu.com/s/1h4gyeZ3vnS5n8dAQYK9rFg 密码: 9scr
其他的es开发,请大家一定要认真的看,官网的中文教程文档:elasticsearch

下载启动成功后,访问浏览器:
http://localhost:9200/

看到这个界面后,就是启动成功了。

Elasticsearch 基础语法使用:

创建索引,类型,文档:

PUT /megacorp/employee/1
{
    "first_name" : "John",
    "last_name" :  "Smith",
    "age" :        25,
    "about" :      "I love to go rock climbing",
    "interests": [ "sports", "music" ]
}

注意,路径 /megacorp/employee/1 包含了三部分的信息:

  • megacorp

    索引名称

  • employee

    类型名称

  • 1

    特定雇员的ID

增加多个文档数据时:

PUT /megacorp/employee/2
{
    "first_name" : "John",
    "last_name" :  "Smith",
    "age" :        25,
    "about" :      "I love to go rock climbing",
    "interests": [ "sports", "music" ]
}

查询所有索引:_cat/indices?v

get http://localhost:9200/_cat/indices?v

查询单个索引信息:

get http://localhost:9200/megacorp

删除索引:

delete http://localhost:9200/megacorp

轻量查询

GET http://localhost:9200/megacorp/_search

指定查询:

GET http://localhost:9200/megacorp/_search?q=title:小明

使用表达式查询:

GET /megacorp/_search
{
    "query" : {
        "match" : {
            "last_name" : "Smith"
        }
    }
}

全文搜索:

有喜欢 about : rock 或者 clilmbing 的数据,都会检索出来

GET /megacorp/_search
{
    "query" : {
        "match" : {
            "about" : "rock climbing"
        }
    }
}

短语搜索:

执行这样一个查询,仅匹配同时包含 “rock” “climbing”

GET /megacorp/_search
{
    "query" : {
        "match_phrase" : {
            "about" : "rock climbing"
        }
    }
}

高亮搜索:

GET /megacorp/_search
{
    "query" : {
        "match_phrase" : {
            "about" : "rock climbing"
        }
    },
    "highlight": {
        "fields" : {
            "about" : {}
        }
    }
}
about //查询字段名称

这里大家可以用Postman 工具自己去测试一下。

像我这样就好了。megacorp 就是索引,也就是图上的shopping大家自己创建的索引是什么就改一下。

springBoot集成Elasticsearch

详细集成实例请看官方文档: spring-data-elasticsearch

1.pom依赖:

 <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-data-elasticsearch</artifactId>
        </dependency>

2.yml配置:

spring:
  elasticsearch:
    rest:
      uris: http://localhost:9200
      username: elasticsearch

3.使用代码操作es

新建一个接口继承 ElasticsearchRepository 就可以使用其中的方法了,并且还可以自定义方法去执行

public interface BookRepository extends ElasticsearchRepository<Book,Integer> {

    List<Book>  findByName(String name);
}

测试代码:

  @Autowired
    BookRepository bookRepository;

    /**
     * 新建文档
     */
    @Test
    void contextLoads() {
        Book book = new Book();
        book.setId(1);
        book.setName("小明");
        bookRepository.index(book);
    }

    /**
     * 查询数据
     */
    @Test
    void getBook(){
        List<Book> byName = bookRepository.findByName("小明");
        System.out.println(byName);
    }

其他好玩的,请自行读文档,调试开发,实例代码在github上面需要的请自行拉取:spring-boot-integrate
然后后续会集成更多的模块进去,需要请点个star。有问题下方讨论一起学习


转载:https://blog.csdn.net/qq_41971087/article/details/116334454
查看评论
* 以上用户言论只代表其个人观点,不代表本网站的观点或立场