PostgreSQL 源码解读(221)- Locks(PROCLOCK Struct)
发表于:2025-01-19 作者:千家信息网编辑
千家信息网最后更新 2025年01月19日,本节是PostgreSQL Locks中介绍PROCLOCK结构体部分,翻译自README文件.一、PROCLOCK Struct/* * We may have several different
千家信息网最后更新 2025年01月19日PostgreSQL 源码解读(221)- Locks(PROCLOCK Struct)
本节是PostgreSQL Locks中介绍PROCLOCK结构体部分,翻译自README文件.
一、PROCLOCK Struct
/* * We may have several different backends holding or awaiting locks * on the same lockable object. We need to store some per-holder/waiter * information for each such holder (or would-be holder). This is kept in * a PROCLOCK struct. * * PROCLOCKTAG is the key information needed to look up a PROCLOCK item in the * proclock hashtable. A PROCLOCKTAG value uniquely identifies the combination * of a lockable object and a holder/waiter for that object. (We can use * pointers here because the PROCLOCKTAG need only be unique for the lifespan * of the PROCLOCK, and it will never outlive the lock or the proc.) * * Internally to a backend, it is possible for the same lock to be held * for different purposes: the backend tracks transaction locks separately * from session locks. However, this is not reflected in the shared-memory * state: we only track which backend(s) hold the lock. This is OK since a * backend can never block itself. * * The holdMask field shows the already-granted locks represented by this * proclock. Note that there will be a proclock object, possibly with * zero holdMask, for any lock that the process is currently waiting on. * Otherwise, proclock objects whose holdMasks are zero are recycled * as soon as convenient. * * releaseMask is workspace for LockReleaseAll(): it shows the locks due * to be released during the current call. This must only be examined or * set by the backend owning the PROCLOCK. * * Each PROCLOCK object is linked into lists for both the associated LOCK * object and the owning PGPROC object. Note that the PROCLOCK is entered * into these lists as soon as it is created, even if no lock has yet been * granted. A PGPROC that is waiting for a lock to be granted will also be * linked into the lock's waitProcs queue. */typedef struct PROCLOCKTAG{ /* NB: we assume this struct contains no padding! */ LOCK *myLock; /* link to per-lockable-object information */ PGPROC *myProc; /* link to PGPROC of owning backend */} PROCLOCKTAG;typedef struct PROCLOCK{ /* tag */ PROCLOCKTAG tag; /* unique identifier of proclock object */ /* data */ PGPROC *groupLeader; /* proc's lock group leader, or proc itself */ LOCKMASK holdMask; /* bitmask for lock types currently held */ LOCKMASK releaseMask; /* bitmask for lock types to be released */ SHM_QUEUE lockLink; /* list link in LOCK's list of proclocks */ SHM_QUEUE procLink; /* list link in PGPROC's list of proclocks */} PROCLOCK;#define PROCLOCK_LOCKMETHOD(proclock) \ LOCK_LOCKMETHOD(*((proclock).tag.myLock))---------------------------------------------------------------------------The lock manager's PROCLOCK objects contain:tag - The key fields that are used for hashing entries in the shared memory PROCLOCK hash table. This is declared as a separate struct to ensure that we always zero out the correct number of bytes. It is critical that any alignment-padding bytes the compiler might insert in the struct be zeroed out, else the hash computation will be random. (Currently, we are careful to define struct PROCLOCKTAG so that there are no padding bytes.) tag.myLock Pointer to the shared LOCK object this PROCLOCK is for. tag.myProc Pointer to the PGPROC of backend process that owns this PROCLOCK. Note: it's OK to use pointers here because a PROCLOCK never outlives either its lock or its proc. The tag is therefore unique for as long as it needs to be, even though the same tag values might mean something else at other times.tag - 与LOCK结构体中的tag字段类似,用于标识共享内存中的PROCLOCK哈希表中对应的条目. tag.mylock 指向PROCLOCK所表示的共享LOCK对象的指针 tag.myProc 指向持有该PROCLOCK的PGPROC后台进程holdMask - A bitmask for the lock modes successfully acquired by this PROCLOCK. This should be a subset of the LOCK object's grantMask, and also a subset of the PGPROC object's heldLocks mask (if the PGPROC is currently waiting for another lock mode on this lock).holdMask - 该PROCLOCK请求获得的lock模式位掩码. 应为LOCK's grantMask掩码的子集,同时也是PGPROC's heldlocks掩码的子集.releaseMask - A bitmask for the lock modes due to be released during LockReleaseAll. This must be a subset of the holdMask. Note that it is modified without taking the partition LWLock, and therefore it is unsafe for any backend except the one owning the PROCLOCK to examine/change it.releaseMask - 在LockReleaseAll执行过程中即将被释放的lock模式位掩码. 应为holdMask位掩码的子集.注意更新该值时不需要持有分区LWLock,因此除了自身的PROCLOCK外 其他后台进程是不安全的.lockLink - List link for shared memory queue of all the PROCLOCK objects for the same LOCK.lockLink - 共享内存中同一个LOCK的PROCLOCK对象队列链表链接.procLink - List link for shared memory queue of all the PROCLOCK objects for the same backend.procLink - 共享内存中同一个后台进程所有PROCLOCK对象的的链表链接.
二、参考资料
README
内存
后台
子集
对象
进程
指向
模式
结构
表链
安全
参考资料
同时
字段
指针
文件
条目
标识
资料
过程
部分
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
惠通时代网络技术
自己如何搭建服务器
网络技术职业认知怎么写
济南市浪潮服务器代理电话多少
erp软件开发需要多久
参展商数据库对展会的招展的作用
网络安全宣传周专刊
普华永道软件开发面试题目
上海思霍网络技术
怎么看服务器有没有做磁盘
医药软件开发具体做什么的
软件开发图书商城
深圳抢红包软件开发
嘀嗒软件开发票
社区服务器开发
后端开发数据库设计流程
江门大数据库安全
多文件下载用什么服务器程序
细胞软件开发公司的口号是什么
计算机网络技术外部环境分析
互联网科技公司的文创包装
网络安全属于什么方面硕士
数据库安全的必要性
河池软件开发人员
台湾服务器游戏加速云主机
部队网络安全问题学习感悟
数据库查询第一位学生信息
无锡通用软件开发技术指导
手机照片打印机服务器
严格落实网络安全法