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

【0257】关于pg内核shared cache invalidation messages (概念篇)

文章目录

  • 1. inval messages
  • 2. 可配置参数(Configurable parameters)

1. inval messages

所谓“共享缓存无效消息(shared cache invalidation messages)”,从概念上讲,共享缓存无效消息存储在一个无限数组中,其中maxMsgNum是存储提交消息的下一个数组下标, minMsgNum是包含尚未被所有后端读取的消息的最小数组下标,并且我们总是有maxMsgNum >= minMsgNum。 (当没有消息挂起时,它们是相等的。)对于每个活动后端,都有一个nextMsgNum指针,指示它需要读取的下一条消息;对于每个后端,我们有maxMsgNum >= nextMsgNum >= minMsgNum。

(在当前的实现中,minMsgNum是每个进程nextMsgNum值的下界,但它并没有严格地保持等于最小的nextMsgNum —— 它可能会落后。我们只在调用SICleanupQueue()时更新它,我们尽量不经常这样做。)

实际上,消息存储在MAXNUMMESSAGES条目的循环缓冲区中。我们通过计算MsgNum % MAXNUMMESSAGES将MsgNum值转换为循环缓冲区索引(只要MAXNUMMESSAGES是一个常数并且是2的幂,这应该很快)。只要ma

http://www.lryc.cn/news/296723.html

相关文章:

  • Nginx 缓存集成、清除、设置不缓存资源
  • C++面试宝典第27题:完全平方数之和
  • webrtc native api的几个要点
  • MinMaxScaler, StandardScaler数据预处理中常用的两种缩放方法,用于将数据标准化或归一化到特定的范围或分布
  • 【Web】vulhub Shiro-550反序列化漏洞复现学习笔记
  • 【论文精读】多模态情感分析 —— VLP-MABSA
  • SQL SELECT TOP, LIMIT, ROWNUM 子句
  • 金融信贷风控评分卡模型
  • 【java苍穹外卖项目实战二】苍穹外卖环境搭建
  • 在 Ubuntu 22.04 上安装 Django Web 框架的方法
  • JVM Java虚拟机入门指南
  • 【错误文档】This与Here的区别、主系表结构、如何合并两个句子、祈使句结构
  • Java入门之JavaSe(韩顺平p1-p?)
  • TCP的连接和断开详解
  • armbian ddns
  • MQTT 服务器(emqx)搭建及使用
  • 【flink状态管理(四)】MemoryStateBackend的实现
  • 前端架构: 脚手架在前端研发流程中的意义
  • Qt网络编程-QTcpServer的封装
  • 【MySQL】_JDBC编程
  • 微信小程序编译出现 project.config.json 文件内容错误
  • 一周学会Django5 Python Web开发-Django5创建项目(用命令方式)
  • DockerUI如何部署结合内网穿透实现公网环境管理本地docker容器
  • UML之在Markdown中使用Mermaid绘制类图
  • Spring Boot + 七牛OSS: 简化云存储集成
  • C++:二叉搜索树模拟实现(KV模型)
  • npm淘宝镜像源换新地址
  • 十大排序算法之线性时间非比较类排序
  • 容器基础:Docker 镜像如何保证部署的一致性?
  • 爪哇部落算法组2024新生赛热身赛题解