PolarDB for PostgreSQL 开源必读手册-PolarDB数据库结构(中)

本文涉及的产品
云原生数据库 PolarDB MySQL 版,通用型 2核4GB 50GB
云原生数据库 PolarDB PostgreSQL 版,标准版 2核4GB 50GB
简介: PolarDB for PostgreSQL 开源必读手册

接上篇:https://developer.aliyun.com/article/1223108?spm=a2c6h.13148508.setting.32.44ec4f0eNvAByn


随着表的数据越来越多,文件尺寸超过1GB后,命名规则也会有所改变,会在原有名字后加上.1以示区别。

 

image.png

 

fsm(free space map)是空闲可用空间地图。比如有多个数据块,往表里插入数据时,需要明确哪个数据块里有空间可用于存放新插入的数据,PolarDB会先查看fsm文件。

 

vm是可见性地图,主要用于对表空间进行整理,帮助vacuum时提高效率。

 

数据文件的fork号为0,空闲空间映射的fork号为1,可见性地图的fork号为2。

 

image.png

 

PolarDB也支持自建表空间(目前仅在企业版PolarDB支持)。

 

创建新的表空间后,PGDATA下的pg.tblspc目录下存在与新建表空间名一致的目录。它是一个指针,指向创建表空间时的物理位置,数据存放于/home/postgres/tblspc上。

 

image.png

 

PolarDB默认有两个可用的表空间,pg_default和pg_global。默认情况下使用pg_default。

 

image.png

 

表数据文件内部被分为多个块,默认8k,每个块都有唯一ID。

 

上图右侧为数据块的结构。块头里面存放了控制性的信息,比如常见的行指针。存放数据时,顺序为从下往上存放,而块头的信息为从上往下存放,中间区域即可用空间。

 

image.png

 

一行数据插入到数据块中,首先,数据会进入块的底部,块头产生指针,指向行开始的位置。插入第二行数据,则会由下往上叠加,并在块头产生新的指针。

 

image.png

 

访问表的方式有两种

 

顺序扫描:即全表扫描。比如有两个数据块,PolarDB在访问时会先找到第一个块的位置,并从第一行开始进行完整扫描;如果没有,则进入第二个块的第一行继续扫描,以此类推。

 

索引扫描:根据索引行里记录的rowID进行扫描,无需全表扫描。

 

image.png

 

启动PolarDB数据库时,会先启动实例,实例由进程和内存组成。postgres server process是PolarDB的父进程,所有后台进程、后端进程等都由父进程派生。backend process进程负责处理用户请求,background process用于管理整个数据库。

 

image.png

 

Backend process负责客户端请求。客户端访问数据库时,并不会直接与数据库交互,而是将所有请求发给Backend进程(相当于代理进程),由它再向server进程或后台进程发出请求。执行结果也由Backend进程返回给用户进程。

 

image.png

接下篇:https://developer.aliyun.com/article/1223106?groupCode=polardbforpg

 

相关实践学习
使用PolarDB和ECS搭建门户网站
本场景主要介绍基于PolarDB和ECS实现搭建门户网站。
阿里云数据库产品家族及特性
阿里云智能数据库产品团队一直致力于不断健全产品体系,提升产品性能,打磨产品功能,从而帮助客户实现更加极致的弹性能力、具备更强的扩展能力、并利用云设施进一步降低企业成本。以云原生+分布式为核心技术抓手,打造以自研的在线事务型(OLTP)数据库Polar DB和在线分析型(OLAP)数据库Analytic DB为代表的新一代企业级云原生数据库产品体系, 结合NoSQL数据库、数据库生态工具、云原生智能化数据库管控平台,为阿里巴巴经济体以及各个行业的企业客户和开发者提供从公共云到混合云再到私有云的完整解决方案,提供基于云基础设施进行数据从处理、到存储、再到计算与分析的一体化解决方案。本节课带你了解阿里云数据库产品家族及特性。
相关文章
|
1月前
|
关系型数据库 MySQL 分布式数据库
零基础教你用云数据库PolarDB搭建企业网站,完成就送桌面收纳桶!
零基础教你用云数据库PolarDB搭建企业网站,完成就送桌面收纳桶,邀请好友完成更有机会获得​小米Watch S3、小米体重称​等诸多好礼!
零基础教你用云数据库PolarDB搭建企业网站,完成就送桌面收纳桶!
|
13天前
|
存储 SQL Apache
Apache Doris 开源最顶级基于MPP架构的高性能实时分析数据库
Apache Doris 是一个基于 MPP 架构的高性能实时分析数据库,以其极高的速度和易用性著称。它支持高并发点查询和复杂分析场景,适用于报表分析、即席查询、数据仓库和数据湖查询加速等。最新发布的 2.0.2 版本在性能、稳定性和多租户支持方面有显著提升。社区活跃,已广泛应用于电商、广告、用户行为分析等领域。
Apache Doris 开源最顶级基于MPP架构的高性能实时分析数据库
|
15天前
|
数据库
|
20天前
|
存储 关系型数据库 MySQL
MySQL vs. PostgreSQL:选择适合你的开源数据库
在众多开源数据库中,MySQL和PostgreSQL无疑是最受欢迎的两个。它们都有着强大的功能、广泛的社区支持和丰富的生态系统。然而,它们在设计理念、性能特点、功能特性等方面存在着显著的差异。本文将从这三个方面对MySQL和PostgreSQL进行比较,以帮助您选择更适合您需求的开源数据库。
80 4
|
28天前
|
存储 JSON Ubuntu
时序数据库 TDengine 支持集成开源的物联网平台 ThingsBoard
本文介绍了如何结合 Thingsboard 和 TDengine 实现设备管理和数据存储。Thingsboard 中的“设备配置”与 TDengine 中的超级表相对应,每个设备对应一个子表。通过创建设备配置和设备,实现数据的自动存储和管理。具体操作包括创建设备配置、添加设备、写入数据,并展示了车辆实时定位追踪和车队维护预警两个应用场景。
49 3
|
13天前
|
关系型数据库 分布式数据库 数据库
锦鲤附体 | PolarDB数据库创新设计赛,好礼不停!
锦鲤附体 | PolarDB数据库创新设计赛,好礼不停!
|
1月前
|
SQL JSON 关系型数据库
MySQL是一个广泛使用的开源关系型数据库管理系统,它有许多不同的版本
【10月更文挑战第3天】MySQL是一个广泛使用的开源关系型数据库管理系统,它有许多不同的版本
133 5
|
1月前
|
关系型数据库 分布式数据库 数据库
PolarDB 开源:推动数据库技术新变革
在数字化时代,数据成为核心资产,数据库的性能和可靠性至关重要。阿里云的PolarDB作为新一代云原生数据库,凭借卓越性能和创新技术脱颖而出。其开源不仅让开发者深入了解内部架构,还促进了数据库生态共建,提升了稳定性与可靠性。PolarDB采用云原生架构,支持快速弹性扩展和高并发访问,具备强大的事务处理能力及数据一致性保证,并且与多种应用无缝兼容。开源PolarDB为国内数据库产业注入新活力,打破国外垄断,推动国产数据库崛起,降低企业成本与风险。未来,PolarDB将在生态建设中持续壮大,助力企业数字化转型。
84 2
|
2月前
|
关系型数据库 分布式数据库 数据库
来!跟通义灵码一起参加PolarDB 数据库创新设计赛,突破传统,探索人机协作
无论你是数据库新手,还是技术大咖,通义灵码邀请你参加2024 年全国大学生计算机系统能力大赛 PolarDB 数据库创新设计赛(天池杯),新参赛模式启动,挑战极限!
109 11
|
2月前
|
存储 关系型数据库 分布式数据库
揭秘PolarDB:中国云原生数据库的超级英雄,如何颠覆传统数据存储?
在数字化时代,数据成为企业的核心资产,而云原生数据库则是推动企业转型的关键。PolarDB凭借其先进的存储计算分离架构,在性能、可靠性和易用性方面脱颖而出,成为国内领先的选择。它支持多种数据库引擎,提供多副本存储机制,并采用按量付费模式,有效降低管理和成本压力,助力企业实现高效、可靠的数字化转型。
67 1

热门文章

最新文章

相关产品

  • 云原生数据库 PolarDB