本文介绍: 书接前文,马不停蹄,博主继续书写Cache的传奇和精彩。Redis主要用于数据分布式缓存通过设置缓存集群实现数据快速响应,同时也解决缓存一致性的困扰。EhCache主要用于数据的本地缓存,因无法保障数据的安全性,通常用于单节点数据的缓存。如果需要实现分布式可以搭载Redis实现二级缓存。MemCache,它又有哪些独一无二的绝技呢?请各位盆友紧随博主,以防“迷路”。微服务实战系列之EhCache服务实战系列之Redis服务实战系列之Cache服务实战系列之Nginx技巧篇)
前言

书接前文,马不停蹄,博主继续书写Cache的传奇和精彩。
Redis主要用于数据的分布式缓存通过设置缓存集群实现数据的快速响应,同时也解决了缓存一致性的困扰。
EhCache主要用于数据的本地缓存,因无法保障数据的安全性,通常用于单节点数据的缓存。如果需要实现分布式,可以搭载Redis实现二级缓存

今天博主带来Cache成员MemCache,它又有哪些独一无二的绝技呢?请各位盆友紧随博主,以防“迷路”



在这里插入图片描述

Q:什么是MemCache

看到MemCache一词,首先想到什么内存。可见它又是一款基于内存的缓存工具。那继续看官方如何定义的,请转向:

MemCache一个免费开源高性能的分布式内存对象缓存系统,旨在通过减轻数据库负载来加速动态web应用程序
MemCache开放的API可支持Java、C/C++/C#、Perl、Python、PHP、Ruby等大部分流行的程序语言

通过以上描述,表明MemCache支持分布式,倘若我们构建分布式缓存时,又多了一件选择的武器。

在这里插入图片描述

既然提到了分布式,那是如何实现的呢?我们继续期待。

Q:MemCache如何实现分布式

这首先要看MemCache如何运转的。

1. 内存机制

MemCache是一个基于内存的缓存系统,对内存的管理自然有一套严格标准slab负责管理),让我们把目光聚焦下图
在这里插入图片描述
MemCache将内存空间分割为若干slab组(class),每个slab分割为若干page每个page默认是1M),而每个page分为若干chunk总结一句话:“MemCache最终把数据存于chunk中”。

MemCache为了快速管理内存和分配内存,将已使用内存和未使用内存,编制为一个链表结构。对于新加入的数据,先更新header(H);对应过期的数据,先更新Tail(T)。

为了将新加入的数据合理存储,MemCache会通过计算将其放在与其大小“相当”的slab中。因此一定程度上容忍内存浪费

当然鉴于MemCache的内存机制,也提出了一些基础限制
比如条数据(Item)最大不超1M,又比如key最大不超250字符等等,在此博主不再赘述,可以另行查阅相关文档

2. 分布式实现

MemCache的分布式无法自己完成,通常是由MemCache客户端API负责实现。通过基于一致Hash算法,完成节点node匹配节点路由router),最终实现数据的分布式缓存。

在这里插入图片描述
这么来看,MemCache分布式是不是很简洁?博主不禁感叹:“这是一个算法支配的世界”
当然如何安装使用它,可以参考其他博主文章相对简单这里不再表述。

Q:MemCache适应场景有哪些

MemCache基于内存,必然消失于内存,比如重启服务器针对开发人员而言,简直是个灾难。
因此它适合存储无需持久化的数据且数据量不宜太大,因此分布式是一个很好的选择。正如“鸡蛋不宜放在同一个篮子”一样,数据也不宜放在同一个slab


结语

MemCache作为分布式缓存的另一选项,势必为微服务提供了一定的技术可能。我们说内存一般决定性能性能高低势必影响最终的用于体验
如何选择合适的Cache工具或系统,取决于业务场景和形式。抛开业务谈技术皆是耍流氓,希望各位盆友明辨取舍的关键。

好了,各位盆友,今天的话题到此结束,期待大家反馈分享,甚至讨论(热烈期待中…)。
在这里插入图片描述

原文地址:https://blog.csdn.net/splendid_java/article/details/134754904

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任

如若转载,请注明出处:http://www.7code.cn/show_31992.html

如若内容造成侵权/违法违规/事实不符,请联系代码007邮箱suwngjj01@126.com进行投诉反馈,一经查实,立即删除

发表回复

您的电子邮箱地址不会被公开。 必填项已用 * 标注