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

谈谈Memcached与Redis(四)

 
阅读更多

3.2 Redis和Memcached的集群实现机制对比

Memcached是全内存的数据缓冲系统,Redis虽然支持数据的持久化,但是全内存毕竟才是其高性能的本质。作为基于内存的存储系统来说,机器物理内存的大小就是系统能够容纳的最大数据量。如果需要处理的数据量超过了单台机器的物理内存大小,就需要构建分布式集群来扩展存储能力。
3.2.1 Memcached的分布式存储
Memcached本身并不支持分布式,因此只能在客户端通过像一致性哈希这样的分布式算法来实现Memcached的分布式存储。图6 给出了Memcached的分布式存储实现架构。当客户端向Memcached集群发送数据之前,首先会通过内置的分布式算法计算出该条数据的目标节点,然后数据会直接发送到该节点上存储。但客户端查询数据时,同样要计算出查询数据所在的节点,然后直接向该节点发送查询请求以获取数据。
3.2.2 Redis的分布式存储
相较于Memcached只能采用客户端实现分布式存储,Redis更偏向于在服务器端构建分布式存储。尽管Redis当前已经发布的稳定版本还没有添加分布式存储功能,但Redis开发版中已经具备了Redis Cluster的基本功能。预计在2.6版本之后,Redis就会发布完全支持分布式的稳定版本,时间不晚于2012年底。下面我们会根据开发版中的实现,简单介绍一下Redis Cluster的核心思想。
Redis Cluster是一个实现了分布式且允许单点故障的Redis高级版本,它没有中心节点,具有线性可伸缩的功能。图7给出Redis Cluster的分布式存储架构,其中节点与节点之间通过二进制协议进行通信,节点与客户端之间通过ascii协议进行通信。在数据的放置策略上,Redis Cluster将整个key的数值域分成4096个哈希槽,每个节点上可以存储一个或多个哈希槽,也就是说当前Redis Cluster支持的最大节点数就是4096。Redis Cluster使用的分布式算法也很简单:crc16( key ) % HASH_SLOTS_NUMBER。
为了保证单点故障下的数据可用性,Redis Cluster引入了Master节点和Slave节点。如图4所示,在Redis Cluster中,每个Master节点都会有对应的两个用于冗余的Slave节点。这样在整个集群中,任意两个节点的宕机都不会导致数据的不可用。当Master节点退出后,集群会自动选择一个Slave节点成为新的Master节点。
3.3 Redis和Memcached整体对比
Redis的作者Salvatore Sanfilippo曾经对这两种基于内存的数据存储系统进行过比较,总体来看还是比较客观的,现总结如下:
1)性能对比:由于Redis只使用单核,而Memcached可以使用多核,所以平均每一个核上Redis在存储小数据时比Memcached性能更高。而在100k以上的数据中,Memcached性能要高于Redis,虽然Redis最近也在存储大数据的性能上进行优化,但是比起Memcached,还是稍有逊色。
2)内存使用效率对比:使用简单的key-value存储的话,Memcached的内存利用率更高,而如果Redis采用hash结构来做key-value存储,由于其组合式的压缩,其内存利用率会高于Memcached。
3)Redis支持服务器端的数据操作:Redis相比Memcached来说,拥有更多的数据结构和并支持更丰富的数据操作,通常在Memcached里,你需要将数据拿到客户端来进行类似的修改再set回去。这大大增加了网络IO的次数和数据体积。在Redis中,这些复杂的操作通常和一般的GET/SET一样高效。所以,如果需要缓存能够支持更复杂的结构和操作,那么Redis会是不错的选择。
 
分享到:
评论

相关推荐

    memcache与redis

    通过《谈谈Memcached与Redis》这篇文档,我们可以深入理解这两种技术的原理、优缺点,并根据具体需求选择合适的缓存解决方案。同时,文档可能还会涵盖安装配置、优化技巧以及实际案例分析,帮助读者更好地掌握和应用...

    存储cache文档+论文.rar

    此外,还有分布式缓存系统,如Memcached和Redis,它们为应用提供高性能的数据缓存服务,特别适用于数据库的读取优化。 在“PD201909300945191818677”这份文档或论文中,可能详细探讨了上述存储技术的实现、优化...

    互联网 Java 工程师面试题1000道500页

    6. **缓存技术**:Memcached和Redis都是高速缓存,面试中会讨论它们的区别、应用场景、数据结构及操作命令。 7. **数据库**:MySQL是常用的SQL数据库,面试会涉及SQL优化、事务、索引、存储引擎等相关知识。 8. **...

    轻松实现Apache_Tomcat集群和负载均衡

    可以使用分布式会话管理,例如Memcached或Redis来存储会话信息。 2. **修改Tomcat配置**:在每个Tomcat实例的server.xml文件中,添加`<Cluster>`元素,配置集群通信协议(如TCP)和序列化机制。 3. **复制应用程序...

    pHP信电系网站建设设计.zip

    对于性能优化,可以使用索引来加快数据库查询速度,合理设计数据库表结构以减少冗余,以及使用缓存技术如Memcached或Redis来减少数据库访问。 在开发过程中,版本控制工具如Git可以帮助团队协作和管理代码。使用...

    谈谈业务中使用分布式的场景1

    另一种解决方案是利用Memcached这类内存数据库,但效率较低。 **分布式事务**:随着业务复杂度的增加,单体应用的事务管理变得困难。分布式事务解决方案如TCC(Try-Confirm-Cancel),通过预操作、确认和补偿机制...

    谈谈MYSQL那点事.ppt

    架构优化则可能涉及主从复制(Master/Slave)、分表分片、分布式数据库,以及利用缓存服务如Redis或Memcached来缓解数据库压力。此外,优化查询语句、事务管理、数据库设计和数据分布也是提升性能的关键。例如,避免...

    互联网高频Java后端面试题20道(适合1~3年)V1.0.46.docx

    问题 13:请解释 Redis 与 Memcached 的异同,以及它们各自适用的场景。答案:Redis 和 Memcached 都是高性能的内存数据存储,常用于缓存。Redis 支持更多数据结构(如字符串、列表、哈希表等),支持持久化,可以...

    气泡提示与文本框绑定事件与缓存

    在服务器端,应用可能会使用内存缓存(如Redis或Memcached)或数据库缓存来加速数据检索。 综合以上,气泡提示和文本框绑定事件关注的是提升用户体验和增强交互性,而缓存技术则旨在优化性能和响应速度。在实际项目...

    nginx+tomcat的负载均衡session共享和ant构建全流程

    2. 共享存储:使用Redis、Memcached等缓存服务作为共享存储,将Session数据持久化并由所有Tomcat实例访问。 3. 使用Cookie或URL重写来携带Session ID,让服务器根据ID查找对应的Session。 接下来,我们谈谈ANT。Ant...

    大型网站技术架构:核心原理与案例分析

    3. **缓存技术**:为了加速数据访问,大型网站会广泛使用缓存,如Redis或Memcached,以减少数据库的读取压力。缓存策略包括页面缓存、对象缓存和数据库查询缓存等。 4. **数据库集群**:单一数据库难以应对大量并发...

    saleor的二次开发,微信支付宝支付加入django,saleor上传文件,商品页修改.zip

    例如,使用Redis或Memcached作为缓存系统,以减少数据库查询;利用Celery或其他异步任务框架处理耗时操作,如发送邮件通知、生成PDF发票等,以提高系统响应速度。 总结来说,这个项目涵盖了Saleor的深度定制,包括...

    网络游戏-无线数据网络中的分布式缓存和再分布系统及其方法.zip

    常见的分布式缓存系统有Redis、Memcached等,它们能够提供高并发、低延迟的数据访问。 其次,无线数据网络环境下的网络游戏需要面对带宽限制、网络抖动等问题。分布式缓存通过预加载热门游戏资源到离玩家最近的缓存...

    Galbanum.Orm源代码

    本地缓存适用于单机应用,而分布式缓存适用于多服务器环境,例如使用Redis或Memcached。通过合理利用缓存,可以显著降低数据库负载,提升系统响应速度。 再来说说Galbanum的Logger模块。日志记录对于软件的调试、...

    vagrant安装包2.2.19 windows

    Homestead是Laravel官方推荐的开发环境,它是一个预配置的Vagrant Box,包含了开发Laravel应用所需的所有组件,如Nginx web服务器、PHP、Composer、MySQL、PostgreSQL、Redis、Memcached等。使用Homestead,开发者...

    海量数据库的查询优化及分页算法方案 - CSDNBlog

    4. **数据库缓存**:使用如Redis或Memcached等内存数据库作为缓存,可以存储经常访问的数据,减少对硬盘的读取,提高响应速度。 5. **分区和分片**:将大表分为多个小表,可以分散负载,提高查询效率。分区通常是...

    PHP实例开发源码—DSShop TP5框架B2C开源商城源码(单店铺).zip

    8. **性能优化**:缓存技术的应用,如页面静态化、Redis或Memcached的使用,以提高系统响应速度。 9. **SEO优化**:通过设置元标签、URL重写等方式提高搜索引擎的友好性,提升网站的流量。 10. **移动适配**:考虑...

    服务器端代码(异步,大并发)

    6. **缓存优化**:使用缓存(如Redis或Memcached)来减少对后端数据库的访问,降低延迟,提升性能。 7. **数据库优化**:例如使用主从复制、分区、索引等策略,提高数据库的并发处理能力。 8. **硬件升级**:增加...

    PHP面试题(最牛)

    - **缓存机制**:使用缓存策略减轻数据库压力,如Memcached或Redis。 #### 7. PHP的意思 PHP是Hypertext Preprocessor的缩写,是一种通用开源脚本语言,尤其适用于Web开发,可以嵌入HTML中。 #### 8. MYSQL取得...

    一份超级全面的PHP面试题

    - **缓存机制**:使用如Redis等缓存技术来存储常用查询结果,减少数据库负担。 ### 7. PHP的意思(送1分) - **知识点**:PHP代表“PHP: Hypertext Preprocessor”,是一种广泛使用的开源服务器端脚本语言。 ### ...

Global site tag (gtag.js) - Google Analytics