聊聊redis和Elasticsearch

redis和Elasticsearch比较

项目RedisElasticsearch
介绍Redis是内存中的数据结构存储,用作数据库,缓存和消息代理Elasticsearch是一个基于Apache Lucene的现代搜索和分析引擎
主数据库模型键值存储搜索引擎
DB-Engines排名得分120.41总排名第9,key-value存储排名第7得分120.00总排名第10,搜索引擎排名第1
网站redis.iowww.elastic.co/cn/elasticsearch
技术文档redis.io/documentationwww.elastic.co/cn/elasticsearch/features
由开发Salvatore Sanfilippo
初始发行20092010
当前版本5.0.8,2020年3月7.6.1,2020年3月
许可证信息开源开源
基于云的信息没有没有
实现语言CJava
支持的操作系统BSD Linux OS X Windows所有带有Java VM的操作系统
数据scheme无scheme无scheme
打字局部
XML支持 没有
二级索引没有
SQL没有没有
API和其他访问方法专有协议Java API RESTful HTTP / JSON API
支持的编程语言C C#C ++ Clojure Crystal D Dart Elixir Erlang Fancy Go Haskell Haxe Java JavaScript(Node.js)Lisp Lua MatLab Objective-C OCaml Perl PHP Prolog Python R Rebol Ruby Rust Scala Smalltalk Tcl.Net Clojure Erlang Go Groovy Haskell Java JavaScript Lua Perl PHP Python Ruby Scala
服务器端脚本Lua
触发器没有
分区方法拆分拆分
复制方法主从复制
MapReduce的没有没有
一致性概念最终的一致性最终的一致性
外键没有没有

应用场景

elasticsearch、redis的应用场景是怎样的?

ElasticSearch

ES场景
分布式的搜索引擎和数据分析引擎,全文检索,结构化检索,数据分析
对海量数据进行近实时的处理,站内搜索(电商,招聘,门户,等等), IT 系统搜索( OA , CRM , ERP ,等等),数据分析

ES不是一个数据库,而是一个搜索引擎,ES的方方面面也都是围绕搜索设计的。ES支持全文搜索,这里简单解释下什么是全文搜索:对于“我在北京的一家互联网公司工作”这样的数据,如果你搜索“北京”、“互联网”、“工作”这些关键词都能命中这条数据的话,这就是全文搜索,你每天都在用的百度、Google都属于全文搜索。值得一提的是,ES的全文搜索对中文也有很好的支持(单是中文分词器就有很多种),绝对能够满足国内大多数人的全文搜索需求。除了搜索之外,ES还会自动的替你对所有字段建立索引,以实现高性能的复杂聚合查询,因此只要是存入ES的数据,无论再复杂的聚合查询也可以得到不错的性能,而且你再也不用为如何建立各种复杂索引而头痛了。

ES也有很多的短处,最明显的就是字段类型无法修改、写入性能较低 和 高硬件资源消耗。                                                                 前边讲到ES会自动的替你建立索引,尽管这能给全文搜索以及聚合查询带来很多好处还能替你省了建索引这一麻烦事,但是这个特性也会带来一堆问题。ES需要在创建字段前要预先建立Mapping,Mapping中包含每个字段的类型信息,ES需要根据Mapping为字段建立合适的索引。由于这个Mapping的存在,ES中的字段一但建立就不能再修改类型了。(例如,你建的数据表的某个字段忘了加全文搜索,你想临时加上,但是表已经建好并且已经有很多数据了,这时候该怎么办呢?不好意思,你只能把整个数据表删了再重建一遍!!!)                                                                                                                                                                                     自动建立索引使得ES的写入性能也收到了影响,明显低于MongoDB。对于同样的数据ES占用存储空间也要明显大于MongoDB(建那么多索引能不占空间吗?),对硬件资源的消耗也是非常厉害,大数据量下64G内存+SSD基本是标配,算得上是数据库中的贵族服务了,因此如果你的老板很小气,对于ES的选用可要慎重喽!

redis 

redis场景
常规计数:粉丝数,微博数;用户信息变更;缓存处理,作为 mysql 的缓存;队列系统,建有优先级的队列系统,日志收集系统

Redis是现在最热门的key-value数据库。它与MongoDB同在2009年发布,也同样是早期大数据时代的数据库代表作。

Redis的最大特点当然就是key-value存储所带来的简单和高性能了。                                                                                                    所谓key-value存储,就是每一条记录只包含一个用于查询数据的Key,以及与之对应的存储数据的value,就如同现实生活中的门牌号与住户,而没有诸如表、字段这些常规数据库中必需有的复杂概念,所有的查询都仅仅依赖于key值。因此,key-value数据库可谓是数据库中数据结构最简单的一种,也得益于这种简单的结构,再加上Redis会把所有数据加载到内存中的,Redis能得到远高于MongoDB这类常规数据库的读写性能。当然,Redis的功能还不止key-value存储这么简单,相较它的key-value前辈Memcached,Redis还支持数据持久化,list、set等多种数据结构,主从复制备份等一些列功能,因此Redis绝对称得上是key-value数据库中功能最全面、最简单易用的款。

Redis的key-valule存储带来了性能这个优势,但是也给复杂查询带来了很多局限。                                                                            由于阉割掉了数据表、字段这样的重要特性,且所有的查询都依赖key,因此Redis无法提供常规数据库所具备的多列查询、区段查询等复杂查询功能。同时,由于Redis需要把数据存在内存中,这也大大限制了Redis可存储的数据量,这也决定了Redis难以用在数据规模很大的应用场景中。

Redis牺牲了常规数据库中的数据表、复杂查询等功能,换来了很大的性能提升,特别适合那些对读写性能要求极高,且数据表结构简单(key-value、list、set之类)、查询条件也同样简单的应用场景。如果你的数据表结构还挺复杂,你还经常需要做一些复杂查询操作,那你最好还是老老实实用MongoDB或者SQL吧。

总结

如果你对数据的读写要求极高,并且你的数据规模不大,也不需要长期存储,选redis

如果你的数据规模较大,对数据的读性能要求很高,数据表的结构需要经常变,有时还需要做一些聚合查询,选MongoDB

如果你需要构造一个搜索引擎或者你想搞一个看着高大上的数据可视化平台,并且你的数据有一定的分析价值或者你的老板是土豪,选ElasticSearch

如果你需要存储海量数据,连你自己都不知道你的数据规模将来会增长多么大,那么选HBase

  • 18
    点赞
  • 72
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: RedisElasticsearch是两种不同的数据库系统,它们的主要区别在于: 1. 数据存储方式不同:Redis是一种基于内存的键值存储系统,而Elasticsearch是一种基于文档的搜索引擎。 2. 数据查询方式不同:Redis主要用于缓存和快速读取数据,支持简单的键值查询和一些基本的数据结构操作,如列表、集合、有序集合等;而Elasticsearch则是专门用于全文搜索和分析数据,支持复杂的查询和聚合操作。 3. 数据处理能力不同:Redis具有高速读写能力和高并发处理能力,适合处理大量的短期数据;而Elasticsearch则具有强大的搜索和分析能力,适合处理大量的长期数据。 4. 数据一致性不同:Redis是一种单机数据库,数据存储在内存中,因此不支持数据持久化和高可用性;而Elasticsearch是一种分布式数据库,支持数据持久化和高可用性,可以通过副本和分片来保证数据的一致性和可靠性。 总之,RedisElasticsearch是两种不同的数据库系统,各有其优缺点和适用场景,需要根据具体的业务需求来选择合适的数据库系统。 ### 回答2: RedisElasticsearch是两个不同的开源软件,用于不同的用途。 首先,Redis是一种高性能的内存数据库。它是一种键值存储系统,可以将数据保存在内存中,以提供快速的读写操作。Redis支持多种数据结构,如字符串、哈希、列表、集合和有序集合,这使得它非常适合用作缓存和实时计算等场景。Redis还提供了一些高级功能,如发布/订阅、事务和持久化。因为Redis将数据存储在内存中,所以它的读写速度非常快,但是由于数据存储在内存中,所以有可能受到内存限制的约束。 而Elasticsearch是一种全文搜索和分析引擎。它使用分布式搜索和分析引擎Apache Lucene作为其核心引擎,提供了一个强大的搜索和分析平台。Elasticsearch支持快速的全文搜索、实时数据分析和可视化等功能。它能够处理大量的数据,并且支持高可用性和分布式部署。Elasticsearch还提供了丰富的查询语言和API,用于构建复杂的搜索和分析操作。因为Elasticsearch使用磁盘存储数据,所以可以处理大规模的数据集。 综上所述,RedisElasticsearch在功能和应用场景上都有所不同。Redis适合于数据缓存和实时计算等场景,而Elasticsearch适合于全文搜索和数据分析等场景。根据具体的需求,可以选择合适的软件来满足不同的应用需要。 ### 回答3: Redis是一个开源的内存数据结构存储系统,而Elasticsearch是一个开源的分布式搜索和分析引擎。 首先,它们的用途不同。Redis主要用于高速读写的非关系型数据库,支持多种数据结构,包括字符串、列表、哈希、集合、有序集合等。它提供了快速的数据存取和数据处理能力,适合作为缓存、队列、消息发布-订阅系统等使用。而Elasticsearch则是用于全文搜索、分析和实时数据处理的引擎,通过对大量数据进行索引,提供了强大的搜索和分析功能。 其次,它们的存储方式也不同。Redis将数据存储在内存中,因此具有快速的读写速度,适合处理对性能要求较高的场景。而Elasticsearch则将数据存储在分布式文件系统中,以实现数据的持久化和高可用性。 另外,它们的查询语言也不同。Redis使用类似于键值对的方式进行数据查询,可以通过键获取值,并支持一些简单的操作,如增删改查。而Elasticsearch则使用基于JSON的查询语言,可以进行复杂的全文搜索、聚合分析等操作。 此外,Elasticsearch具备分布式特性,可以将数据分散存储在多个节点上,实现数据的分片和复制,提高了系统的可扩展性和容错性。而Redis在分布式方面的支持较弱,需要借助其他工具才能实现分布式存储和高可用性。 综上所述,RedisElasticsearch在用途、存储方式、查询语言和分布式特性等方面存在一些区别。根据实际需求,可以选择合适的数据库来满足业务的需求。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值