底层:字典

底层:字典

字典是redis整个映射的基础,hash结构依赖字典,zset中member到score的映射也是通过字典。set的底层也是字典,只不过value是null。

一个字典内部实际包含两个hashtable,因为扩容缩容需要渐进式hash迁移。hashtable是由数组加链表组成。

渐进式hash

在渐进式rehash时,搬迁操作在对字典的后序指令中触发,如果没有的话也会进行定时任务。

在扩容时如果redis正在bgsave(后台异步保存数据到磁盘),为了尽量少的页面分离,就会尽量不扩容,除非hash表已经很拥挤了。缩容时不用顾忌bgsave。

遍历方式

在遍历时字典要先遍历旧的,再遍历新的。遍历的迭代器有两种:安全迭代器和不安全迭代器。

安全迭代器遍历过程中可以对字典进行查找和修改,且元素不会出现重复,在安全遍历时会阻止字典rehash,在keys指令执行时采用安全迭代器,因为不允许出现重复元素,涉及持久化的操作也会使用安全迭代器。

不安全迭代器只能对字典进行查找,元素可能重复,不会阻止rehash,如scan命令。

hash算法

redis的hash算法采用一种siphash算法,这种算法有效的抵御了hash flooding攻击,降低hash函数的偏向性,即使key很小结果差别也很巨大。(还有一种常用的hash算法是MD5)

转载于:https://www.cnblogs.com/shizhuoping/p/11521175.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
机票预定系统底层数据字典是指系统中使用的数据表及其字段的定义和说明。下面是一个可能的机票预定系统底层数据字典的示例: 1. 用户表(User) - 用户ID(UserID):唯一标识用户的ID - 用户名(Username):用户的登录名 - 密码(Password):用户的登录密码 - 姓名(Name):用户的真实姓名 - 手机号码(PhoneNumber):用户的联系电话 - 邮箱(Email):用户的电子邮箱 2. 航班表(Flight) - 航班ID(FlightID):唯一标识航班的ID - 起飞城市(DepartureCity):航班的起飞城市 - 到达城市(ArrivalCity):航班的到达城市 - 起飞时间(DepartureTime):航班的起飞时间 - 到达时间(ArrivalTime):航班的到达时间 - 航空公司(Airline):执飞该航班的航空公司 - 机型(AircraftType):该航班所使用的飞机型号 3. 订单表(Order) - 订单ID(OrderID):唯一标识订单的ID - 订单状态(Status):订单的状态,如待支付、已支付、已取消等 - 订单金额(Amount):订单的总金额 - 下单时间(OrderTime):订单的下单时间 4. 支付表(Payment) - 支付ID(PaymentID):唯一标识支付记录的ID - 订单ID(OrderID):支付对应的订单的ID - 支付方式(PaymentMethod):支付所使用的方式,如支付宝、微信支付等 - 支付金额(Amount):支付的金额 - 支付时间(PaymentTime):支付的时间

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值