当前位置: 首页 > news >正文

【0259】inval.h/inval.c的理解

1. inval.h/inval.c

inval.h、inval.c是缓存无效消息(invalidation message)调度程序定义。

2. inval.h/inval.c特性

inval.h/inval.c的实现是一个非常微妙的东西,所以需要注意:

  • 当一个元组被更新或删除时,我们的标准可见性规则(standard visibility rules)认为只要我们在同一个命令中,它“仍然有效”,即直到下一个CommandCounterIncrement()或事务提交。(请参阅 access/heap/heapam_visibility.c,注意系统catalogs(system catalogs)通常在可用的最新快照下扫描,而不是在事务快照下扫描。)在命令边界,旧的元组不再有效,新版本(如果有的话)变得有效。因此,我们不能简单地在heap_update()heap_delete()期间从系统缓存中刷新元组。元组在这一点上仍然是好的;更重要的是,即使我们确实刷新了它,它也可能在同一命令中的后续请求中被重新加载到缓存中。因此,正确的做法是保留过期(已更新/已删除)元组的列表,然后在下一个命令边界执行所需的缓存刷新。我们还必须跟踪插入的元组,以便我们可以刷新与新元组匹配的“负”缓存项;再说一遍,在命令结束之前,这绝不能发生。
  • 完成命令后,我们仍然需要记住插入的元组(包括更新元组的新版本),以便在中止事务时从缓存中刷新它们。类似地, 我们最好能够刷新“负”缓存条目&#
http://www.lryc.cn/news/304379.html

相关文章:

  • 力扣爆刷第77天--动态规划一网打尽打家劫舍问题
  • 深入理解C语言(5):程序环境和预处理详解
  • ESP8266智能家居(3)——单片机数据发送到mqtt服务器
  • lvm逻辑卷创建raid阵列(不常用)—— 筑梦之路
  • LayUI发送Ajax请求
  • 平时积累的FPGA知识点(10)
  • 使用Streamlit构建纯LLM Chatbot WebUI傻瓜教程
  • 电脑死机卡住怎么办 电脑卡住鼠标也点不动的解决方法
  • RAG 语义分块实践
  • 12 Autosar_SWS_MemoryMapping.pdf解读
  • 【Linux取经路】文件系统之缓冲区
  • 华为OD机试真题-查找接口成功率最优时间段-2023年OD统一考试(C卷)--Python3--开源
  • 缓存篇—缓存雪崩、缓存击穿、缓存穿透
  • Python实现视频转音频、音频转文本的最佳方法
  • 阿里云SSL免费证书到期自动申请部署程序
  • Vue全局事件防止重复点击(等待请求)【进阶版】
  • C#程序反编译经验总结
  • Android系统启动流程
  • Flask——基于python完整实现客户端和服务器后端流式请求及响应
  • crmeb多门店商城系统二次开发 增加车辆车牌搜索功能、车辆公里数
  • 深度好文|关于人类智能与自主系统
  • 防火墙内容安全笔记
  • 应用于温度报警器中的高精度温度传感芯片
  • 微信小程序swiper 视频中间大,两边小,轮播滑到中间视频自动播放组件教程
  • ARM服务器上部署zookeeper集群
  • 利用Ubuntu22.04启动U盘对电脑磁盘进行格式化
  • Nginx基础入门
  • 分布式和微服务
  • 【无标题】学习Markdown
  • 由于 vscode 版本更新为 1.86.1引起的相关问题。