美文网首页
Redis学习笔记(二)Redis与同类产品的比较

Redis学习笔记(二)Redis与同类产品的比较

作者: 萌妈码码 | 来源:发表于2018-10-14 14:06 被阅读0次

    本文摘自Redis学习(一) Redis初步入门

    Redis和同类产品的比较

    根据Redis的简介,Redis可用作数据库高速缓存消息队列代理,那么当你打算使用它们这些功能的时候,可以考虑一下与其他产品的对比,选出一个更好用的。

    1.1 做为数据库与之比较

    Redis是可以做为数据库来使用的,它可以看做一个key/value型数据库,因为Redis会根据配置定时将内存中的数据写入到硬盘中,这样即便重启以后依然可以恢复,但是有几个缺点需要考虑一下:

    • Redis只能存储key/value类型,虽然value的类型可以有多种,但是对于关联性的记录查询,没有Oracle/Mysql方便。
    • Redis内存数据写入硬盘有一定的时间间隔,在这个间隔内数据可能会丢失,虽然后续会介绍各种模式来保证数据丢失的可能性,但是依然会有可能,所以对数据有严格要求的不建议使用Redis做为数据库。

    1.2 做为高速缓存与之比较

    我觉得Redis的本职工作还是高速缓存,同样可以做为缓存的有Ehcache、Memcached 。有一篇博客介绍的很详细:http://blog.csdn.net/jationxiaozi/article/details/8509732。我就简单总结一下,只说它们最大的特点,读取速度不再考虑范围之内,毕竟能作为相互比较的缓存工具,速度不会差的太多,只列出较为突出的优点和缺点,列出来表示其他没有:

    Ehcache

    • 是一个Java开源项目,使用的方式就是引入一个jar包,非常方便

    Memcached

    • 如果开启多线程模式,读取速度将有极大的提高
    • 数据只会存储在内存中,挂掉后数据不可恢复

    Redis

    • 数据结构非常丰富,字符串、hash列表、list、Set等等
    • 支持主从,Sentinal,分片等多种高级特性,用于负载均衡和容灾,具有高可用性
    • 几乎支持所有语言的客户端

    根据需求选择最合适的。

    1.3 做为消息队列与之比较

    Redis也是可以做为消息队列的,与之相同功能比较优秀的就是Kafka,简单比较如下:

    Redis

    • 只能说具备发布订阅功能,一个或多个消费者订阅一个频道

    Kafka

    • 高级特性一应俱全,集群、负载均衡、动态扩容、数据备份等

    这么说,如果能用Kafka就用Kafka,对于数据不敏感的一般场景也是可以应用Redis的。

    相关文章

      网友评论

          本文标题:Redis学习笔记(二)Redis与同类产品的比较

          本文链接:https://www.haomeiwen.com/subject/mdizaftx.html