elasticsearch 与 传统数据库的区别与选用

elasticsearch 与 传统数据库的区别与选用

1:ES

ElasticSearch是一款分布式全文检索框架,底层基于Lucene实现。

ElasticSearch 使用 JSON 格式存储数据,属于文档存储

 

2:遍历方式

ES有分片的概念,一个大的索引会被分成多个分片来进行存储数据,使用分布式的架构对分片进行并行搜索(基于倒排)

传统数据库的遍历,属于正向全表扫描

 

3:ES采用倒排索引,传统数据库采用B+树索引

倒排索引:

对文本进行分词处理,记录单词,词频,文本id等信息,搜索时基于内容(根据单词和词频词向量等来计算评分)来找文本id

B+树索:

一种树的数据结构,存储时会根据内容生成一个数节点,搜索时时跟据节点id来查找内容数据结构,存储时会根据内容生成一个数节点,搜索时时跟据节点id来查找内容

4:es的注意点

ES没有事务的概念,不支持回滚,无法恢复删除数据

 

5 : 选用

在面对大数据量简单计算的时候es的效率原高于mysql等传统数据库,但是在定位某一个唯一值(如用会员id找会员)时并不需要es

但在大数据的相似计算与查找或简单计算时,es的分布式并行计算有绝对的优势

 

  • 3
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值