本文目录一览:
- 1、Redis的各数据类型的内存占用
- 2、Redis内存满了会怎么样?
- 3、redis查询到已经过期数据原因
对象内存(推荐学习:Redis视频教程)对象内存是Redis内存占用最大的一块,存储着用户所有的数据 。Redis所有数据都采用key-value数据类型,每次创建键值对时,至少创建两个类型对象:key对象和value对象 。
used_memory 为 Redis 内存分配器(如:jemalloc)分配的 内存总量 ,这些内存主要用于存储 Redis 实际运行时产生的数据 。注意,这里说的内存总量包含 内存 和 虚拟内存。
dict类型使用的两个指向哈希表的指针,其中0号哈希表(ht[0])主要用于存储数据库的所有键值 , 而1号哈希表主要用于程序对0号哈希表进行rehash时使用,rehash一般是在添加新值时会触发,这里不做过多的赘述 。
原因如下:json数据本身通常比纯文本数据占用更多的存储空间,因为它包含了更多的元数据和结构信息 。redis存储的所有数据都是存在内存中的,包括json数据,因此如果大量存储json数据会占用较多的内存 。
Redis内存满了会怎么样?1、获取当前内存淘汰策略:通过配置文件设置淘汰策略(修改redis.conf文件):通过命令修改淘汰策略:近似LRU算法 Redis使用的是近似LRU算法,它跟常规的LRU算法还不太一样 。
2、与RDB 存储某个时刻的快照不同,AOF 持久化方式会记录客户端对服务器的每一次写操作命令,并将这些写操作以 Redis 协议追加保存到以后缀为 aof 文件末尾,在Redis服务器重启时 , 会加载并运行 aof 文件的命令,以达到恢复数据的目的 。
3、将Redis用作缓存时,如果内存空间用满,就会自动驱逐老的数据 。
4、当Redis内存超出物理内存限制时,内存数据会开始和磁盘产生频繁的交换,使得性能急剧下降 。
5、内存限制:Redis是基于内存的存储系统,当缓存数据量过大时,可能会消耗大量内存资源,影响软件其他功能的性能 。缓存穿透、缓存击穿和缓存雪崩:这些现象可能导致缓存系统承受较大压力,进而影响整个软件的性能和稳定性 。
redis查询到已经过期数据原因(被动)惰性删除:当客户端请求到一个已经过期的key时 , redis会检查是否过期并删除 所以,虽然key过期了 , 但是没被清理的话,还是会占内存的 。
如果 读取的是 Slave 库,则有可能会拿到过期数据 , 一般造成这样原因有两个 。这样的场景由于 Redis 控制不住过期数据被客户端应用误读,形成数据不安全 。
Redis 对于已经过期的数据,采用两种策略来处理这些数据 , 分别是惰性删除和定期删除 。惰性删除不会去主动删除数据,而是在访问数据的时候,如果发现数据已经过期,就会自动删除 。
【redis命令 redis占100】由于指令的同步存在异步 , 所以会出现主从数据不一致的情况 。当Redis内存超出物理内存限制时,内存数据会开始和磁盘产生频繁的交换,使得性能急剧下降 。
推荐阅读
- redis十万条数据 redis百万数据交集
- 如何利用自己的服务器赚钱? 我有台服务器怎么赚钱
- 南昌生育津贴领取标准及新规2023年 2023南昌生育津贴能领多少钱?
- 如何设置首选DNS服务器? 首选dns服务器怎么配置
- 管理空间的其他是什么 管理空间的mysql
- mysql如何设置表的男女 mysql男1女0
- 崔老师英语 崔老师mysql
- mysql运行一段时间连不上 mysql不联网怎么解决