转载于: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 也会带来昂贵的代价,所以使用时务必谨慎。

相关热词搜索:

 

最新文章

  1. 关于ES6新增的东西
  2. Uncaught ReferenceError: WebForm_DoPostBackWithOptions is not defined
  3. 高性能网站架构设计之缓存篇(1)- Redis的安装与使用
  4. hibernate HQL和Criteria
  5. flask+sqlite3+echarts2+ajax数据可视化--静态图
  6. .NET软件工程师面试总结
  7. IOS设计模式-简单工厂
  8. JavaScript显示输出
  9. JavaScript Type Conversion
  10. oc-20-多态
  11. poj2014 不带修改区间第k大树
  12. 有两个数组a,b,大小都为n,;通过交换a,b中的元素,使sum(a)-sum(b)最小。
  13. C/C++用strncpy()与strstr()分割与匹配查找字符串
  14. CSS3动画效果示例
  15. 前端笔记之服务器&Ajax(上)服务器&PHP&数据交互&HTTP
  16. Ansible playbook 部署Openresty
  17. Asp.Net HttpPostedFile和base64两种上传图片(文件)方式
  18. python3 使用libvirt 相关安装
  19. 【洛谷】3960:列队【Splay】
  20. rman备份恢复命令之switch

热门文章

  1. OD使用教程7
  2. 1260: [CQOI2007]涂色paint
  3. 国内首个微信小程序开发者社区www.mntuku.cn
  4. 利用xtraBackup实现不停master服务做主从同步
  5. sky简介
  6. C程序员学bash shell容易掉坑的注意点(未完待续)
  7. Inno setup定制安装界面
  8. PERL/LEX/YACC技术实现文本解析--XML解析
  9. 转载:JProfiler远程监控LINUX上的Tomcat过程细讲
  10. 织梦cms、帝国cms、PHPcms优缺点解析