[ES三周年]如何使用SpringBoot 整合ES

2023-03-14 23:06:40 来源: 腾讯云

引言

平时我们存储数据用的最多的就是mysql,在前面的文章里我也分享过很多关于mysql的知识,今天我们来集成另外一种数据存储系统ES,它是一款NoSql型数据库,主要使用场景有商品搜索,文章搜索等,关键词就是搜索。 我们先简单介绍下ES。 ​

Elasticsearch是一个基于Lucene的搜索服务器。它提供了一个分布式多用户能力的全文搜索引擎,基于RESTful web接口。Elasticsearch是用Java语言开发的,并作为Apache许可条款下的开放源码发布,是一种流行的企业级搜索引擎。Elasticsearch用于云计算中,能够达到实时搜索,稳定,可靠,快速,安装使用方便 ​

这是来自于百度百科的解释,其实我们就直接把它理解成搜索引擎就行了,接下来,我们就开始快速集成,然后上手使用吧! ​


(相关资料图)

安装ES

本篇介绍的是如何通过docker安装es,提前你得有docker环境 ​

拉取ES镜像

docker pull elasticsearch:7.6.2复制代码

创建挂载目录

mkdir -p /Users/lezai/docker/volumes/data/elasticsearch/config/mkdir -p /Users/lezai/docker/volumes/data/elasticsearch/datamkdir -p /Users/lezai/docker/volumes/data/elasticsearch/plugins复制代码

编辑配置文件

vim /Users/lezai/docker/volumes/data/elasticsearch/config/elasticsearch.yml复制代码

elasticsearch.yml

http.host: 0.0.0.0复制代码

运行执行脚本

docker run --name elasticsearch -p 9200:9200  -p 9300:9300 \ -e "discovery.type=single-node" \ -e ES_JAVA_OPTS="-Xms256m -Xmx256m" \ -v /Users/lezai/docker/volumes/data/elasticsearch/config/elasticsearch.yml:/usr/share/elasticsearch/config/elasticsearch.yml \ -v /Users/lezai/docker/volumes/data/elasticsearch/data:/usr/share/elasticsearch/data \ -v /Users/lezai/docker/volumes/data/elasticsearch/plugins:/usr/share/elasticsearch/plugins \ -d elasticsearch:7.6.2复制代码

安装成功后

在浏览器输入 http://localhost:9200,如果出现以下内容,则代表安装成功

{  "name" : "43e2638f84ac",  "cluster_name" : "elasticsearch",  "cluster_uuid" : "hZKT7NQNRl-Dg2Xrb3isGg",  "version" : {    "number" : "7.6.2",    "build_flavor" : "default",    "build_type" : "docker",    "build_hash" : "ef48eb35cf30adf4db14086e8aabd07ef6fb113f",    "build_date" : "2020-03-26T06:34:37.794943Z",    "build_snapshot" : false,    "lucene_version" : "8.4.0",    "minimum_wire_compatibility_version" : "6.8.0",    "minimum_index_compatibility_version" : "6.0.0-beta1"  },  "tagline" : "You Know, for Search"}复制代码

配置项目

添加必要依赖

                    org.springframework.boot            spring-boot-starter-data-elasticsearch                            org.springframework.boot            spring-boot-starter-test            test                                    org.projectlombok            lombok            1.18.18            复制代码

添加实体

其实这里的实体对应的就是ES索引 @Document(indexName = "sys_user") 代表映射的是sys_user 索引 @Field(type = FieldType.Keyword) 代表字段应设在es中是keyword类型 ​

这里就不介绍过多的ES用法 ​

package com.aims.springbootes.entity;import lombok.Builder;import lombok.Data;import org.springframework.data.annotation.Id;import org.springframework.data.elasticsearch.annotations.Document;import org.springframework.data.elasticsearch.annotations.Field;import org.springframework.data.elasticsearch.annotations.FieldType;import java.io.Serializable;import java.util.List;@Document(indexName = "sys_user")   //文档@Data@Builderpublic class SysUser implements Serializable {    @Id //主键    private String id;  //ES中id不能定义为Long    private String username;    private String password;    private int level;    @Field(type = FieldType.Keyword)    private List roles;}复制代码

添加操作es的dao

ElasticsearchRepository 遵循Spring-data的规范,所以操作es,就相当于我们使用jpa去操作数据库一样

package com.aims.springbootes.dao;import com.aims.springbootes.entity.SysUser;import org.springframework.data.domain.Page;import org.springframework.data.domain.Pageable;import org.springframework.data.elasticsearch.repository.ElasticsearchRepository;import org.springframework.stereotype.Repository;import java.util.List;/** * 第一种方式,类似于JPA,编写一个ElasticsearchRepository *  第一个泛型为Bean的类型 *  第二个泛型为Bean的主键类型 */@Repositorypublic interface SysUserDao extends ElasticsearchRepository {}复制代码

添加配置信息

spring:    elasticsearch:      rest:        uris: http://localhost:9200复制代码

编写test,测试添加数据到ES中

这里通过往ES中塞入1000条数据,我们运行下,但是我们现在不知道有没有插入进去。

@Test    public void testInsert() {        List list = new ArrayList<>();        list.add("teacher");        list.add("student");        list.add("admin");        list.add("leader");        for (int i = 0; i < 1000; i++) {            int toIndex = new Random(1).nextInt(4);            SysUser build = SysUser.builder()                    .password("123456")                    .username("AI码师")                    .level(i)                    .roles(list.subList(0, toIndex))                    .build();            sysUserDao.save(build);        }        System.out.printf("结束");    }复制代码

在编写一个查询的,来验证是否插入成功

@Test    public void testFindAll(){        Iterable all = sysUserDao.findAll();        all.forEach((sysUser)->{            System.out.printf(sysUser.getId());        });    }复制代码

到这已经集成了ES,更多Spring-Data语法可以参考JPA的写法,在IDEA中会有很多智能提示,帮助你写的。 ​

集成Spring-data-es后的思考

使用spring-data-es 提供的ElasticsearchRepository 只能进行简单的增删改查操作,如果碰到一些稍微复杂的聚合操作,他就很难应付了,所以这里有几个建议: ​

如果只需要做简单增删改查操作,直接继承ElasticsearchRepository即可如果项目中有非常复杂的查询或聚合操纵,可以使用结合ElasticsearchRestTemplate做一些复杂的操作,这个包不需要再引用其他依赖,已经集成在spring-data-es里面了。

​如何利用客户端快速编写ES 语句

这里我要介绍一款软件 kibana,它和es是老组合了,通过它能够直接连接es,直接在页面编写ES语句,值得一提的是它的语法智能提示简直不要太棒了

Docker安装kibana

拉取镜像

这个一定要和es的版本保持一致,防止api不兼容

docker pull kibana:7.6.2复制代码

创建挂载目录

mkdir -p /Users/lezai/docker/volumes/data/kibana/config/复制代码

编辑配置文件

`vim /Users/lezai/docker/volumes/data/kibana/config/kibana.yml

## ** THIS IS AN AUTO-GENERATED FILE **## Default Kibana configuration for docker targetserver.name: kibanaserver.host: "0"elasticsearch.hosts: [ "http://elasticsearch:9200" ]xpack.monitoring.ui.container.elasticsearch.enabled: true

标签:

[ES三周年]如何使用SpringBoot 整合ES

平时我们存储数据用的最多的就是mysql,在前面的文章里我也分享过很多关于mysql的知识,今天我们来集成另...

03-14 23:06:40

允儿:不雅照流出,乳房私处清晰可见十分不雅,疑似自摸还呻吟不止?-每日观察

允儿:不雅照流出,乳房私处清晰可见十分不雅,疑似自摸还呻吟不止?,韩国,润娥,模特,乐器,林允儿,张允贞,不...

03-14 20:18:42

【播资讯】市值蒸发3000亿,海底捞的内卷式服务也受不了“白嫖”了?

文|华商韬略600近日,有网友在社交平台上曝出:海底捞不能点4个清水锅了。而海底捞方面回应,今年新规定...

03-14 17:42:08

黑暗森林理论是什么_黑暗森林理论 环球热资讯

1、黑森林理论指:宇宙就是一座黑暗森林,每个文明都是带枪的猎人,像幽灵般潜行于林间,轻轻拨开挡路的...

03-14 15:51:18

当前消息!华为售后服务网点查询电话_华为售后服务网点查询

1、第一步:先点击打开华为手机“服务”软件。2、第2步,然后点击页面中的“店铺维修”。3、第三步,选...

03-14 13:55:50

割席断交的故事450字_割席断交的故事

1、原文:管宁、华歆共园中锄菜。2、见地有片金,管挥锄与瓦石不异,华捉而掷去之。3、又尝同席读书,有...

03-14 11:03:16

天天观点:rank和rankl_rankeq与rank的区别

1、rankeq和rank是Excel表格中的函数,作用是给数据排序,rank和rankeq本身没有区别。2、关闭Exc

03-14 09:03:21

2022年职工产假能休息多长时间

女职工生育享受98天产假,其中产前可以休假15天;难产的,增加产假15天;生育多胞胎的,每多生育1个婴儿...

03-14 05:54:29

王者荣耀:达到前所未有的段位以后,该如何继续,一定要补位吗?

哈喽大家好,我是铃铛儿~几乎所有的玩家都会被一个相同的问题所困扰,那就是当自己达到了前所未有的段位...

03-13 23:57:24

调档线是不是最低分_调档线

1、调档线就是高校调取考生档案的最低控制线。2、每一所院校都有自己的投档分数线,在填报了该校志愿且...

03-13 20:06:54

华夏幸福董事会“换血” 老将大部分留任 赵威晋升总裁

经过年初境外债成功展期,华夏幸福的债务重组进度已接近8成,同时也完成了新一届董事会换血。近期华夏幸...

03-13 17:52:59

快消息!保诚公布获纳入沪港通机制

保诚(02378)发布公告,保诚于香港联合交易所交易的股份现已获纳入沪港通机制。这是保诚继于去年获纳入...

03-13 15:28:46

诸葛亮明明在北伐的路上一直失败,为什么还要继续坚持?

诸葛亮,是三国时期蜀汉的丞相。他在位期间,主要负责蜀汉的政治、

03-13 12:59:04

海通证券首次试点上交所CDS储架发行_热点

近日,海通证券成功发行了信用保护凭证“23海通w1”,该券为海通证券首次针对客户持仓的存续期公募AA+公...

03-13 10:29:26

华尔街押注加息将放缓 黄金交易性机会凸显

纽约黄金期货周五攀升,并在本周录得涨幅。周五公布的数据显示美国在2月份创造了31 1万个新工作岗位,...

03-13 08:39:00

吃什么对女性子宫跟卵巢有好处_吃什么对子宫修复好_头条

1、如果想保养子宫,可以选择以下食物:完全植物雌激素食物,包括大豆、谷类小麦、黑米、葵花籽、洋葱、...

03-13 03:49:59

大专怎么备考注册会计-今日快看

首先了解考试的内容,根据考试大纲,去复习重点基础的内容,然后制定好科学的备考方案,严格遵守。规划...

03-12 21:52:54

动静脉内瘘的健康教育_动静脉内瘘的健康日常

正确的吃法。1 取优质蛋白质,如鸡蛋、牛奶、酸奶、牛肉、猪肉、鱼肉。2 充分补充热量。3 避免摄入过...

03-12 17:46:49

上次写小作文痛骂扎鸟的罗马球迷代表Marco C...

上次写小作文痛骂扎鸟的罗马球迷代表MarcoConidi在ins上发文响应了罗马球迷协会的呼吁,希望罗马球迷现...

03-12 14:18:03

今日看点:刚装修好的房子多久可以入住(刚装修好的房子多久可以入住)

1、新装修完的房子多久能住人是所有业主最关心的问题,按正常情况来说刚装修完的房子是不能立即居住的。...

03-12 10:24:39

斗破苍穹:萧炎与迦南学院院长的“孽缘”,苏千:这学白上了-世界报资讯

导语:萧炎与迦南学院院长的孽缘萧炎大家都不会陌生了,三年之约完结后便来到了迦南学院修行,在迦南学...

03-12 05:57:07

全球百事通!研究:枪支暴力成美儿童"头号杀手" 黑人儿童被枪击概率是白人100倍

资料图:美国警方在枪击案现场海外网3月11日电美国医学协会所属期刊《JAMA网络开放版》3月8日发布的一项...

03-11 23:47:49

世界新消息丨Docker - 搭建Mysql PXC高可用集群环境部署

ps:设置如果报错,去配置文件修改,去掉最后的一个逗号,路径vim etc docker daemon json ,修改配置...

03-11 19:15:01

世界视点!属牛上等命出生时辰 子时出生受命运眷顾

有的人生来就是有很好的运势的,这是他们出生的时间和日期能够决定的,我们是可以结合出生的生辰五行来...

03-11 15:29:12

蝶美膜力小铺是干什么的_蝶美膜力小铺是干什么的

1、蝴蝶胶片店介绍如下:2、蝴蝶膜店是国内新一代护肤品牌,采用多店经营模式,产品多元化。3、蝴蝶膜店...

03-11 12:47:25

少女的诱惑_说一说少女的诱惑的简介 最新资讯

夏弥来为大家解答以下的问题,少女的诱惑,说一说少女的诱惑的简介,现在让我们一起来看看吧!1、《少女...

03-11 11:46:49

香港将和珠海探讨发展国际货运业务 短讯

3月11日电,据香港特区政府公报,香港特区政府运输及物流局局长林世雄3月10日率领十多位香港物流发展局...

03-11 08:07:13

全球快看点丨寄托家园论坛

1、一般的说法是,无论你自己怎么算,美国人会重新给你计算的。2、另外,有的学校申请出国的人比较多。3...

03-11 07:24:37

退热药的治疗效果_退热药包括哪些

1、解热药是指能使发热患者体温恢复正常,但对正常体温无影响的药物,通常有中度镇痛作用。2、常用的解...

03-11 06:03:43

魔兽世界怀旧服急救150了去哪里学_魔兽世界怀旧服急救150以后去哪学-全球微头条

1、联盟的玩家在150级之后要去阿拉希高地的激流堡,看到路口后往右转去联盟NPC德尼布那购买道具就能升到...

03-11 00:36:20

今日看点:人人租车

1、武汉市人人汽车租赁有限公司是经工商部门批准并登记注册的正规合法机构,是一家从事专业武汉租车、武...

03-10 21:55:45

抗震伸缩缝

1、抗震伸缩缝是具有良好抗震性能的伸缩缝。2、利用支撑和转轴运动原理。3、有效的解决桥梁伸缩缝在受到...

03-10 21:02:37

三七分身材是黄金比例_朴孝敏黄金比例身材 世界要闻

1、这方面数据没曝光过。2、不知。3、但在nicebody的MV里服装上有标明三围342436,你可以理解为是孝敏的真实

03-10 18:18:46

长城大脚兽-世界速讯

1、长城赛弗是一款经济型SUV,它在路上的加速性不算突出,2 3排量的长城赛弗最高时速为130km h。2、不过在动力表

03-10 16:25:31

重庆工伤预防体验式教学直通车“驶入”企业

心肺复苏、触电应急救援、VR事故体验……3月10日,重庆中小微企生产人员工伤预防体验式教学直通车“驶入...

03-10 16:11:07

别克E5:5座中大型纯电SUV,配30英寸连屏,内饰外观发布

去年凯迪拉克上市了一款重磅SUV,这款SUV就是被通用寄予厚望的LYRIQ锐歌。由于这款新车是凯迪拉克首款真...

03-10 14:00:49

正式服怎么去熔火之心城堡_正式服怎么去熔火之心

1、做AG的御风者飞到黑石塔附近的点,一直往里走,岩浆上面的锁链桥连接的小房子门口有个血精灵。2、对...

03-10 10:34:19

美国家庭资产四季度反弹至147.71万亿美元 房地产价值缩水约1000亿美元 环球速递

去年年底,美股上涨将财富重新注入到美国人的口袋中,但房地产价值下降、信贷增长放缓以及企业利润下降...

03-10 07:01:07

dnf王的遗迹在哪里_dnf王的遗迹

1、《地下城与勇士》是一款由韩国网络游戏公司NEOPLE开发的2D网络游戏。游戏继承了很多家用手机和街机的...

03-10 04:27:27

挽联对逝者称呼大全_挽联的意思

1、挽联含义:是哀悼死者、治丧祭祀时专用的对联。2、它是对死人哀悼,也是对活人的慰勉,有其社会性,...

03-10 01:55:44

天天速讯:打了败仗要找人背锅?乌克兰或爆发内乱,地方政府下令:收缴民间武器

近日,在俄乌冲突愈演愈烈之际,乌克兰总统泽连斯基突然批准撤掉5名国家安全局官员的职位。值得注意的是...

03-09 21:44:21

环球微速讯:最新各省市汽车补贴和车企降价消息一览

近日,湖北省联合东风集团推出史无前例的高额汽车补贴,掀起价格战狂潮,并蔓延至全国各地。以下汇总了...

03-09 19:17:32

焦点速讯:外星小子哆布哆演员表真诚_外星小子哆布哆演员表

1、香奈儿饰演:马以黄誉博饰演:帅克郑伟饰演:钮寇贺瑞文饰演:甄诚蔡文凯饰演:高升唐旭饰演:甄实李...

03-09 18:43:26

无锡人才房需要在锡工作满多久可以申请?

无锡人才房需要在锡工作满多久可以申请?根据政策,没有规定工作年限哦符合以下条件可以购买人才房:1、...

03-09 17:22:33

第十三双眼睛原版试听禁曲_第十三双眼睛原版试听

1、哥们现在这3大禁曲都已经是绝版了,第13双眼睛和忏魂曲在几十年前已经被彻底销毁了,黑色星期天据说...

03-09 16:01:30

好老师的标准是什么呢_好老师的标准是什么

1、当代教师优秀品质教师论坛实录一、教师既不是天使也不能成为妖魔社会对老师的评价有两个极端,一个是...

03-09 14:03:10

百事通!天蝎女喜欢一个人的表现 超准知乎_天蝎女喜欢一个人的表现

1、本人天蝎女,以前外在给人感觉很冷很难靠近,现在恰恰相反,性格有时候会因为一些经历和一些事件改变...

03-09 13:13:17

蓝科高新董秘回复:感谢关注蓝科高新!电解槽设备正在进行技术研发,技术参数还在不断调整和优化中

蓝科高新(601798)03月09日在投资者关系平台上答复了投资者关心的问题。

03-09 11:33:06

热讯:贝宁总统采访中赞扬“中国模式”遭法国主持人插话 当场犀利回怼

据法国新闻台(LCI)6日报道,贝宁总统帕特里斯·塔隆近日接受专访时,赞扬中国为发展中国家起到榜样模范作用

03-09 10:04:31

中国杂志铺官网_杂志铺官方网站-天天快消息

1、还是不错的。2、我家买的书现在一些课外杂志都在这家买的。3、还介绍了些朋友买。4、他们都说还挺便...

03-09 07:59:14

允儿:不雅照流出,乳房私处清晰可见十分不雅,疑似自摸还呻吟不止?-每日观察
【播资讯】市值蒸发3000亿,海底捞的内卷式服务也受不了“白嫖”了?
黑暗森林理论是什么_黑暗森林理论 环球热资讯
当前消息!华为售后服务网点查询电话_华为售后服务网点查询
割席断交的故事450字_割席断交的故事
天天观点:rank和rankl_rankeq与rank的区别
2022年职工产假能休息多长时间
王者荣耀:达到前所未有的段位以后,该如何继续,一定要补位吗?
调档线是不是最低分_调档线
华夏幸福董事会“换血” 老将大部分留任 赵威晋升总裁
快消息!保诚公布获纳入沪港通机制
诸葛亮明明在北伐的路上一直失败,为什么还要继续坚持?
海通证券首次试点上交所CDS储架发行_热点
华尔街押注加息将放缓 黄金交易性机会凸显
吃什么对女性子宫跟卵巢有好处_吃什么对子宫修复好_头条
大专怎么备考注册会计-今日快看
动静脉内瘘的健康教育_动静脉内瘘的健康日常
上次写小作文痛骂扎鸟的罗马球迷代表Marco C...
今日看点:刚装修好的房子多久可以入住(刚装修好的房子多久可以入住)
斗破苍穹:萧炎与迦南学院院长的“孽缘”,苏千:这学白上了-世界报资讯
全球百事通!研究:枪支暴力成美儿童"头号杀手" 黑人儿童被枪击概率是白人100倍
世界新消息丨Docker - 搭建Mysql PXC高可用集群环境部署
世界视点!属牛上等命出生时辰 子时出生受命运眷顾
蝶美膜力小铺是干什么的_蝶美膜力小铺是干什么的
少女的诱惑_说一说少女的诱惑的简介 最新资讯
香港将和珠海探讨发展国际货运业务 短讯
全球快看点丨寄托家园论坛
退热药的治疗效果_退热药包括哪些
魔兽世界怀旧服急救150了去哪里学_魔兽世界怀旧服急救150以后去哪学-全球微头条
今日看点:人人租车
抗震伸缩缝
三七分身材是黄金比例_朴孝敏黄金比例身材 世界要闻
长城大脚兽-世界速讯
重庆工伤预防体验式教学直通车“驶入”企业
别克E5:5座中大型纯电SUV,配30英寸连屏,内饰外观发布
正式服怎么去熔火之心城堡_正式服怎么去熔火之心
美国家庭资产四季度反弹至147.71万亿美元 房地产价值缩水约1000亿美元 环球速递
dnf王的遗迹在哪里_dnf王的遗迹
挽联对逝者称呼大全_挽联的意思
天天速讯:打了败仗要找人背锅?乌克兰或爆发内乱,地方政府下令:收缴民间武器
环球微速讯:最新各省市汽车补贴和车企降价消息一览
焦点速讯:外星小子哆布哆演员表真诚_外星小子哆布哆演员表
无锡人才房需要在锡工作满多久可以申请?
第十三双眼睛原版试听禁曲_第十三双眼睛原版试听
好老师的标准是什么呢_好老师的标准是什么
百事通!天蝎女喜欢一个人的表现 超准知乎_天蝎女喜欢一个人的表现
蓝科高新董秘回复:感谢关注蓝科高新!电解槽设备正在进行技术研发,技术参数还在不断调整和优化中
热讯:贝宁总统采访中赞扬“中国模式”遭法国主持人插话 当场犀利回怼
中国杂志铺官网_杂志铺官方网站-天天快消息
gaggenau是什么牌子_gaggenau是什么意思
X 广告
资讯
X 广告

Copyright ©  2015-2022 每日畜牧网版权所有  备案号:浙ICP备2022016517号-15   联系邮箱:5 146 761 13 @qq.com