Redis缓存击穿是指,由于缓存中不存在某个键,当大量请求企图访问它时,缓存集群将会击穿成为直接到源服务层的请求,导致源服务层过载,短时间内持续处理的请求过多从而宕掉,从而影响服务的正常运行,严重时还会给用户带来困扰,故防止Redis缓存击穿几乎成为了所有程序员的必修课。
创新互联是一家专注于网站设计、成都网站制作与策划设计,天等网站建设哪家好?创新互联做网站,专注于网站建设十余年,网设计领域的专业建站公司;建站业务涵盖:天等等地区。天等做网站价格咨询:028-86922220
那么,如何有效防止Redis缓存击穿呢?
第一、合理设计Redis缓存结构。一般来说,将数据分到多个Redis节点上可以降低击穿无法给节点带来压力,而Hash管理结构可以更好管理缓存,分散请求量,加大整个redis集群的容量,从而有效防止击穿,当然实际的缓存结构的选择要结合具体的业务场景。以下是一个在Js中分离Redis键的示例代码:
//redis键名:userid:complex:info
var redisKey = 'userid:' + userId + ':complex:info';
//redis键值:拆分成多个Redis键
var redisHashKey = {
name: 'userid:' + userId + ':name',
age: 'userid:' + userId + ':age‘
job: 'userid:' + userId + ':job'
....
....
};
第二、即使缓存中不存在某个键,也要尽量避免直接向源服务层发出请求。Redis缓存中可以设置一个虚拟值,当程序发现不存在某个键时,也能够拿到一个虚拟值,从而可以有效的减少直接的源服务层请求,拦截掉缓存击穿。如下面示例代码:
//首先查看缓存中是否存在该键
if (!exist) {
//不存在,设置虚拟值,并设置缓存过期时间,以免发生误操作
redis.setex(' userid ' + user_id + ': no_exist ', 60, "This record doesn‘t exist!’");
}else {
//存在,走正常的流程
var val = redis.get(' userid ' + user_id + ':userinfo ');
//调用回调函数
cb(val);
}
对于一些更高级的操作,可以考虑使用布隆过滤器。布隆过滤器是一种高效的技术,可以有效减少缓存击穿发生的概率,比如说缓存中没有某键,在布隆过滤器中也可以查到,这样,哪怕向源服务层发出请求,也可以先从布隆过滤器中查询,有了肯定结果后才向源服务层发出请求,从而有效的减少击穿的概率,还可以有效的减少源服务层的压力。
为了有效的防止Redis缓存击穿,需要我们充分认识其原理,并结合缓存结构设计、虚拟值设置以及布隆过滤器的技术,一起细致的对缓存系统进行设计,才能够有效的防止Redis缓存击穿的问题。
创新互联-老牌IDC、云计算及IT信息化服务领域的服务供应商,业务涵盖IDC(互联网数据中心)服务、云计算服务、IT信息化、AI算力租赁平台(智算云),软件开发,网站建设,咨询热线:028-86922220
分享名称:如何有效防止Redis缓存击穿(如何防止redis被击穿)
文章源于:http://www.csdahua.cn/qtweb/news15/300265.html
网站建设、网络推广公司-快上网,是专注品牌与效果的网站制作,网络营销seo公司;服务项目有等
声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 快上网