首页 > 代码库 > Redis 系列 - 1 【简要介绍】 - 它是什么?它用来做什么?它的优势与短板如何?

Redis 系列 - 1 【简要介绍】 - 它是什么?它用来做什么?它的优势与短板如何?


1.0 前提

阅读目的: 对什么是内存型数据库有概念性的认知。?

阅读需知:有关Redis系列的博文,大致有以下的5篇博文。本ID将陆续补充。   


 本ID  Redis系列

   1 . 0 :首先,这是您在Redis的官方网站:

            http://www.redis.cn/

    1.1      您需要成功的下载,安装,并且配置好Redis。 有关过程请参考本ID的另外的一篇博文:

            Redis 系列 - 2 【安装与配置】

     1.2     如果您需要了解Redis的设计与实现,请参考本ID博文:

          Redis 系列 - 3 【Redis的设计与实现】

      1.3    如果您需要了解Redis的 客户端,请参考本ID的其他博文:

        Redis 系列 - 4 【Redis 客户端 - JRedis的详细解析】

      1.4  如果您需要了解 Redis与Storm是如何整合的,那么请参考本ID的博文:

        Redis系列 -5 【Storm-redis-pubsub】 -Storm接口系列

    ?  1.5  如果您需要了解,抑或是在使用的过程之中出现了问题,请参考本ID的另外的博文

    ?    ?Redis系列 - 6 【疑难杂症与问题诊断】 - QA时间。

       如果以上的博文存在任何的纰漏,亦或您对本ID的博文有任何疑问,观点,建议,请及时给我反馈。多谢您的阅读。

Redis 是什么?

    通常而言目前的数据库分类有几种,包括 SQL/NSQL,,关系数据库,键值数据库等等 等,分类的标准也不以,Redis本质上也是一种键值数据库的,但它在保持键值数据库简单快捷特点的同时,又吸收了部分关系数据库的优点。从而使它的位置处于关系数据库和键值数 据库之间。Redis不仅能保存Strings类型的数据,还能保存Lists类型(有序)和Sets类型(无序)的数据,而且还能完成排序(SORT) 等高级功能,在实现INCR,SETNX等功能的时候,保证了其操作的原子性,除此以外,还支持主从复制等功能。

  更为详细的描述请参考如下:

        http://code.google.com/p/redis/wiki/index

  Redis官方也同样提供了一个名为Retwis的项目代码,可以对照着官方学习。

2 Redis用来做什么?

        通常局限点来说,Redis也以消息队列的形式存在,作为内嵌的List存在,满足实时的高并发需求。而通常在一个电商类型的数据处理过程之中,有关商品,热销,推荐排序的队列,通常存放在Redis之中,期间也包扩Storm对于Redis列表的读取和更新。

        一个详细的示范用例,还请参考本ID的另外一篇博文: Storm 【topN】 排序。期间使用的是:Storm-redis-pubsub的接口

3 Redis的优点
  • 性能极高 – Redis能支持超过 100K+ 每秒的读写频率。

  • 丰富的数据类型 – Redis支持二进制案例的 Strings, Lists, Hashes, Sets 及 Ordered Sets 数据类型操作。

  • 原子 – Redis的所有操作都是原子性的,同时Redis还支持对几个操作全并后的原子性执行。

  • 丰富的特性 – Redis还支持 publish/subscribe, 通知, key 过期等等特性。

4 Redis的缺点

是数据库容量受到物理内存的限制,不能用作海量数据的高性能读写,因此Redis适合的场景主要局限在较小数据量的高性能操作和运算上。

    总结: Redis受限于特定的场景,专注于特定的领域之下,速度相当之快,目前还未找到能替代使用产品。

 

Redis 系列 - 1 【简要介绍】 - 它是什么?它用来做什么?它的优势与短板如何?