[ES三周年]如何使用SpringBoot 整合ES_简讯
引言
平时我们存储数据用的最多的就是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_简讯
- 3月14日昨日连板板块涨幅达6%|天天报道
- 全球百事通!约不到九价怎么办?二价和四价还值得打吗?
- 环球今热点:藏族文化的组成包括_藏族文化
- 焦点热文:晶科科技:3月13日融资买入833.15万元,融资融券余额3亿元
- 宏组词两个字_宏组词 精选
- 利物浦客场对战伯恩茅斯比赛中的数据对比:射门数:...
- 科技要闻:尼康D3500是专为智能手机毕业生设计的数码单反相机_世界要闻
- 撒狗粮如何机智回复_对于撒狗粮的经典回复_每日关注
- 今日快讯:才下眉头却上心头全诗的意思_ldquo 才下眉头 却上心头 rdquo 是什么意思
- 天天热文:久坐不动致髋屈肌较弱 5项练习让它变强
- 世界要闻:过敏性鼻炎 到了高发期
- 哔哩哔哩虚拟主播大航海历史最高纪录TOP99盘点(截至2023年3月12日)
- 新型职业兴起,社保、劳务合同……各项保障如何跟上?_环球快资讯
- 快消息!不合格电三轮出事故,销售商被罚 11 万余元
- 避孕药哪里有卖多少钱一盒_避孕药哪个好
- 陈晓的“存货”还真不少,24小时内三部主演的电视剧官_世界焦点
- 世界观速讯丨疯狂兔子4合集_疯狂兔子4
- 天天热消息:原神:问题太多,米哈游却不管不问,每个游戏都有自己的坚持!
- 在双点校园全新的校园鬼魂DLC中捉鬼
- 环球快资讯丨邓建平个人资料简介_邓建国个人资料
- 当前时讯:国庆期间全国文化旅游市场产品供给丰富
- 微头条丨三个火字念什么
- 全球热消息:2元服装批发市场_2元服装批发
- 跳舞毯歌曲
- 阻焊层加铜箔什么意思_阻焊层 视焦点讯
- 35岁了还可以改名字吗_35岁了还可以改年龄吗|讯息
- 速读:工业级消泡剂商品报价动态(2023-03-10)
- 手工diy相册制作范本_手工diy相册制作范本_全球快消息
- 双钱牌梧州龟苓膏价格_双钱牌梧州龟苓膏
- 2023无锡扫墓临停道路汇总_天天即时看
- 爱的教育读后感100字_爱的教育读后感100字范文
- 2月全国CPI同比上涨1% 当前视讯
- 简笔画猪的画法最简单_简笔画猪的画法
- 平凡职业成就世界最强第二季什么时候出?(平凡职业成就世界最强第二季什么时候出)
- 逃离中国市场,PSA与FCA即将展开全球大整合,东风标雪和广汽菲克,尚能饭否?
- 热头条丨重庆大米价格多少钱一斤_大米价格多少钱一斤
- 全球微速讯:冬雨季施工费计取原则辽宁省_冬雨季施工费计取原则
- 研究确定了治疗子宫内膜癌的新治疗策略
- 新农保缴费档次和收益明细表_新农保
- 看点:购房者注意啦!河南将新增2项住房公积金“跨省通办”业务
- 全球报道:今日主力资金仅净流入航运和煤炭板块 净流出大金融、食品饮料、证券等板块
- 胜负彩23033期欧洲四大机构最新赔率(03.09)
- 保尔四次死里逃生的经历概括60_保尔四次死里逃生的经历概括
- 好时尚!华阳路街道这群奶奶围炉煮茶过节日
- 分式的基本性质(分式的基本性质)
- 中科信息工程东部校区_中科信息
- 策划书财务分析包括哪些内容_策划书财务分析怎么写 全球快资讯
- 满帮2022年总收入67.34亿元,同比增长44.6% 天天快看
- 守望先锋天梯怎么看自己的段位
-
世界要闻:2月铜价高位徘徊 3月消费有望回温 中旬后库存将逐步下降【SMM月度展望】
》查看SMM铜报价、数据、行情分析SMM3月8日讯:沪铜主力以69030元 吨的价格开启了2月的征程
-
怎么安装wifi无线上网_怎么安装wifi
1、买个无线路由器,如图一,找到路由器上的wan口,一般是蓝色的。2、找到你家内部或周围的网线,然后得...
-
三月你好,来一场说走就走的花海旅行吧 全球快播报
花海是贵州的主要旅游胜地。贵州省的花海,春、夏、秋、冬都有,而且规模很大,在全国范围内,甚至在世...
-
港股异动|煤炭股全线回落 中煤能源(01898)、兖矿能源(01171)均跌超4%-世界动态
智通财经获悉,煤炭股昨日表现强势,今日集体回落,截至发稿,蒙古焦煤(00975)跌5 07%,报3 18港元;中煤能源(
-
死得其所快哉快哉的意思
1、死得其所,快哉快哉,语出清代谭嗣同《秋雨年华之馆丛脞书·临终语》。意谓死得很有价值,真快活呀。...
-
快银是哪部电影中的人_快银是哪部电影
1、《X战警:逆转未来》是二十世纪福克斯电影公司出品的科幻动作电影,由布莱恩·辛格执导,休·杰克曼...
-
麻花钻 即时看
1、普通麻花钻是最常用的孔加工刀具,通常直径范围为0 25~80毫米。2、它主要由工作部分和柄部构成。3...
-
3月8日数据安全板块涨幅达2% 世界要闻
3月8日10点25分,数据安全板块指数报939 426点,涨幅达2%,成交58 27亿元,换手率1 65%。板块个股中...
-
win7设置开机密码怎么取消_win7怎么设置开机密码 新资讯
1、首先,用鼠标点击电脑桌面左下角的圆形“开始”按钮。2、在出现的开始菜单的右侧,单击管理员的头像...
-
朴基雄-环球新要闻
1、朴基雄,出生于1985年2月13日,韩国演员,毕业于庆北外国语大学。2、2005年,出演恐怖影片《怪谈壹:...
-
环球快资讯丨试图开舱门还用勺刺空乘 男子大闹美联航航班
试图开舱门还用勺刺空乘男子大闹美联航航班,舱门,飞机,机长,托雷斯,美联航航班
-
萨顿假说 环球焦点
1、沃尔特·萨顿(1877~1916)美国遗传学家,生物学家。2、他提出“基因在染色体上”。3、摩尔根及其学...
-
IPO项目平移大考后 投行完成率几多?这些投行100%完成 这些投行仅完成一半 观速讯
【IPO项目平移大考后投行完成率几多?这些投行100%完成这些投行仅完成一半】随着IPO在审企业平移工作结...
-
身残志坚、砥砺前行——广州白云湖街残疾人李永焰绘就亮丽人生画卷 焦点精选
南方网讯(记者 陈司悦见习记者 刘陈缘通讯员 白云湖街宣)“耳朵听不到的世界,我用眼睛来看见,用...
-
速看:成都会计证继续教育
1、首先登录四川省会计学会网站;2、点击“继续教育”专栏,选择继续教育网点;3、打开四川省会计学会网...
-
当前热门:新希望:公司资本投入主要是涉及配套饲料厂的建设、配套育肥场建设、部分种猪场改造,不涉及新增的养殖产能
同花顺金融研究中心3月7日讯,有投资者向新希望提问,公司计划2023年40亿的资本投入存量工程中,是不是...
-
环球快讯:俗话说良药苦口如果怕药苦可用甜水服苦药吗 用甜水喝药有影响吗
俗话说良药苦口如果怕药苦可用甜水服苦药吗用甜水喝药有影响吗部分药物不可行。对于有些通过苦味刺激消...
-
金圆股份董秘回复:公司捌千错项目2000吨产能生产线正在持续产出,虽尚未完全达产,但产能效率已进一步提升
金圆股份(000546)03月07日在投资者关系平台上答复了投资者关心的问题。
-
目成语生气_目成语 当前信息
1、“以耳代目”、“以耳为目”或“道路以目”或“拭目以待”。本文就为大家分享到这里,希望小伙伴们会...
-
极乐
1、极乐,梵文本意是幸福所在之处,大乘佛教用语,出处在净土宗圣经《净土三经》。2、极乐指的是阿弥陀...
-
03月07日10时天津昨日累计报告阳性感染者确诊2741例 怎么判断自己是否属于轻型感染者
新型冠状病毒传播性强,不侥幸,不冒险,情谊常在,聚会不急一时。03月07日10时天津昨日累计报告阳性感...
-
天天日报丨网络托管服务
1、网络托管业务是指受用户委托,代管用户自有或租用的国内的网络、网络元素或设备,包括为用户提供设备...
-
环球百事通!首届广州业余女子足球赛落幕,暨大女足夺得冠军
广州第一届业余女足联赛日前在广州拾号体育同创汇足球场落幕。经过几轮的较量,暨南大学女足以全胜战绩...
-
南网能源03月06日获深股通增持170.51万股
03月06日,南网能源获深股通增持170 51万股,已连续5日获深股通增持,共计898 29万股
-
何当金络脑|每日热门
1、《马诗·大漠沙如雪》是唐代诗人李贺创作的一首五言绝句,是《马诗二十三首》的第五篇。2、这首诗用...
-
锦绣谷瑞龙多久刷新_锦绣谷怎么去
2 在麋鹿村召唤一个飞骑,自己飞到锦绣谷;3 虽然锦绣谷已经被恩佐斯腐蚀,但是两个月神殿中的传送门...
-
刘敏涛的现任丈夫_刘敏涛的丈夫
1、2006年演技刘敏涛嫁给了一位做地产生意的商人,后来离婚了,目前单身。2、她是一位低调不炒作的演员...
-
3个字古风网名_求三个字唯美古风名字
1、画卿颜、千堆雪、云中书、莫言歌、梦倾笙、玉笙寒、樟木板、画卿晚、雕花影、陌南尘、风启觞、清笑歌...
-
路虎揽胜运动版电车_揽胜运动版电动踏板 当前资讯
2 各种中高配车型都可以装,发现4、神行者2、发现漫步、极光、卡宴、玛卡、大切诺基、牧马人、探险者、...
-
120亿天量资金出逃浪潮信息,深股通及机构净卖超7亿|全球快看
3月6日,浪潮信息(000977 SZ)股价盘中反复触及跌停,最终收盘跌超9%。公司成交额119 25亿元,创出历...
-
电脑辐射对女性的危害_电脑辐射的危害你知道吗
1、 辐射是指在自然界中,物体只要在绝对温度之上,都会以电磁波的形式向外散发热量,辐射就是传送能...
-
2022湖南卫视春节联欢节目表_2022湖南卫视春节联欢晚会 天天观热点
1、2022湖南卫视春节联欢晚会。2、由湖南卫视主办。3、于2022年1月26日(农历腊月二十四日)晚7:30在湖南卫视
-
三星Galaxy S21系列价格再次泄漏这既是好消息也是坏消息
好吧,三星的泄漏周期将在2020年再次发生。到现在,显然,三星无法控制GalaxyS21信息泄漏,而信息泄漏现...
-
世界上有多少种兔子
兔是兔形目兔科动物,共9属43种,通称兔。兔具有管状长耳朵,耳长大于耳宽数倍,簇状短尾,比前肢长得多...
-
小儿调理脾胃最有效的方法_健宝灵片的功效与作用 每日讯息
1、健保灵片具有健脾和胃的功效,用于治疗厌食和病后虚弱的患者。2、健保灵片以银耳为原料,滋阴润燥;...
-
三态门的主要用途_三态门
1、高电平,低电平,高阻态称为三态 可以具备这三种状态的器件就叫做三态(门,总线, ) 高电平,
-
WAZ:德雷克斯勒肌肉受伤,将无法出战鲁尔德比
据WAZ报道,沙尔克中场德雷克斯勒大腿肌肉受伤,将继续无法上场,将错过对阵多特蒙德的鲁尔区德比。他也...
-
微束冷焊机
1、微束冷焊机是当今高科技的产物被誉为“精密模具修补。本文到此分享完毕,希望对大家有所帮助。
-
涠洲岛在哪里
涠洲岛在广西壮族自治区北海市北部湾海域中部,其总面积为24 74平方千米。涠洲岛是火山喷发堆凝而成的...
-
残疾人创业者陆鸿获评感动中国人物 颁奖典礼后 “阿甘厂长”胆子大了一把-天天观点
3月4日晚,《感动中国》2022年度人物颁奖典礼上,“阿甘厂长”陆鸿憨憨的笑容感染了所有人。他是一名脑...
-
每日速看!office小姐
1、百圈OL相册频道人气电影。本文到此结束,希望对大家有所帮助。
-
ppt怎么修改背景图片_ppt背景怎么修改
1、更改母版版式 在PowerPoint2007中创建的演示文稿都带有默认的版式,这些版式一方面决定了占位符、
-
沙和尚的性格特点
1、沙僧外貌丑恶,但个性憨厚,忠心耿耿。他不像孙悟空那么叛逆,也不像猪八戒那样好吃懒惰、贪恋女色,...
-
五项管理和双减政策_五项
1、YY五项分别为:散磕、套词、另类、MC、说唱。2、五项的发展已有十几年之久,最早在传奇里盛行,发展...
-
刺球仙人掌_刺球|热消息
1、刺球放在电脑旁有防辐射和净化空气美化环境的作用。2、 刺球是一种茎、叶、花均有较高观赏价值,它...
-
风雪佳人绯颜,诗末晨曦古韵(第三弹)
诶!说的就是你这个可爱的家伙!看过来嘛!对应视频在这里啦!末尾有全部参数哦~风雪佳人绯颜,诗末晨曦...
-
承包商是什么意思
承包商是指有一定生产能力、技术装备、流动资金,具有承包工程建设任务的营业资格,在建筑市场中能够按...
-
当前速讯:输卵管造影多久可以复查一次_输卵管造影多少钱
1、输卵管造影一般由两个科室做,要在月经干净后3-7天做,这几天应该没有室友史。2、血管造影时,由妇科...
-
中国国企排行榜前十名 中国十大大型国有企业-环球今日讯
国有企业值得是由中央和地方国有资产监督管理机构和其他部分所监管的企业,是一种追求国有资产的保值增...
-
陈婉婷:江苏无锡女足本赛季保5争3 希望更多赞助商投资女超
3月4日进行的首轮女超联赛,江苏无锡女足主场0-0战平了杭州银行女足。赛后,江苏无锡女足主帅陈婉婷点评...
X 关闭
X 关闭