方向专业网站制作咨询,威海网站优化,郑州企业网站设计,嘉兴做企业网站的公司目录 1、内存碎片如何产生的#xff1f;
2、跟踪内存碎片率对理解Redis实例的资源性能是非常重要的
3、解决碎片率大的问题
二、内存使用率
1、避免内存交换发生的方法
2、内回收key
三、缓存的穿透、击穿、雪崩 #查看Redis内存使用方法
info memory #进入数据库查看
re…目录 1、内存碎片如何产生的
2、跟踪内存碎片率对理解Redis实例的资源性能是非常重要的
3、解决碎片率大的问题
二、内存使用率
1、避免内存交换发生的方法
2、内回收key
三、缓存的穿透、击穿、雪崩 #查看Redis内存使用方法
info memory #进入数据库查看
redis-cli info memory#在redis数据库外面查看#内存碎片率
mem_fragmentation_ratio
#内存碎片率。mem_fragmentation_ratioused_memory_rss/used_memory used memory rss #是Redis向操作系统申请的内存。
used memory #是Redis中的数据占用的内存
used_memory_peak #redis内存使用的峰值。
1、内存碎片如何产生的
Redis内部有自己的内存管理器为了提高内存使用的效率来对内存的申请和释放进行管理。 Redis中的值删除的时候并没有把内存直接释放交还给操作系统而是交给了Redis内部的内存管理器。 Redis中申请内存的时候也是先看自己的内存管理器中是否有足够的内存可用。 Redis的这种机制提高了内存的使用率但是会使Redis中有部分自己没在用却不释放的内存导致了内存碎片的发生。
2、跟踪内存碎片率对理解Redis实例的资源性能是非常重要的
内存碎片率在1到1.5之间是正常的这个值表示内存碎片率比较低也说明Redis没有发生内存交换。 内存碎片率超过1.5说明Redis消耗了实际需要物理内存的150%其中50%是内存碎片率。 内存碎片率低于1的说明Redis内存分配超出了物理内存操作系统正在进行内存交换。需要增加可用物理内存或减少Redis内存占用。
3、解决碎片率大的问题
如果你的Redis版本是4.0以下的需要在redis-cli工具上输入shutdown save命令让Redis 数据库执行保存操作并关闭Redis服务再重启服务器。Redis服务器重启后Redis会将没用的内存归还给操作系统碎片率会降下来。
Redis4.0版本开始可以在不重启的情况下线上整理内存碎片。
config set activedefrag yes #自动碎片清理内存就会自动清理了。
memory purge #手动碎片清理
二、内存使用率
redis实例的内存使用率超过可用最大内存操作系统将开始进行内存与swap空间交换。
1、避免内存交换发生的方法
针对缓存数据大小选择安装Redis实例 尽可能的使用Hash数据结构存储 设置key的过期时间
2、内回收key
内存清理策略保证合理分配redis有限的内存资源。
当达到设置的最大阀值时需选择一种key的回收策略默认情况下回收策略是禁止删除。
配置文件中修改maxmemory-policy属性值
vim/etc/redis/6379.conf
--598--
maxmemory-policy noenviction
volatile-lru #使用LRU算法从己设置过期时间的数据集合中淘汰数据移除最近最少使用的key针对设置了TTL的key
volatile-tt1 #从己设置过期时间的数据集合中挑选即将过期的数据淘汰移除最近过期的key
volatile-random #从已设置过期时间的数据集合中随机挑选数据淘汰在设置了TTL的key里随机移除
allkeys-lru #使用LRU算法从所有数据集合中淘汰数据移除最少使用的key针对所有的key
allkeys-random #从数据集合中任意选择数据淘汰随机移除key
noenviction #禁止淘汰数据不删除直到写满时报错
三、缓存的穿透、击穿、雪崩 穿透通过防火墙从一个网络到另一个网络击穿当一个数据被大量访问对数据库的请求就会增多就会宕机 雪崩相当于分布式系统上一个节点故障其他节点负载增加导致一个系统奔溃