IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 大数据 -> postgreSQL——事务处理3 -> 正文阅读

[大数据]postgreSQL——事务处理3

2021@SDUSC

目录

概述

TransactionStateData

1)nestingLevel

2)gucNestLevel

3)curTransactionOwner

4)preUser

?总结


概述

上一周分析了事务系统上层事务块的操作,主要涉及事务执行的入口和出口的相关处理。这一周,我分析postgreSQL源码整理了一下事务进入到底层事务之后的具体处理过程。大致分析了一下后发现postgreSQL关于底层事务的处理主要包括三大部分:资源和锁的获取及释放、信号的处理、日志记录等。

根据分析得知,postgreSQL系统中,事务的状态定义在TransState中。

TransState表示的是一种低层次的事务状态。而事务处理过程中存储事务状态相关数据的数据结构是TransactionStateData

TransactionStateData

typedef struct TransactionStateData{

TransactionId?tansactionId;? ? ? ? ? ? ? ? ? ? ? ? ?//当前事务XID

SubTransactionId?subTransactionId;//子事务ID

char *name; //保存点名称

int savepointLevel;//保存点层数

TransState state;//低层次事务状态

TBlockState blockState;//事务块状态

int nestingLevel;//事务嵌套深度

int gucNestLevel;//GUC嵌套深度

MemoryContext curTransactionContext;//事务当前上下文

ResourceOwner curTransactionOwner;//缓冲区等资源

TransactionId*chilXids;//提交的子事务链表

int nChildXids;//提交的子事务个数

int maxChildXids;//已分配的子事务存储空间

Oid preUser;//标记用户OID

bool preSecDefCxt;//用户上下文环境设置

bool prevXactReadOnly;//只读事务标记

struct TransactioStateData*parent;//指向父事务代表的指针

}TransactionStateData;

在TransactionStateData结构中,根据分析和上网查找文献,根据重要性我分析了以下几个字段的作用。

1)nestingLevel

代表当前事务所在的嵌套级别,其中顶层事务的嵌套级别为1,每开启一个子事务(通过调用PushTransaction函数),该子事务的nestingLevel将在父事务的基础上加1。

2)gucNestLevel

记录的是本事务GUC(全局统一配置)的嵌套深度。在TopTransaction中会分配一个GUC用来存储事务嵌套压栈后GUC变量的变化情况。当子事务提交时,其父事务变量会出栈,此时的gucNestLevel与GUC栈中的嵌套级别比较,用来确定GUC变量是否恢复,即当此时的gucNestLevel小于GUC栈的嵌套级别,表示当前的GUC变量需要恢复。顶层事务的gucNestLevel为1,当函数PushTransaction把子事务压入栈的时候,首先会把全局变量GUCNestLevel加1,然后再把该值赋给子事务的gucNestLevel。当一个子事务中止时,在gucNestLevel大于等于当前事务嵌套级别(nestingLevel)的事务定义全局变量都会被丢弃。

3)curTransactionOwner

是指向ResourceOwnerData的指针,用于记录当前事务占有的资源。

4)preUser

记录的是上一个CurrentUserId设置,因为事务执行过程中CurrentUserId可能改变。当开启子事务,父事务入栈时,postgreSQL会调用GetUserAndContext将当前UserId保存起来,当事务出栈时会调用SetUserAndContext恢复父事务曾经的UserId。CurrentUserId对应的是目前执行环境下的用户名。例如,访问权限查询函数has_table_privilege查询用户是否有访问表的权限,该函数缺省的用户即CurrentUserId。

?总结

这个周分析了postgreSQL中关于底层事务的事务状态的源码结构体,下个周打算在着重分析一下底层事务的操作函数源码的运行机制。

欢迎批评指正。

?

  大数据 最新文章
实现Kafka至少消费一次
亚马逊云科技:还在苦于ETL?Zero ETL的时代
初探MapReduce
【SpringBoot框架篇】32.基于注解+redis实现
Elasticsearch:如何减少 Elasticsearch 集
Go redis操作
Redis面试题
专题五 Redis高并发场景
基于GBase8s和Calcite的多数据源查询
Redis——底层数据结构原理
上一篇文章      下一篇文章      查看所有文章
加:2021-10-23 12:34:35  更:2021-10-23 12:35:20 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/18 5:17:12-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码