您当前的位置:首页 > 新闻 > 科技

分布式缓存组件-Redis你还用错,来看看Redis秘籍

时间:2020-07-04 12:01:32  来源:  作者:

 

分布式缓存组件-Redis你还用错,来看看Redis秘籍

缓存设计

设计Key的注意事项

注意以下几点

简单、简洁、可读、无特殊符号、分组。

简单:不要过长,太长会占更多内存

简洁:清晰明了、不拖泥带水

可读:可读性良好,知道是什么

不使用特殊符号:不要用空格、引号或其他转移符号。

key分组:防止在公共redis里key冲突。

Value值的注意事项

类型选择

可能很多童鞋还在想着Redis只有5种数据类型,但是实际上现在明面上已经大致有八种数据类型。

Redis支持多种数据类型:字符串、散列表、列表、集合、有序集合、位图、hyperloglogs、地理空间,我们要结合业务需求合理的选择。

压缩

如果使用String类型,Value内容过大,需要考虑进行压缩、序列化(尤其使用json序列化后存储,需要进行压缩)。

分布式缓存组件-Redis你还用错,来看看Redis秘籍

Cache 批量执行

批量执行

批量执行主要有mset、mget和pipeline,这几个基本上我们用哪个都可以提升我们的执行效率。

需要考虑两种批量最大的区别,mget、mset是原生的命令,是原子的。而pipeline是管道,在管道上发送多个指令,是非原子的。

除此之外pipeline可以组合不同的命令,mget、mset则不行。

禁用命令

keys、flushall、flushdb等指令,我们直接在中间件层面进行拦截,终止。

内存回收

Redis自带了很多内存回收策略。为了保证内存的可用,我们可以根据业务场景选择不同的内存策略。

- noeviction:当内存达到阈值,申请内存操作会跑错。

- allkeys-lru:在所有key上采用lru算法进行删除回收内存。

- volatile-lru:在设置了expire的key上采用lru算法进行删除回收内存。

- allkeys-random:在所有key中进行随机删除回收内存。

- volatile-random:在设置了expire的key上随机进行删除回收内存。

- volatile-ttl:在设置了expire的可以上搜索,找到具有更早过期时间的key优先删除,回收内存。

分布式缓存组件-Redis你还用错,来看看Redis秘籍

内存碎片

内存碎片

Redis长期运行后,会出现一定程度的内存碎片,导致内存还有,但是内存不够用了,这时候我们就需要做一些调优,尤其是对内存碎片的调优。

Redis4开始支持内存碎片清理功能,两种方式:

支持在运行期进行自动内存碎片清理 (config set activedefrag yes)

支持通过命令 memory purge 进行清理(与自动清理区域不同)

过期时间

我们不能把Redis完全的当做DB使用,因为其使用的是内存,如果数据只添加不整理,那么很容易导致内存不够,所以我们需要对数

设置过期时间,如果是热点数据我们时间可以设置长一些,但是没有永远的热点,所以不建议设置永久。

分布式缓存组件-Redis你还用错,来看看Redis秘籍

并发安全

并发安全

原子性

Redis自身提供了Watch,以及一些原子的加减指令,有时候已经够用了,但是如果遇到多个key组成一个原子的操作,我们需要采用Lua来实现,提交lua脚本到服务端,保证操作是原子的。

熔断降级

我们可以对客户端做熔断降级,比如访问Redis超时,那么可以启用熔断,当前请求的后续其他Redis请求,都直接返回,不走redis

防止因为过度的超时,直接拖垮当前服务,甚至拖垮整个服务。可以考虑hystrix或sentinel,也可以自己通过滑动窗口统计实现一个简单的断路器。

密码

推荐使用密码,这样可以保证一定程度的安全。

当然最好是可以有一个密码管理服务,可以管理DB、Redis等数据源的密码,可以通过一个token来获取密码,而不是直接配置明文密码。



Tags:分布式缓存组件-Redis   点击:()  评论:()
声明:本站部分内容及图片来自互联网,转载是出于传递更多信息之目的,内容观点仅代表作者本人,如有任何标注错误或版权侵犯请与我们联系(Email:2595517585@qq.com),我们将及时更正、删除,谢谢。
▌相关推荐
缓存设计设计Key的注意事项注意以下几点简单、简洁、可读、无特殊符号、分组。简单:不要过长,太长会占更多内存简洁:清晰明了、不拖泥带水可读:可读性良好,知道是什么不使用特殊...【详细内容】
2020-07-04  Tags: 分布式缓存组件-Redis  点击:(49)  评论:(0)  加入收藏
▌简易百科推荐
非法购买公民信息、开发人脸认证规避技术……今年年初,广东省公安厅网安部门侦破全国首例破解“青少年防沉迷系统”的新型网络犯罪案件,抓获犯罪嫌疑人13名,查处非...【详细内容】
2021-12-28    人民日报客户端  Tags:数据安全步   点击:(5)  评论:(0)  加入收藏
就在今天,腾讯方面宣布将在2022年1月31日下架企业QQ和营销QQ,其实这一消息的降临并不让笔者意外,因为早在今年的10月28日20点之后,企业QQ和营销QQ就被停止了续费服务。相信很多...【详细内容】
2021-12-27  科技探险家    Tags:企业QQ   点击:(20)  评论:(0)  加入收藏
日前,上海交通大学发布《全球电竞之都评价报告》,对全球15个致力于发展电竞之都的城市进行评价,上海作为中国城市电竞发展的排头兵,其拥有众多优质电竞企业及完整产业集群,因此排...【详细内容】
2021-12-27  经济日报    Tags:电竞   点击:(3)  评论:(0)  加入收藏
为优化网络氛围环境,微博又开始整顿用户信息了。本月月初,微博官方发布公告,要求昵称中带有如“二货”“SB”“瘪三”“娘炮”等明显低俗或侮辱性词汇的用户尽快修改,否则将面临...【详细内容】
2021-12-24  运了个营    Tags:微博   点击:(10)  评论:(0)  加入收藏
昨日谷歌宣布,自2022年12月19日开始停止对OnHub的软件支持,OnHub路由器仍将提供Wi-Fi信号,但用户无法用谷歌Home应用程序管理它。无法更新Wi-Fi网络设置、添加额外的Wifi设备或...【详细内容】
2021-12-22  雷峰网    Tags:Google OnHub   点击:(5)  评论:(0)  加入收藏
IT之家 12 月 20 日消息,百度网盘青春版 iOS 客户端今日晚间率先开启内测,安卓客户端将在稍后内测。使用苹果 iPhone 的IT之家小伙伴可以点此下载内测版,需要先下载 TestFlight...【详细内容】
2021-12-21  IT之家    Tags:百度网盘   点击:(10)  评论:(0)  加入收藏
对于拼车单,是接还是不接,不少网约车司机表示很矛盾。接吧,钱少事多,常常跑了个寂寞,不接吧,车多客少,挑三拣四没饭吃。 在平台大力推广拼车单之下,不少司机迫于生活压力,最终还是打...【详细内容】
2021-12-17  网约车情报分享    Tags:滴滴   点击:(9)  评论:(0)  加入收藏
蓝鲸TMT频道12月16日讯,据饿了么官方微信公众号,近日,在圆桌会上,蓝骑士与平台交流了配送安全问题。饿了么表示,线上将技术手段融入安全防护;线下将持续进行安全培训,并试点智能头...【详细内容】
2021-12-17    金融界  Tags:饿了么   点击:(24)  评论:(0)  加入收藏
开源最前线(ID:OpenSourceTop) 猿妹编译项目地址: https://github.com/restic/restic全球知名代码托管平台 GitHub 今天就重磅发布了今年的年度报告——《2021 年度 O...【详细内容】
2021-12-17  Python部落    Tags:   点击:(9)  评论:(0)  加入收藏
新京报快讯 据中国网络视听节目服务协会网站消息,12月15日,中国网络视听节目服务协会发布了《网络短视频内容审核标准细则》(2021)。中国网络视听节目服务协会组织有关短视频平...【详细内容】
2021-12-16    新京报  Tags:短视频   点击:(11)  评论:(0)  加入收藏
相关文章
    无相关信息
最新更新
栏目热门
栏目头条