中间件 - ElasticSearch

前言

6题。

为什么要用ES?

从mysql为什么不行来说

数据量大又涉及到模糊查询。

涉及到分词查询。

什么是倒排索引?

倒排索引其实就是分词查询

  1. 分词:把原始内容分词,分词后和原始文档有对应关系;

  2. 查询:根据分词可以获取到原始文档。

ES中的查询关键字有哪些(方法)?

  1. term :精确查询;
  2. match :分词查询(模糊查询);
  3. range :范围查询;
  4. bool :复合查询;

must与、should或、must_not非、filter

  1. geo_distance :地理位置查询。

ES中字符串类型有几个?

keywordTextkeyword类型是不会分词的,Text类型会分词。

ES中query和filter的区别?

都可以实现ES中的查询,区别是:

  1. query查询操作不仅仅会进行查询,还会计算分值;

  2. filter查询操作仅判断是否满足查询条件,不会计算任何分值,也不会关心返回的排序问题。

如何保证ES和MySQL的数据一致性?

有以下四种方式:

  1. 同步双写 :如果是分布式项目,通过fegin进行远程调用;

  2. 异步消息 :通过MQ发消息(微服务之间);

  3. canel监听 :使用canel监听MySQLbinlog日志,当发现写入操作后,立即读取内容,写入ES

  4. logstatsh :使用开源的数据搜索引擎logstatshMySQL中的数据实时传输给ES。

相关推荐
bxlj_jcj1 小时前
解锁Java多级缓存:性能飞升的秘密武器
java·缓存·面试·架构
工呈士1 小时前
React 性能监控与错误上报
前端·react.js·面试
前端小巷子2 小时前
JS中的 eval
前端·javascript·面试
Dignity_呱2 小时前
玩转Vue插槽:从基础到高级应用场景(内含为何Vue 2 不支持多根节点)
前端·vue.js·面试
异常君2 小时前
Java 逃逸分析:让你的代码性能飙升的秘密
java·面试·代码规范
迢迢星万里灬2 小时前
Java求职者面试:Spring、Spring Boot、Spring MVC与MyBatis技术深度解析
java·spring boot·spring·面试·mybatis·spring mvc
掘金安东尼3 小时前
🧭 前端周刊第416期(2025年5月26日–6月1日)
前端·javascript·面试
xrz2774 小时前
JAVA获取ES连接并查询所有数据
java·elasticsearch
赵成默4 小时前
es 的字段类型(text和keyword)
elasticsearch·es
汪子熙5 小时前
Angular NG04002 错误概述
前端·javascript·面试