2 PostgreSQL 物理,逻辑,进程结构以及系统表系统函数|学习笔记

本文涉及的产品
云原生数据库 PolarDB PostgreSQL 版,标准版 2核4GB 50GB
日志服务 SLS,月写入数据量 50GB 1个月
云原生数据库 PolarDB MySQL 版,通用型 2核4GB 50GB
简介: 快速学习2 PostgreSQL 物理,逻辑,进程结构以及系统表系统函数

开发者学堂课程【PostgreSQL 快速入门2 PostgreSQL 物理,逻辑,进程结构以及系统表系统函数】学习笔记,与课程紧密联系,让用户快速学习知识。

课程地址https://developer.aliyun.com/learning/course/16/detail/88


2 PostgreSQL 物理,逻辑,进程结构以及系统表系统函数


内容介绍:

一、PostgreSQL 体系结构

二、PostgreSQL 数据库逻辑概貌

三、PostgreSQL 数据库进程结构概貌

、PostgreSQL 系统表介绍

、PostgreSQL 系统视图介绍

、PostgreSQL 管理函数

、PostgreSQL 进程结构

八、PostgreSQL 物理结构

九、PostgreSQL 数据库可靠性

十、练习


一、PostgreSQL 体系结构

1、了解系统表以及系统表之间的关系,系统视图,管理函数等。

2、了解 PG 进程结构。

3、了解 PG 物理结构,数据库逻辑概貌,物理概貌,可靠性等。

安装好 PostgreSQL,数据库初始化,可以连接到 PostgreSQL 的数据库里面。


二、PostgreSQL 数据库逻辑概貌

image.png

initdb 执行完后会初始化数据库,数据库在最顶端的是 cluster,cluster 下可以创建很多数据库,数据库和数据库之间是分开的关系,从a库连到c库需要 PostgreSQL 其它的库文件实现,比如 cluster 插件实现,在连接数据库时,通过程序连接数据库,通过ipq连接,就需要主机地址,监听端口,数据库名,用户名和密码。

host=localhost port=5432 dbnaneFnydb connect_ tineoute 10

网络端口数据库名参数

postresq1:// [user[:passvord]@] [netloc] [:port][/ dbname]

[?p aram1=value1&. ..]

在连接一个数据库时候提供数据库名 database如果通过命令创建很多数据

CREATE DATABASE 可以创建很多数据库在一个集群下面可以有很多个数据库这些是逻辑分开的一些概念,每一个库下面,比如连在 dn 库下面可以放进很多 schemas,默认是 pubilc schemas,默认创建好权限赋予给所有pubilc 下面的角色创建 schemas sa,下面就会多sa的postgres当连接到一个数据库之后要访问不同 schemas 下面的表,from sa.tablename;

当连接数据库之后访问本地数据库数据库里面所有的 schemas 直接带上点即可,在 digoal 库下面访问 postgres 库里面东西不行必须要重新连接到 postgres 库访问 postgres 的东西在 postgres 里面不像 schemas创建好多用户和 schemas 类似于绑定在一起的概念一旦数据库连接以后只要有权限用户都可以访问在集群下面如果有多个数据库跟数据库之间是没有办法直接访问的可以通过其它的一些方法,比如 databse 访问,库的库之间一个隔离状态集群层面有共享集群系统表,

pg database

Select=from pg_database

Temlate1

Temlate0

Postgres

Digoal

全局的表不管连接到哪个库访问 pg database 表都一样连接到 digoal 也是一样因为是全局对象全局的数据表对于单个数据库 schemas下面建立的是到对象层级创建 Table(s)Index(s)View(s)Function(s)Sequmce(s)Other(s)逻辑层面分为5个层面最顶级的 instance 的 cluster

cd$ PGDATA

6 pg93 pg93 4.0K Dec 27 18:58 base

2 pg93 pg93 4.0K Dec 27 19:09 global

2 pg93 pg93 4.0K Dec 2? 18:38 p9 clog

1 pg93 pg93 4.4K Dec 27 18:43 p9 hba . conf

1 pg93 pg93 1.6K Dec 27 18:38 pg ident.conf

2 pg93 pg93 4.0K Dec 2? 19:02 p9 log

4 pg93 pg93 4.0K Dec 27 18:38 p9 nultixact

2 pg93 pg93 4.0K Dec 27 19:02 pg notify

2 pg93 pg93 4.0K Dec 2? 18:38 pg serial

2 pg93 pg93 4.0K Dec 27 18:38 p9 snaps hots

2 pg93 pg93 4.0K Dec 27 18:38 pg stat

2 pg93 pg93 4.0K Dec 27 18:38 pg stattmp

2 pg93 pg93 4.0K Dec 27 18:38 pg subtrans

2 pg93 pg93 4.0K Dec 27 18:50 p9 tblspc

2 pg93 pg93 4.0K Dec 27 18:38 pg twophase

1 pg93 pg93 4Dec2718:38PGUERSION

3 pg93 pg93 4.0K Dec 2? 18:57 p9 xlog

1 pg93 pg93 20K Dec 2? 19:02 pos tgresql. conf

1 pg93 pg93 2Dec 27 19:02 postmaster.opts

1 pg93 pg93 71 Dec 27 19:02 postmaster.pid

数据库里面有 schemas默认有 public创建其他的 schemas

digoa 1

List of schemas

Public postgres

Sa postgres

在库里面创建 schemas 类似于连接到 ouner 用户之间的层级schemas 类似于 ouner 层级database 类似于 ouner 顶级的层级再往上一层是 clusterschemas 下面是创建对象逻辑层

image.png

对于每一个表每一个对象toast 表或是普通的 table 表index 索引或者 sequence 序列都会有自己对应的数据文件数据文件单个文件的大小在编译数据库时安装时指定大小默认是1gb

With-segsize=SEGSIZE set table segnent size in GB [1 ]

单个文件1gb当表超过1gb时会生成同名但是后面加后缀比如123,当表超过1gb就会变成123.1文件对于其它表索引也是一样的情况数据库的物理文件还包括数据文件wals 日志还可以做归档文件ouner 非常类似


三、PostgreSQL 数据库进程结构概貌

image.png

9.3还会比这个多一些进程

Ps-ewfGrep pg93

/opt/pgsq1932/bin/postgres 主进程监听进程

postgres : logger process

postgres: checkpointer process

postgres : writer process

postgres: wal writer process

grep pg93

netstat anpigrep 1999

监听在13723进程下面同时它也是所有进程的父进程比如收集日志的进程父进程是13723,checkpointer 父进程也是13723,数据库启动时先启动/opt/pgsq1932/bin/postgres进程再报一堆子进程

postmaster 是/opt/pgsq1932/bin/postgres主进程它负责监听同时负责 fork 子进程包括autovacuum launcher autovacuum worker,backend process,跟用户连上时它也是先跟监听交互好后 fork 进程fork 进程再跟 app 地址沟通wal writer 是把 wal buffer 写到 xlogs 中也就是 wal 日志shared buffer 是bgwriter写 shared buffer 写到 datafiles 中当 shared buffer 空间不够时如果执行 sql 语句申请 shared bufferbackend process 会主动的把 shared buffer 里面的脏的 buffer 写到文件里也就是在 Postgre 里面不光光是bgwriter 会写 shared bufferbackend process 也会写 shared buffer同时 wal buffer 也是一样当 wal buffer 满了也会到 xlogs 中archiver 负责把已经写满的 xlogs 文件进行归档到另外的地方


四、PostgreSQL 系统表介绍

1、系统表,系统表之间基本上都是以 oid 关联,例如 pg_ attrdef.adrelid 关联 pg_ class.oid

oid 可能是隐藏的字段

Pg class

查看 postresql 帮助d类似于 dsc 命令中括号表示可选加表示 additional detail 额外的详细信息show system objectsDs+可以看到系统表的信息pg catalog 后面都是系统pg calss 大小是96kb可以看到有字段 oid描述里面打印出的看不到字段实际上是有 oid 的select oid from pg_class limit 1;就能看到记录上面有 oidoid 也被其它的用来做关联

2、select relkind,relname from pg_ class where

relnamespace = (select oid from pg_ namespace where

nspname= 'Pg_ catalog') and relkind='r' order by 1,2;

pg_ class 存储的所有对象都在里面包括表。relkind 指的是对象的类型r表示 relationships 表,S就是序列看视图就是v,pg_ namespace 也有 oid 字段直接看 pg_ namespace 也是看不到 oid 字段的隐含的字段oid 对应的是pg_ class relnamespace 字段在做关联时可以直接用

3、r | pg_aggregate 聚合函数信息,包括聚合函数的中间函数,中间函数的初始值,最终函数等。

4、r | pg_am 系统支持的索引访问方法。(如Ibtree, hash, gist, gin , spgist)

当前数据库支持哪些类型的索引通过 from pg_am 查询可以看到 amname 里面对应的 btreepostresql 数据库支持hitmap 索引btree 索引hash 索引gist 索引gin 索引spgist 索引支持五种索引方法在创建索引时可以选择哪个索引索引和数据类型有关系并不是所有的类型都支持 gist 索引并不是所有的类型都支持 btree 索引普通类型使用 btree 索引像一个字段里面存储多种值数据点的类型可以用 gin 或者 gist 类型比如存储数组数组类型可以选择用 gin 或者 gisthash 索引用的非常少只支持一种操作符号完全相等

5、r | pg_amop 存储每个索引访问方法操作符家族(pg _opfamily)中的详细操作符信息。

6、r | pg_ amproc 存储每个索引访问方法操作符家族(pg_ opfamily)支持的函数信息。

7、r | pg_ attrdef 存储数据表列的默认值(例如创建表时指定了列的default值)。一张表创建完后对应的某一个列对应的默认值是什么对应的是 attrdef 系统表

8、r | pg_attribute 存储数据表列的详细信息包括隐含的列(ctid, cmin, cmax, xmin, xmax)

创建一个表table tb1<id int .info text.crt_time timestamp>;

D tbl就能看到字段也可以通过from pg attribute where attrelid=‘tbl’::regclass做隐形转化可以直接把tbl类型转换成 regclass 类型转成16470,sql 语句直接写成16470也可以常用的方法是转成 regclass虚拟的数据类型通过 attribute 输出的三个字段对应的 attum 是1,2,3,-1,-3,-5,-6,-7。

drop table tbl;

创建表

create table thl(id int , info text , crt_time timestanp> with oids ;

查询系统表可以看到字段因为是隐含字段大于等于1的attnum中可以看到如果加了oid就会多了-2的attnum包含隐含字段ctidtableoid,cmax,xnax,cmin,Xmin,oid

  1. r | pg_ auth_ members 数据库用户的成员关系信息。比如创建某一个角色所有的权限都是基于角色进行控制

grant digoal to postgres ;

select =from pg_auth_members

Pg_roles 视图

Postgre 中很多系统都是通过 oid 做管理

Pg_authid

select oid,* from pg_authid ;

有两个用户它的oid分别是1016482。

Grantor10把权限给16482。

  1. r | pg _authid 存储数据库用户的详细信息(包括是否超级用户,是否允许登陆,密码(加密与否和创建用户时是否指定encrypted有关),密码失效时间等)。

输入123,可以认为是一个字符串也可以认为数据类型

insert into tbl values <'123' ,' test' now<>>;

做了隐式转化所以可以输入

11、r | pg _cast 数据库的显性类型转换路径信息,包括内建的和自定义的。

12、r | pg_ class 几乎包括了数据库的所有对象信息(r = ordinary table, i= index, 大写S = sequence, 视图v = view, m = materialized view, 自定义类型c = composite type, t= TOAST table,外部表 f= foreign table)

relkind中存储单字符串数据

13、r | pg_ collation 集信息,包括国际化的信息 encoding, collate, ctype 等。

From pg_ collation;

可以看到collnamespacecollownercollencodingcollcollatecollctype

Postgre支持的编码都在里面

14、r | pg _constraint 存储列上定义的约束信息(例如PK FK UK排他约束 check 约束但是不包括非空约束)

15、r | pg _conversion 字符集之间的转换的相关信息

connname 转换名字叫 ascii_to_mic可以把ascii编码转换成 mic也有 gbk 相互转换,df euc_jr to_utf8

16、r | pg_ database 集群中的数据库信息

17、r | pg_db_role_setting基于角色和数据库组合的定制参数信息(alterroleset...

From pg_db_role_setting没有信息

Alter role digoal set enable _ seqscan =off;16482角色参数是关闭的用户连接后不允许做全链扫描是在其它所有的路径不通的情况下但是有一个索引在就允许它

grant se lect on ALL TABLES IN schema sa to digoal;

查 default 表中什么也没有

创建 create table sa.tbl<id int>;

Dp’ sa. tb1

\c digoal digoal

用户没有链接权限

alter role digoal login;

Select*from sa.tbl;

permission denied for schema sa

grant select on ALL TABLES IN *chema sa to digoal;

LTER DEFAULT PRIỤI LEGES FOR role postgres in schema sa

grant all on tables to digoal ;

在 sa 里面所有的用户 postgres 创建的表所有的权限都赋予给 digoal默认会进行 arwdxt postgres

Create table sa.test ;

在创建表时会读 from Pg_ default _acl系统表自动生成 arwdxt postgres 权限

ALTER DEFAULT PRIULEGES FOR role postgres in schema sa

grant select on tables to test

多了读的权限假设在 sa schema下面创建表的对象创建对象时自动把读的权限进行使用通过命令给予的权限都会反映在 Pg_ default _acl 系统表中只跟 ALTER DEFAULT PRIULEGES FOR 命令有关系

Create table sa.test1;

Dp*sa.test1

18、r | pg_ default_ acl 存储新建对象的初始权限信息

19、r | pg_ depend 数据库对象之间的依赖信息

20、r | pg_ description 数据库对象的描述信息

21、r | pg_ enum 枚举类型信息

22、r | pg _event_ trigger 事件触发器信息

23、r | pg _extension 扩展插件信息

24、r | pg_ foreign_ data_ wrapper  FDW信息

25、r | pg_ foreign_ server 外部服务器信息

26、r | pg_ foreign_ table 外部表信息

27、r | pg_ index 索引信息

28、r | pg inherits 继承表的继承关系信息

29、r | pg langage 过程语言信息

支持internalcsqlplogsql四种语言

30、r | pg_ largeobject 大对象的切片后的真实数据存储在这个表里

31、r | pg_largeobject_ metadata 大对象的元信息,包括大对象的 owner访问权限.

32、r | pg _namespace 数据库中的 schema 信息(pg 中称为 namespace)

33、r | pg. _opclass 索引访问方法的操作符分类信息.

34、r | pg_ operator 操作符信息

35、r | pg _opfamily 操作符家族信息

36、r | pg _pltemplate 过程语言的模板信息

37、r | pg _proc 数据库服务端函数信息

create function f_test<id int> returns int as $$

declare

begin

Return id+1;

end ;

$$ language plpgsql strict ;

From pg_proc where pronane ='f _test’;

存在prosrc中

declare

begin

Return id+1 ;

end ;

Postgre 里面创建同名的函数

create function f_testreturns int as $$

查询到两个函数<id idl>,对应同一函数名只要参数类型不一样就可以创建多个函数调用一个类型就是 di调用两个类型就是 f_test

38、r | pg _range 范围类型信息

39、r | pg_rewrite 表和视图的重写规则信息

40、r | pg_ seclabel 安全标签信息(SELinux)

41、r | pg_shdepehd 数据库中的对象之间或者集群中的共享对象之间的依赖关系

42、r | pg _shdescription 共享对象的描述信息

43、r | pg_ shseclabel 共享对象的安全标签信息(SELinux)

44、r | pg_ statistic - analyze 生成的统计信息,用于查询计划器计算成本

45、r | pg _tablespace 表空间相关的信息

46、r | pg _rigger 表上的触发器信息

47、r | pg _ts_config 全文检索的配置信 息

48、r | pg ts_ config_map 全文检索配置映射信 息

49、r | pg _ts_dict 全文检索字典信息

50、r | pg_ts_parser-全文检索解析器信息

51、r | pg _ts_ template 全文检索模板信息

52、r | pg_type 数据库中的类型信息

53、r | pg _user mapping - foreign server 的用户配置信息


五、PostgreSQL 系统视图介绍

1、select relkindrelname from Pg class where

relnamespace = (select oid from Pg_ namespace where

nspname- 'Pg catalog) and relkind=v' order by 1,2

系统视图通过另外一个 sql 语句可以达到或者 dv s 也能得到系统的值包括安装的 Pldbgapi 数据库在启动时会读

2、v | pg_ available_extension_ versions 显示当前系统已经编译的扩展插件的版本信息

通过版本进行查询plpgsql 1.1.0

安装了两个插件 Pldbgapiplpgsql

3、v | pg_ available_extensions 显示当前系统已经编译的扩展插件信息

4、v | pg _cursors 当前可用的游标

5、v | pg group 用户组信息

6、v | pg _indexes 索引信息

7、v |pg_ locks 锁信息

8、v | pg_matviews 物化视图信息

9、v | pg prepared statements 当前会话中使用 prepare 语法写的预处理 SQL 信息

10、v | pg_ prepared _xacts 二阶事务信息

11、v | pg_ roles 数据库角色信息

12、v | pg_rules 数据库中使用 create rule 创建的规则信息规则可以用来做数据分区

13、v | pg. seclabels -安全标签信息

select from pg_ shadow

14、v | pg_settings 当前数据库集群的参数设置信息

15、v| pg_ shadow 数据库用户信息

可以看到密码 nd53175bce1 d3201d16594ce bf 9d7eb3f 9d空的代表用户没有密码输入权限的角色

16、v | pg _stat_activity 会话活动信息

17、v | pg_stat_all_indexes 查询用户权限范围内的所有索引的统计信息

18、v | pg_stat_ all _tables 查询用户权限范围内的所有表的统计信息stat统计信息的意思

19、v | pg_ stat_ bgwriter_ bgwriter 进程的统计信息

20、v | pg_stat_ database 数据库级别的统计信息

21、v | pg_ stat_ database_ conficts 数据库冲突统计信息

22、v | pg_ stat_ replication 流复制相关的统计信息

23、v | pg_ stat_ sys_ indexes 系统表相关的索引统计信息

24、v Ipg_ stat_ sys_tables 系统表统计信息

25、v | pg _stat_ user_ functions 用户函数统计信息

26、v | pg_stat_user_ indexes 用户表的索引相关的统计信息

27、v | pg_stat_user_ tables 用户表统计信息

28、v | pg_ stat_ xact all tables 当前事务的表级统计信息,显示用户可以访问的所有表

29、v | pg_stat_ xact_ sys _tables 当前事务的表级统计信息,仅显示系统表

30、v | pg_ stat _xact_user_ functions 当前事务的用户函数的统计信息

31、v | pg _stat_ xact_ user _ables 当前事务的用户表的统计信息

32、v | pg_ stalio_ all indexes - io 相关的统计信息

33、v | pg_ statio_ all sequences

34、v | pg_ statio_ all tables

35、v | pg_ statio_ sys_ indexes

36、v | pg_ statio_ sys_ sequences

37、v | pg_ statio_ sys_ tables

38、v | pg_ statio_ user_indexes 用户级别

39、v | pg_ statio_ user_ sequences

40、v | pg_statio_ user_ tables

41、v | pg_ stats 数据库中的统计信息,以列为最小统计单位输出

42、v | pg_tables 数据库中的表对象的信息

43、v | pg_ timezone_ abbrevs 时区缩写信息

44、v | pg_ timezone_ names 时区信息,包含全名

45、v | pg_ user 用户信息

46、v | pg _user_mappings 外部表的用户映射权限信息

47、v | pg_ views 视图信息


六、PostgreSQL 管理函数

系统视图还是系统表之间的关联都是通过 oidreferences 表示关联关系relnamespace 是 oid 类型关系到pg namespace.oid 表的字段在 pg.class 查表对应的放在哪个 space 下面可以通过关联关系进行对应比如对应的类型是什么对应的是 pg type.oid属于哪个用户下面的 pg authid. oid 查询很多都是通过 oid 进行关联

1、http://www.postgresql.org/docs/9.3/static/functions-admin.html

2、管理函数

Name

Return Type

Description

current_ setting(setting_ name)查看当前的配置

Showenable_seqscan或from curret_ sett ing(' enable seqscan' ) ;

text

get current value of setting

set_ config(setting_ name new_ value is_ local)配置名字新的值是否设置当前的环境中

from set_config< ‘enable -seqscan' . ' off ‘,false>;

Set_config

off

is_ local)只设置本地如果把设置关掉它就会继承上一个设置了会话级别

text

set parameter and return new value

3、服务端信号发送函数

Name

Return Type

Description

pg_ cancel_ backend(pidint)

某一个进程执行sql语句半天没有响应把当前查询退出不让查只是把当前sql语句断掉绘画还是连在上面

boolean

Cancel a backend's current query You can execute this against anotherbackend that has exactly the same role as the user calling the function. In allother cases you must be a superuser.

pg_ reload_confo

重读配置文件比如数据库有常用的配置文件一个是pg_hba.conf,一个是postgresql.conf,如果对这两个文件做修改修改生效执行sql语句进行重读发信号看接收的信号是什么signit信号reloadtheserverconfigurationfiles接收sighup信号kill -ssighup 13723把信号发给进程跟踪日志可以看到pg_log/

Tail -f -n 1 postgresql-2013-12-27_190209 .c sv

可以看到接收到了sighup信号做reloadingconfiguration动作

Pg_ctl reload发送了相同的信号通过函数也是接收到信号

boolean

Cause server processes to reload their configuration files

pg_ rotate_ logfileo

文件很大几百兆可以看到新生成两个文件csvlog

boolean

Rotate server's log file

pg_ terminate_ backend(pidint)

直接把终端关闭连接在上面没有响应也没有执行sql把上面的更暴力直接把会话断掉

boolean

Terminate a backend. You can execute this against another backend that has

exactly the same role as the user calling the function. In all other cases you

must be a superuser.

4.备份控制函数

Name

Return Type

Description

pg_ create_ restore_ _point(name text)创建还原点

text

Create a named point for performing restore (restricted to superusers)

pg_ current _xlog_ insert_ location()虚拟地址分成两个段返回具体的意思查看源代码

text

Get current transaction log insert location

pg_ current_ xlog_ location()正在写的信息30f8df8

text

Get current transaction log write location

pg_ start_ _backup(label text [ fast boolean ])备份数据库启动指定参数select pg _start_backup('first backup' >;wal必须在归档级别或者standby级别当前是minimal模型不允许在线备份数据库改成hot_standby就允许备份数据库拷贝文件

text

Prepare for performing on-line backup (restricted to superusers or replication roles)

pg_stop_ backup()

备份完之后需要执行命令进行归档动作把备份的文档归档到归档文件中再把归档文件拷出来

text

Finish performing on-line backup (restricted to superusers or replication roles)

pg_is _in_ _backup()当前是否正在备份

bool

True if an on-line exclusive backup is still in progress

pg_ backup_ start_ time()备份启动时间创建标签文件back_label,START WAL LOCATION: 0/4000028 (file 00000001 0000000000000004)备份时写在哪里

CHECKPOINT  LOCATION: /4000060

位置在哪里

BACKUP METHOD :

pg start backup备份方法

BACKUP FROM: mas ter备份在左节点进行

START TIME: 2013-12-27 21 :02:52 PST 启动时间

LABEL: first backup标签

timestamp

with time

zone

Get start time of an on-line exclusive backup in progress.

pg_ switch _xlog()切换xlog的意思

text

Force switch to a new transaction log file (restricted to superusers)

pg_xlogfile_ name(location text)把虚拟地址作为参数传给函数需要地址信息对应的xlog的名字是什么通过名字找到xlog信息

text

Convert transaction log location string to file name

pg_xlogfile_ name_ _offset(location text)在文件中告诉虚拟地址地址在xlog中偏移量是多少

text integer

Convert transaction log location string to file name and decimal byte offset within file

pg_ xlog_ _location_ diff(location text location text)返回两个虚拟地址之间的数据量有两个xlog的虚拟地址告诉之间的字节数是多少,0-16,16兆给地址,0兆给地址计算出是16

numeric

Calculate the difference between two transaction log locations

5、恢复控制函数

Name

Return Type

Description

pg_ is_in_ recovery()当前是否在做数据恢复检查当前数据库是否是standby总结点返回falsestandby节点返回的是true

bool

True if recovery is still in progress.

pg_ last_ xlog receive_ location()接收到哪个虚拟定位

text

Get last transaction log location received and synced to disk by streaming replication. Whilestreaming replication is in progress this will increase monotonically. If recovery has completed thiswill remain static at the value of the last WAL record received and synced to disk during recovery.

pg_ last_ xlog_ replay_ location()持续恢复恢复到哪个点通过函数返回的是位置

text

Get last transaction log location replayed during recovery. If recovery is still in progress this will

increase monotonically If recovery has completed then this value will remain static at the value of

the last WAL record applied during that recovery. When the server has been started normally

without recovery the function returs NULL. .

pg_ last_ xact_ _replay_ _timestamp()最后一次事物的时间戳返回的是时间戳

timestamp with time zone

Get time stamp of last transaction replayed during recovery. This is the time at which the commit or

abort WAL record for that transaction was generated on the primary If no transactions have been

replayed during recovery this function returns NULL. Otherwise if recovery is still in progress this

will increase monotonically. If recovery has completed then this value will remain static at the

value of the last transaction applied during that recovery When the server has been started

normally without recovery the function returns NULL. 

pg_ is_xlog_ replay_ paused()基于时间点恢复延迟暂停恢复调用paused数据库从总结点接收到xlog文件

bool

True if recovery is paused.

pg_ xlog_ replay_ _pause()接收过来不做恢复好处是在总结点做测试更新删除数据随时回滚在standby上执行pause暂停住standby虽然会接收xlogstandby暂停恢复如果要马上恢复激活把数据导出来再回给总结点也可以

void

Pauses recovery immediately.

pg_ xlog_ replay_ resume()查看当前是否暂停如果暂停重启resume

void

Restarts recovery if it was paused.

6、事物镜像导出函数

Name

Return Type

Description

pg_ export_ snapshot()

并行逻辑备份事物必须是串行级别以上

text

Save the current snapshot and return its identifier

7、数据库对象管理函数

Name

Return Type

Description

pg_ column_ size(any)看列的大小,select pg Co lumn size(oid> from pg c las s

Limit 1;oid占四个字节relname占64个字节

int

Number of bytes used to store a particular value (possibly compressed)

pg_ database_ size(oid)

select pg - database - s ize( ' digoal' ) ;数据库占6809784个字节通过-l+也可以看到

bigint

Disk space used by the database with the specified OID

pg_ database_ _size(name)

bigint

Disk space used by the database with the specified name

pg_ indexes_ size(regclass)索引的大小select pg indexes size<oid)>from pg_class where relkind=' i' limit 1;索引都是0

bigint

Total disk space used by indexes attached to the specified table

pg_ relation_ size(relation regclass fork text)查看main的文件大小还是fsm的文件大小还是vm文件大小

查看表的大小查看索引的大小

bigint

Disk space used by the specified fork ('main'主要数据存在main 'fsm' 存储的数据块的空闲时间分别是百分之多少空闲信息or 'vm'存储的是数据块信息是否对所有事物可见没有脏数据都在vm中对进程可以减少开销) of the specified table or index

pg_ relation_ _size(relation regclass)

bigint

Shorthand for pg_ relation_ size(... 'main')后面不加参数表多大索引多大

pg_ size_ pretty(bigint)多少kb多少gb

text

Converts a size in bytes expressed as a 64-bit integer into a human-readable format with size units

Pg_size_ pretty(numeric)

text

Converts a size in bytes expressed as a numeric value into a human-readable format with size units

pg_ table_ _size(regclass)查看表的大小

bigint

Disk space used by the specified table excluding indexes (but including TOAST free space map andvisibility map)

pg_ tablespace size(oid)统计数据所有数组大小的综合接受oid类型表空间对饮过得oid

bigint

Disk space used by the tablespace with the specified OID

pg_ tablespace_ size( name)接受name参数类型表空间名字

bigint

Disk space used by the tablespace with the specified name

pg_ total_ relation_ size(regclass)

bigint

Total disk space used by the specified table including all indexes and TOAST data计算表的大小包括表上面所有的索引和TOAST data的大小

8、数据库对象存储位置管理函数

表对应的是哪个数据文件可以通过函数查询在 pg_root 下相对路径,base /16392/16476_ fsn,base/16392/16476_vm,如果看底层信息可以创建 create extension pgpageinspect ;

select from fsm_ page contents

0>>;输出底层信息输入 mainvim 查看

Name

Return Type

Description

pg_ relation_ filenode(relation regclass)

oid

Filenode number of the specified relation

pg_ relation_ filepath(relation regclass)

text

File path name of the specified relation

9、文件访问函数

Name

Return Type

Description

pg_ ls_ dir(dirmame text)列出目录里面有哪些东西

setof text

List the contents of a directory

pg_ read_ file(filename text [ offset bigint length bigint])读文件

text

Return the contents of a text file

pg_ read_ binary_ file(filename text [ offset bigint length bigint])读返回的内容二进制文件

bytea

Return the contents ofa file

pg_ stat_ file( filename text)文件的状态信息什么时候被更新的访问时间是什么大小是多大是不是目录

record

Return information about a file

10、应用锁函数,对于长时间持锁的应用非常有效,做 dml 之后对一条记录产生多个版本通过多个版本进行 bmr控制降低控制冲突所以数据库要不停的回收垃圾如果是 key bigint 事物并且长时间开在这里不关闭事物之前所产生的垃圾不能被会收掉因为是 key bigint 隔离级别的事物能够有权利读到以前变更并且已提交的垃圾数据即使数据删掉也能读到数据垃圾回收并不能把所有数据都回收掉因为长时间的数据库重量锁会带来垃圾回收的问题。

Name

Return Type

Description

pg_ advisory_ lock(key bigint)跟数据没关系在内存中的锁状态会话级别事物级别

void

Obtain exclusive session level advisory lock

pg_ advisory_ lock(keyl int key2 int)

void

Obtain exclusive session level advisory lock

pg_ advisory _lock_ shared(key bigint)

void

Obtain shared session level advisory lock

pg_ advisory_ lock_ shared(keyl int key2 int)

void

Obtain shared session level advisory lock

pg_ advisory_ unlock(key bigint)

boolean

Release an exclusive session level advisory lock

pg_ advisory_ unlock(keyl int key2 int)

boolean

Release an exclusive session level advisory lock

pg_ advisory_ unlock_ all()

void

Release all session level advisory locks held by the current session

pg_ advisory_ unlock_ shared(key bigint)

boolean

Release a shared session level advisory lock

pg_ advisory unlock_ shared(key1 int key2 int)

boolean

Release a shared session level advisory lock

pg_ advisory _xact_ lock(key bigint)

void

Obtain exclusive transaction level advisory lock

pg_ advisory xact_ lock(key1 int key2 int)

void

Obtain exclusive transaction level advisory lock

pg_ advisory_ _xact_ lock_ shared(key bigint)

void

Obtain shared transaction level advisory lock


七、PostgreSQL 进程结构

1、进程源码大部分在: src/backend/postmaster。

2、postmaster 所有数据库进程的主进程(负责监听和 fork 子进程)。

3、startup 主要用于数据库恢复的进程。

4、syslogger 记录系统日志。

5、pgstat 收集统计信息。

6、pgarch 如果开启了归档,那么 postmaster 会 for 个归档进程。

7、checkpointer 负责检查点的进程,

8、bgwriter 负责把 shared buffer 中的脏数据写入磁盘的进程

9、autovacuum lanucher 负贵回收垃圾数据的进程,如果开启autovacuum 的话,那么 postmaster 会 fork 这个进程。

10、autovacuum worker 负责回收垃圾数据的 worker 进程,是 lanucher 进程 fork 出来的。


八、PostgreSQL 物理结构

1、数据存储结构

第一个问题:对象对应的物理文件在哪里?

create table tblt (id int) tablespace tbs test ;

pg tblspc/15384/PG_ 9.3 201306121/16392/16609

目录数据库表空间的 oid数据库表的 id

select oid from pg_tablespace where spcname=tbs_test' ;

16392连接的是当前对应的数据库

select oid from pg database where datname .' digoal '

16392

表空间表空间的 oid,版本信息数据库的 oidfilenode oid

pg_ tblspc/66422/PG_9.3_201306121/16384/12658

(1 row)

分解

数据库总目录短链接

pg_ tblspc/66422/PG_ 9.3_ 201306121/16384/12658

代表$PGDATA 中的相对路径

2.66422

这个对应表空间 oid

digoal= # select spcname from pg_ ,tablespace where oid=66422;

spcname

tbs_ _digoal

(1 row)

2、数据文件结构

image.png

One DataFile(s) Per Table or Index .

BlockID :

sequentially, 0 to 0xFFFFFFE

Initilixd Block 0x00000000是数据块每插入一个记录有合适的会取没有合适的会新生成数据块生成数据块数据块的大小在编译数据库时的大小默认是8。

with-blocksize -BLOCKSIZE set table block size in kB [8 ]

数据块不够用或者没有数据空间会生成数据块8kB。数据块在整个数据体系中有 id,0号数据块,1号数据块,0号数据块里面第一条记录<0,1>,数据块里面存储了很多条数据,0,1,0,2,0,3,32位的地址空间所以最多到0xFFFFFFE 数据大小新生成blockid继续往后datafile 应该是 datafiles因为是很多数据文件一个数据文件的大小有限默认1gb2gb 时第二个数据文件不是从0号开始编,从前面那个号用完开始再加一个号开始编的。

3、单个 BLOCK 的结构

PageHeaderData(24 Bytes)配置头部信息24字节

ItemIdData(Array of (offset,length) pairs 在数据块中的位移地址位移地址是6000,从第6000个字节开始长度是100,6000-6100就是在数据块中的位置

数据开始分配在页面中的索引

pointing to«she actual items. 4 bytes per item)

Free space(The unallocated space.

New item pointers are allocated from the start of this area,

new items from the end.)

行的索引从下往上分配

Items (The actual items themselves.)

如果是索引数据块在最底部有索引相关的信息如果是存数据的数据块存表以下信息就没有

Special space (Index access method specific data.

Different methods store different data. Empty

in ordinary tables. )( an access method should always

initialize its pages with PageInit

and then set its own opaque fields. )

4、BLOCK 头数据结构

Field

Type

Length

Description

pd_ lsn

最后一次被改变的字符号

XLogRecPtr

记录指针

8 bytes

LSN: next byte after last byte of xlog record for

pd_ tli当前数据块实例线的id

uintl 6

2 bytes

last change to this page

pd_ flags数据块剩余空间

uintl 6

2 bytes

TimeLineID of last change (only its lowest 16

pd_ lower

LocationIndex

2 bytes

bits)

pd_ upper

LocationIndex

2 bytes

Flag bits

pd_ special如果是索引地址是什么

LocationIndex

2 bytes

Offset to start of free space

pd_ pagesize_ version版本号

uintl6

2 bytes 

Offset to end of free space

pd prune_ xid

TransactionId

4 bytes

Offset to start of special space

2、TUPLE 数据结构

image.png

如果存储的是表的数据块表里面有每一条记录每一条记录对应每一行的头部信息是23个字节中间三个虚线是可选的只要有字段允许为空就有 null bitmap,1表示非空,0表示空如果有空空的字段在行中没有占任何空间只能通过 bitmap 标识它

HeapTupleHeaderData(23 Bytes on most machine)

null bitmap(Optional,The null bitmap is only present

if the HEAP_ HASNULL bit is set in t infomask.

occupies enough bytes to have one bit per data column.

a 1 bit indicates not-null, a 0 bit is a null)

存储对齐添加

Padding(Optional, Any padding needed to make t_ hoff a

MAXALIGN multiple will appear between the null bitmap

and the object ID)

创建表时有 object ID,行头部里面也会包含

object ID(Optional, only present if the

HEAP_ HASOID bit is set in t_ infomask)

ColumnData

3、TUPLE 头部数据结构

Field

Type 

Length

Description

t_xmin

TransactionId

4 bytes

insert XID stamp

T_xmax

TransactionId

4 bytes

delete XID stamp

T_cid

CommandId

4 bytes

insert and/or delete CID stamp (overlays

T_xvac

TransactionId

4 bytes

witht _xvac)

T_ctid

记录hot相关的信息

ItemPointerData

6 bytes

XID for VACUUM operation moving a row

T_infomask2

intl6

2 bytes 

version

t_ infomask存储标签行锁信息当前行锁是否有效提交状态是什么样的

uintl 6

2 bytes

current TID of this or newer row version

T_hoff

uint8

1 byte

number of attributes, plus various flag bits

7、使用 pg_ pageinspect 插件可以观察这些数据

image.png

图例data 目录base 相对目录默认表空间,16385数据库 oid,24692表空间 oid默认表空间下面是数据库的oid如果是自定义的表空间下面会有表空间的 odi数据文件被切成数据块的单位在数据块中存储行的信息数据块头部行的信息 tuple从下往上分配在当前页面中的索引


九、PostgreSQL 数据库可靠性

1、当一批事物提交后数据库只要硬件没有坏事物在下次也是提交的状态不会变成中间状态通过 wal 保证fsync 指的是把 walbuffer里面的数据放到 wal 存储的磁盘里面通过调用 fsync 的接口调用内部短信的接口把buffer 信息写到存储上面对于 writecache 有断电保护断电了也能写到磁盘里面硬盘级别的 cache 没有断电保护比如笔记本硬盘 writecache 打开再写数据笔记本是死机状态会发现某些数据丢失写在硬盘 cahce 上面没有写到硬盘非易失存储会导致丢失postgre 只到了 writecache 这一层在这个架构里面硬盘硬盘的writecache 不要打开确保存储有断电保护才要打开如果不能保证硬件在损坏之后存储掉电数据会丢失只能保证到 buffercache交给存储控制器靠硬件如果没有掉电保护建议关掉硬盘的 cache 一定要关掉当安全时数据可以得到保障

image.png

  1. 归档的图例做了 checkpoint 的点数据块在第一次变更时整个数据块都会写到 wal后面变只写一部分确保在做恢复时拿到所有的数据左边是在线的备份备份完把归档日志也要备份如果有误操作恢复到点可以把备份拿出来做时间点的恢复确保数据库可靠

image.png

3、让数据库可靠的注意事项

跟数据库可靠性息息相关当配置不当会失去可靠性/

1、事务提交后确保这个事务未来可恢复吗?

事务返回成功前,事务日志(xlog)写入磁盘, synchronous_ commit = on 保持数据库一次性但是不能保证数据库完全不丢失不可能出现先提交的事物在后提交的事物之后数据一次性可以保证可能会丢失没有写入磁盘的一些信息大大提高写的效率如果磁盘 io 性能不够的情况下会发现使用 synchronous_ commit 之后写信会有极大的提高

2、备份可恢复吗?恢复后确保数据致吗?

fsync= on . full_ page_ writes = on 打开数据一致

3、必须写入非易失存储的 数据已经写入到非易失存储了吗?

write - through,write - back 存储没有掉电保护建议关闭 writecache使用 write - through

关闭磁盘的 write cache

只允许有断电保护的 write cache。

4、主机异常 DOWN 机后重启数据库能不能起到一个一致的状态?

write 打开PostgreSQL periodically writes full page images

to permanent WAL storage before modifying the actual

page on disk. -- full_ _page_ writes= on

5、数据库异常 DOWN 机后重启数据库能不能起到一个一致的状态?

PostgreSQL periodically writes full page images to

permanent WAL storage before modifying the actual page

on disk. -- full page_ writes = on

6、事务日志可以用于恢复到任意时间点吗?

开启归档,并且有良好的备份策略。

wal _level = archive 或 hot standby

7、如果存储挂了怎么办?

开启归档,并且有良好的备份策略。

wal_ level = archive 或 hot_standby

archive_ mode = on 打开归档

archive_ command = 'cp %p /backup/%f

8、如果 IDC 挂了怎么办?

开启归档,并且有良好的备份策略。

wal_ level = archive 或 hot _standby

异地容灾,如流复制。

十、练习

1、系统表直接的关联关系的熟悉

2、系统视图的使用

3、系统管理函数的使用

4、pageinspect 插件观察数据块,uple,数据

相关实践学习
使用PolarDB和ECS搭建门户网站
本场景主要介绍基于PolarDB和ECS实现搭建门户网站。
阿里云数据库产品家族及特性
阿里云智能数据库产品团队一直致力于不断健全产品体系,提升产品性能,打磨产品功能,从而帮助客户实现更加极致的弹性能力、具备更强的扩展能力、并利用云设施进一步降低企业成本。以云原生+分布式为核心技术抓手,打造以自研的在线事务型(OLTP)数据库Polar DB和在线分析型(OLAP)数据库Analytic DB为代表的新一代企业级云原生数据库产品体系, 结合NoSQL数据库、数据库生态工具、云原生智能化数据库管控平台,为阿里巴巴经济体以及各个行业的企业客户和开发者提供从公共云到混合云再到私有云的完整解决方案,提供基于云基础设施进行数据从处理、到存储、再到计算与分析的一体化解决方案。本节课带你了解阿里云数据库产品家族及特性。
相关文章
|
2月前
|
存储 关系型数据库 数据库
【赵渝强老师】PostgreSQL的逻辑存储结构
PostgreSQL的逻辑存储结构包括数据库集群、数据库、表空间、段、区、块等。每个对象都有唯一的对象标识符OID,并存储于相应的系统目录表中。集群由单个服务器实例管理,包含多个数据库、用户及对象。表空间是数据库的逻辑存储单元,用于组织逻辑相关的数据结构。段是分配给表、索引等逻辑结构的空间集合,区是段的基本组成单位,而块则是最小的逻辑存储单位。
【赵渝强老师】PostgreSQL的逻辑存储结构
|
3月前
麒麟系统mate-indicators进程占用内存过高问题解决
【10月更文挑战第7天】麒麟系统mate-indicators进程占用内存过高问题解决
332 2
|
15天前
|
存储 监控 Linux
嵌入式Linux系统编程 — 5.3 times、clock函数获取进程时间
在嵌入式Linux系统编程中,`times`和 `clock`函数是获取进程时间的两个重要工具。`times`函数提供了更详细的进程和子进程时间信息,而 `clock`函数则提供了更简单的处理器时间获取方法。根据具体需求选择合适的函数,可以更有效地进行性能分析和资源管理。通过本文的介绍,希望能帮助您更好地理解和使用这两个函数,提高嵌入式系统编程的效率和效果。
75 13
|
1月前
|
存储 SQL 关系型数据库
【赵渝强老师】PostgreSQL的物理存储结构
PostgreSQL在初始化时通过环境变量$PGDATA指定的目录下生成各类文件,构成其物理存储结构,包括数据文件、日志文件(如运行日志、WAL预写日志、事务日志和服务器日志)、控制文件及参数文件等,确保数据库的高效运行与数据安全。
|
2月前
|
网络协议 Linux 虚拟化
如何在 Linux 系统中查看进程的详细信息?
如何在 Linux 系统中查看进程的详细信息?
141 1
|
2月前
|
Linux
如何在 Linux 系统中查看进程占用的内存?
如何在 Linux 系统中查看进程占用的内存?
|
4月前
|
监控
MASM32写的免费软件“ProcView/系统进程监控” V1.4.4003 说明和下载
MASM32写的免费软件“ProcView/系统进程监控” V1.4.4003 说明和下载
|
3月前
麒麟系统mate-indicators进程占用内存过高问题解决
【10月更文挑战第5天】麒麟系统mate-indicators进程占用内存过高问题解决
208 0
|
4月前
|
监控 Ubuntu API
Python脚本监控Ubuntu系统进程内存的实现方式
通过这种方法,我们可以很容易地监控Ubuntu系统中进程的内存使用情况,对于性能分析和资源管理具有很大的帮助。这只是 `psutil`库功能的冰山一角,`psutil`还能够提供更多关于系统和进程的详细信息,强烈推荐进一步探索这个强大的库。
56 1
|
4月前
|
安全 开发者 Python
揭秘Python IPC:进程间的秘密对话,让你的系统编程更上一层楼
【9月更文挑战第8天】在系统编程中,进程间通信(IPC)是实现多进程协作的关键技术。IPC机制如管道、队列、共享内存和套接字,使进程能在独立内存空间中共享信息,提升系统并发性和灵活性。Python提供了丰富的IPC工具,如`multiprocessing.Pipe()`和`multiprocessing.Queue()`,简化了进程间通信的实现。本文将从理论到实践,详细介绍各种IPC机制的特点和应用场景,帮助开发者构建高效、可靠的多进程应用。掌握Python IPC,让系统编程更加得心应手。
43 4