Redis原理篇(String)

一.编码方式

String 有三种编码方式

1.RAW编码

 type是类型,表示该类型是String类型

encoding是编码方式,表示当前是String的RAW编码方式

ptr指针指向一个SDS(动态字符串)对象

2.EMBSTR编码

当要存的字符串长度小于44个字节时,String的编码方式会转变成EMBSTR编码

此时RedisObject的头部分与SDS会是一段连续的内存空间

因为当字符串长度小于44字节时,ReidsObject的大小小于64字节,而内存分片函数每次分片的内存空间都是2的n次方,64就刚刚好,不会产生内存碎片。

3.INT编码

当存储的字节是整数值,并且在最大整数范围内(8个字节,即,64个比特位,2的64次方)时,

String的编码方式会变成INT编码

 

二.总结

  • 8
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Redis是一种基于内存的高性能键值存储系统。它以其快速的读写能力和丰富的数据结构而闻名,被广泛应用于缓存、队列、计数器等场景。 Redis的核心原理包括以下几个方面: 1. 内存存储:Redis将数据存储在内存中,以实现低延迟的读写操作。它使用了一种叫做"跳表"(Skip List)的数据结构来实现有序集合和有序哈希表,以及哈希表和字符串等其他数据结构。 2. 持久化:Redis支持两种持久化方式,分别是RDB(Redis Database)和AOF(Append-Only File)。RDB是一种快照方式,将内存中的数据定期保存到磁盘上;AOF则是将写命令追加到一个日志文件中,通过重新执行这些命令来恢复数据。 3. 复制:Redis支持主从复制机制,在一个Redis服务器上配置一个或多个从服务器,从服务器会自动复制主服务器上的数据。主从复制可以提高系统的可用性和读取性能。 4. 高可用:Redis提供了哨兵(Sentinel)和集群(Cluster)两种方式来实现高可用。哨兵监控主服务器的状态,并在主服务器失效时自动将一个从服务器升级为主服务器;集群则将数据分散到多个节点上,每个节点负责一部分数据。 5. 事务:Redis支持简单的事务操作,通过MULTI、EXEC、WATCH和UNWATCH等命令来实现。事务中的命令在执行EXEC命令时原子地被提交,保证了相关操作的一致性。 这些是Redis的一些核心原理,它们共同构成了Redis的高性能和可靠性。当然,Redis还有很多其他的特性和功能,比如发布订阅、Lua脚本等,可以根据具体需求进行使用。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值