`
zhaomengsen
  • 浏览: 212003 次
  • 性别: Icon_minigender_1
  • 来自: 河北
社区版块
存档分类
最新评论

Redis数据库的使用场景介绍(避免误用Redis)

阅读更多
转载于:http://www.itxuexiwang.com/a/shujukujishu/redis/2016/0216/122.html?1455854235
Redis 是目前 NoSQL 领域的当红炸子鸡,它象一把瑞士军刀,小巧、锋利、实用,特别适合解决一些使用传统关系数据库难以解决的问题。但是 Redis 不是银弹,有很多适合它解决的问题,但是也有很多并不适合它解决的问题。另外,Redis 作为内存数据库,如果用在不适合的场合,对内存的消耗是很可观的,甚至会让系统难以承受。
我们可以对系统存储使用的数据以两种角度分类,一种是按数据的大小划分,分成大数据和小数据,另一种是按数据的冷热程度划分,分成冷数据和热数据,热数据是指读或写比较频繁的数据,反之则是冷数据。
可以举一些具体的例子来说明数据的大小和冷热属性。比如网站总的注册用户数,这明显是一个小而热的数据,小是因为这个数据只有一个值,热是因为注册用户数随时间变化很频繁。再比如,用户最新访问时间数据,这是一个量比较大,冷热不均的数据,大是数据的粒度是用户级别,每一个用户都有数据,如果有一千万用户,就意味着有一千万的数据,冷热不均是因为活跃用户的最新访问时间变化很频繁,但是可能有很大一部非活跃用户访问时间长时间不会发生变化。
大体而言,Redis 最适合处理的是小而热,而且是写频繁,或者读写都比较频繁的热数据。对于大而热的数据,如果其它方式很难解决问题,也可以考虑使用 Redis 解决,但是一定要非常谨慎,防止数据无限膨胀。原因如下:
首先,对于冷数据,无论大小,都不建议放在 Redis 中。Redis 数据要全部放在内存中,资源宝贵,把冷数据放在其中实在是一种浪费,冷数据放在普通的存储比如关系数据库中就好了。
其次,对于热数据,尤其是写频繁的热数据,如果量比较小,是最适合放到 Redis 中的。比如上面提到的网站总的注册用户数,就是典型的 Redis 用做计数器的例子。再比如论坛最新发表列表,最新报名列表,可以控制数量在几百到一千的规模,也是典型的 redis 做最新列表的使用方式。
另外,对于量比较大的热数据(或者冷热不均数据​),使用 Redis 时一定要比较谨慎。这种类型数据很容易引起数据膨胀,导致 Redis 消耗内存巨大,让系统难以承受。薄荷的一个惨痛教训是把用户关注(以及被关注)数据放在 Redis 中,这是一种数据量极大,冷热很不均衡的数据,在几百万的用户级别就占用了近 10 GB左右内存,让 Redis 变得难以应付。应对这种类型的数据,可以用普通存储 + 缓存的方式。
如果用对了地方,比如在小而热的数据情形,Redis 表现很棒,如果用错了地方,Redis 也会带来昂贵的代价,所以使用时务必谨慎。
相关热词搜索:

分享到:
评论

相关推荐

    redis禁止几个危险命令的方法

    更好的做法是,如果不希望使用这些危险命令,应当从应用程序层面避免触发它们,或者通过其他方式确保数据安全,例如限制对 Redis 的访问权限,使用 ACL(Access Control Lists)进行细粒度控制,或者设置严格的备份...

    Redis禁用命令、危险命令及规避方法

    Redis,作为一个高性能的键值数据库,提供了一系列丰富的命令来满足各种数据操作需求。然而,其中的一些命令如果在不当的情况下使用,可能会对数据安全或者系统稳定性造成严重的影响。本篇文章主要聚焦于两个非常...

    Redis的持久化方案.pdf(两种持久化方案:RDB 和 AOF,共15页)

    Redis是一种高性能的键值数据库,它提供了两种主要的数据持久化机制:RDB(Redis Database Backup)和AOF(Append Only File)。这两种方法各有特点,适用于不同的场景。 #### RDB 持久化方案 **概述** RDB方式...

    NoSQL误用和常见陷阱分析

    在NoSQL数据库的使用过程中,一种常见的误用是循环网络调用,这通常发生在开发者没有充分利用NoSQL数据库的批量操作能力时。例如,在使用Memcached或Redis时,如果对多个键值进行单独查询而不是一次性批量查询,将会...

    几种主流No SQL的测试和比较

    不当使用NoSQL数据库可能导致一系列副作用,如Redis被误用为持久化存储或MongoDB复制集配置不当,这些问题都需在实际部署中予以充分考虑。 #### 总结与展望 NoSQL数据库为现代大数据应用带来了新的可能性,但也...

    CTF之信息泄漏.pdf

    - **MongoDB、Redis、ZooKeeper**:数据库服务。 - **ElasticSearch、Memcache、CouchDB**:数据存储服务。 - **Docker、Solr、Hadoop、Dubbo**:容器化、搜索、大数据处理及微服务框架。 **示例:Redis未授权访问*...

Global site tag (gtag.js) - Google Analytics