Postgresql数据库体系结构-进程和内存结构

简介: 数据库体系结构-进程和内存结构(Process and Memory Architecture) 进程结构 服务器进程postmaster后台工作进程后端进程 内存结构 本地内存区 work_memmaintenance_work_memtemp_buffers 共享内存区 shared buffer poolWAL buffercommit log 数据库启动过程 数据库连接过程 PostgreSQL是一个client/server架构rdbms,一个服务器上运行多个进程。

数据库体系结构-进程和内存结构(Process and Memory Architecture)

  • 进程结构

服务器进程postmaster

后台工作进程

后端进程

  • 内存结构

本地内存区

work_mem

maintenance_work_mem

temp_buffers

共享内存区

shared buffer pool

WAL buffer

commit log

  • 数据库启动过程
  • 数据库连接过程

PostgreSQL是一个client/server架构rdbms,一个服务器上运行多个进程。

1、进程结构



Postgres Server Process(postmaster)--pg的主进程,也是父进程,后端进程和后台工作进程都是由server process fork派生出来;同时具有监听的功能

Background Processes--后台工作进程,实现数据库的功能及管理

logger process--日志收集进程,将日志信息输出到日志文件

checkpointer process--检查点进程,执行检查点

writer process--后台写进程,将shared buffer中的数据写入磁盘

wal writer process--后台wal日志写进程,将walbuffer中的日志流写入磁盘

autovacuum launcher process--自动清理进程,清理版本数据,向postmaster主进程申请调用autovacuum进程

archiver process--归档进程,归档wal日志

stats collector process--统计信息收集进(pg_stat_database、pg_stat_activity)

logical replication,wal sender process等其他进程
backed process--后端进程求,用来处理客户端连接请服务

pg postgres [local] idle--本地登陆进程

pg postgres 192.168.6.1(53171) idle--远程登陆进程

pg postgres 192.168.6.1(51846) idle intransaction--远程登陆进程,进程中事务未完成

eg 
[root@pg ~]# pstree -ap |grep post |grep -v grep
|-postmaster,889 -D /opt/postgres/data
| |-postmaster,906 
| |-postmaster,990 
| |-postmaster,991 
| |-postmaster,992 
| |-postmaster,993 
| |-postmaster,994 
| |-postmaster,995 
| |-postmaster,996
| |-postmaster,1249 
| |-postmaster,1301
| `-postmaster,1428`
[root@pg ~]# ps -ef |grep postgres |grep -v grep
pg 889 1 0 09:44 ? 00:00:00 /opt/postgres//bin/postmaster -D /opt/postgres/data
pg 906 889 0 09:44 ? 00:00:00 postgres: logger process 
pg 990 889 0 09:44 ? 00:00:00 postgres: checkpointer process 
pg 991 889 0 09:44 ? 00:00:00 postgres: writer process 
pg 992 889 0 09:44 ? 00:00:00 postgres: wal writer process 
pg 993 889 0 09:44 ? 00:00:00 postgres: autovacuum launcher process 
pg 994 889 0 09:44 ? 00:00:00 postgres: archiver process 
pg 995 889 0 09:44 ? 00:00:00 postgres: stats collector process 
pg 996 889 0 09:44 ? 00:00:00 postgres: bgworker: logical replication launcher 
pg 1249 889 0 09:51 ? 00:00:00 postgres: pg postgres [local] idle
pg 1301 889 0 10:18 ? 00:00:00 postgres: pg postgres 192.168.6.1(51846) idle in transaction
pg 1428 889 0 11:03 ? 00:00:00 postgres: pg postgres 192.168.6.1(53171) idle
[root@pg ~]# 
以上以看出,postmaster fork出其他的进程,其中包括必可须的后台服务进程和后端进程。
注意:
由于所有进程都是由postmster进程派生出来的,不能对进程进行kill操作,否则会造成postmaster重启,也就是数据库重启
杀死后端进程需要使用函数pg_terminate_backend(apid int)
如:
postgres=# select pg_terminate_backend(1301);
pg_terminate_backend 
----------------------
t
(1 row)
postgres=# 

2、内存结构


  • Local memory area--每个后端进程自己使用,主要用于查询

work_mem--用于存放排序和hash结果

maintenance_work_mem--管理工作使用的内存,如VACUUM

temp_buffers--存储临时表

  • Shared memory area--所有进程共同使用,启动数据库后分配的内存

shared buffer pool--存放page,数据库所有操作都在此内存完成

WAL buffer--存放wal日志流

commit log--存放事务状态

内存大小有参数控制
postgres=# select name,setting,source from pg_settings where name like '%work_mem%';
name | setting | source 
----------------------+---------+---------
autovacuum_work_mem | -1 | default
maintenance_work_mem | 65536 | default
work_mem | 4096 | default
(3 rows)
postgres=# select name,setting,source from pg_settings where name like '%buffer%';
name | setting | source 
----------------+---------+--------------------
shared_buffers | 16384 | configuration file
temp_buffers | 1024 | default
wal_buffers | 512 | override
(3 rows)
知道以上内存的作用,进行参数调优

3、数据库启动过程


start数据库后,首先启动Postgres Server Process(postmaster),然后分配共享内存,分配内存后启动必须的后台工作进程,postmaster监听一个端口,等待客户端连接请求

4、客户端连接过程


客户端进程申请连接数据库,postmaster监听连接,通过连接认证后,fork出后台进程backend process代替客户端进程操作数据库

相关实践学习
使用PolarDB和ECS搭建门户网站
本场景主要介绍如何基于PolarDB和ECS实现搭建门户网站。
阿里云数据库产品家族及特性
阿里云智能数据库产品团队一直致力于不断健全产品体系,提升产品性能,打磨产品功能,从而帮助客户实现更加极致的弹性能力、具备更强的扩展能力、并利用云设施进一步降低企业成本。以云原生+分布式为核心技术抓手,打造以自研的在线事务型(OLTP)数据库Polar DB和在线分析型(OLAP)数据库Analytic DB为代表的新一代企业级云原生数据库产品体系, 结合NoSQL数据库、数据库生态工具、云原生智能化数据库管控平台,为阿里巴巴经济体以及各个行业的企业客户和开发者提供从公共云到混合云再到私有云的完整解决方案,提供基于云基础设施进行数据从处理、到存储、再到计算与分析的一体化解决方案。本节课带你了解阿里云数据库产品家族及特性。
目录
相关文章
|
存储 关系型数据库 数据库
【赵渝强老师】PostgreSQL的逻辑存储结构
PostgreSQL的逻辑存储结构包括数据库集群、数据库、表空间、段、区、块等。每个对象都有唯一的对象标识符OID,并存储于相应的系统目录表中。集群由单个服务器实例管理,包含多个数据库、用户及对象。表空间是数据库的逻辑存储单元,用于组织逻辑相关的数据结构。段是分配给表、索引等逻辑结构的空间集合,区是段的基本组成单位,而块则是最小的逻辑存储单位。
348 2
【赵渝强老师】PostgreSQL的逻辑存储结构
|
10月前
|
SQL 缓存 分布式数据库
【赵渝强老师】达梦数据库的线程结构
达梦数据库采用单进程、多线程结构,利用对称服务器架构实现高效资源利用与可扩展性。其核心线程类型包括监听线程(管理客户端连接)、I/O线程(处理数据页读写)、工作线程(执行数据操作)、调度线程(定时任务管理)和日志刷新线程(确保REDO日志刷盘)。通过合理分工与同步机制,达梦数据库实现了高性能与稳定性。视频讲解进一步详细介绍了各线程的功能与协作方式。
308 1
【赵渝强老师】达梦数据库的线程结构
|
10月前
|
存储 SQL NoSQL
【赵渝强老师】达梦数据库的逻辑存储结构
本文介绍了达梦数据库的存储结构,包括逻辑和物理存储两部分。逻辑存储结构由数据库(Database)、表空间(Tablespaces)、段(Segments)、簇(Cluster)和页(Page)组成。数据库是最大逻辑单元,包含所有表、索引等;表空间由数据文件组成,用于存储对象;段由簇构成,簇包含连续的数据页;页是最小存储单元。文中还提供了查询表空间、段和页大小的SQL语句,并附有视频讲解和示意图。
400 7
|
11月前
|
数据管理 关系型数据库 MySQL
数据管理服务DMS支持MySQL数据库的无锁结构变更
本文介绍了使用Sysbench准备2000万数据并进行全表字段更新的操作。通过DMS的无锁变更功能,可在不锁定表的情况下完成结构修改,避免了传统方法中可能产生的锁等待问题。具体步骤包括:准备数据、提交审批、执行变更及检查表结构,确保变更过程高效且不影响业务运行。
658 2
|
10月前
|
SQL 存储 缓存
【赵渝强老师】达梦数据库的内存结构
本文介绍了达梦数据库管理系统的内存结构,包括内存池、缓冲区、排序区和哈希区。内存池分为共享内存池和运行时内存池,能够提高内存申请与释放效率,并便于监控内存使用情况。缓冲区涵盖数据缓冲区、日志缓冲区、字典缓冲区和SQL缓冲区,用于优化数据读写和查询性能。排序区和哈希区分别提供排序和哈希连接所需的内存空间,通过合理配置参数可提升系统效率。文内附有具体配置示例及视频讲解,帮助用户深入理解达梦数据库的内存管理机制。
362 0
|
10月前
|
存储 SQL 安全
【赵渝强老师】达梦数据库的物理存储结构
本文介绍了达梦数据库的存储结构及各类物理文件的作用。达梦数据库通过逻辑和物理存储结构管理数据,包含配置文件(如dm.ini、sqllog.ini)、控制文件(dm.ctl)、数据文件(*.dbf)、重做日志文件(*.log)、归档日志文件、备份文件(*.bak)等。配置文件用于功能设置,控制文件记录数据库初始信息,数据文件存储实际数据,重做日志用于故障恢复,归档日志增强数据安全性,备份文件保障数据完整性,跟踪与事件日志辅助问题分析。这些文件共同确保数据库高效、稳定运行。
485 0
|
存储 SQL 关系型数据库
【赵渝强老师】PostgreSQL的物理存储结构
PostgreSQL在初始化时通过环境变量$PGDATA指定的目录下生成各类文件,构成其物理存储结构,包括数据文件、日志文件(如运行日志、WAL预写日志、事务日志和服务器日志)、控制文件及参数文件等,确保数据库的高效运行与数据安全。
336 1
|
SQL 数据库
gbase 8a 数据库 shm满导致gclusterd进程异常
gbase 8a 数据库 shm满导致gclusterd进程异常
|
Oracle 关系型数据库 数据库连接
|
SQL Cloud Native 关系型数据库
ADBPG(AnalyticDB for PostgreSQL)是阿里云提供的一种云原生的大数据分析型数据库
ADBPG(AnalyticDB for PostgreSQL)是阿里云提供的一种云原生的大数据分析型数据库
1963 1

推荐镜像

更多