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

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

 

image.png

 

PolarDB由众多数据库组成,因此称为数据库集群,每个数据库下存放各自的对象,对象包括表、索引、视图、存储过程、序列等。

 

image.png

 

登录到数据库以后,可以通过\l查看数据库信息。

 

image.png

 

PolarDB提供了两种SQL语句,一种是标准的SQL语句,另一种是PSQL。PSQL使用l来代替select pg_database语句。可以通过\?查看PSQL提供的所有命令。

 

 

PolarDB管理对象时通过oid(对象标识符)进行管理,它与数据库物理结构的名字一一对应,数据库oid和堆表oid分别存储在pg_database和pg_class。

 

image.png

 

进行数据库访问时,PGDATA变量指定了整个数据库的基本位置。下面的base目录是所有数据库的副目录,其下的子目录都以数字命名,与每个数据库的OID对应。

 

image.png

 

比如查找当前数据库的物理位置,需要先找到PGDATA目录所在。

 

image.png

 

查看base目录,即可看到它以数字命名的子目录。

 

image.png

 

子目录名称与数据库创建目录的OID(上图)一致。

 

image.png

 

上图为PGDATA下不同目录和文件的作用。

 

pg_hba.conf用于控制实例的访问权限,可以在文件里定义哪一些主机可以访问哪一些数据库;postgresql.conf是PolarDB数据库的主要参数文件,postgresql.auto.conf是二进制的参数文件,两者可以结合使用。PolarDB代理启动时先读postgresql.conf文件,再读postgresql.auto.conf文件。

 

image.png

 

上图为数据库集群布局的主要文件和子目录。

 

image.png

 

数据库是base子目录下的子目录。

 

image.png

 

初始化时,表的OID与数据文件名字一致,但TRUNCATE、REINDEX等操作会造成不一致。

 

如上图所示,查询sampletbl表所在的数据文件。

 

image.png

 

首先,登录到sampledb。sampledb数据库的OID为32768。

 

image.png

 

到sampledb目录下查找文件32769,可以发现实际的数据并没有存放在该路径下。因为PolarDB将数据存放的位置做了分流。

 

 

真正的数据放在上图路径的32768子目录下。

 

image.png

 

PolarDB为了方便查找表的数据文件位置提供了查询函数,如上图。此处的file-dio为PolarDB提供的共享存储。

 

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

相关实践学习
使用PolarDB和ECS搭建门户网站
本场景主要介绍基于PolarDB和ECS实现搭建门户网站。
阿里云数据库产品家族及特性
阿里云智能数据库产品团队一直致力于不断健全产品体系,提升产品性能,打磨产品功能,从而帮助客户实现更加极致的弹性能力、具备更强的扩展能力、并利用云设施进一步降低企业成本。以云原生+分布式为核心技术抓手,打造以自研的在线事务型(OLTP)数据库Polar DB和在线分析型(OLAP)数据库Analytic DB为代表的新一代企业级云原生数据库产品体系, 结合NoSQL数据库、数据库生态工具、云原生智能化数据库管控平台,为阿里巴巴经济体以及各个行业的企业客户和开发者提供从公共云到混合云再到私有云的完整解决方案,提供基于云基础设施进行数据从处理、到存储、再到计算与分析的一体化解决方案。本节课带你了解阿里云数据库产品家族及特性。
相关文章
|
1月前
|
存储 NoSQL 关系型数据库
PolarDB开源数据库进阶课17 集成数据湖功能
本文介绍了如何在PolarDB数据库中接入pg_duckdb、pg_mooncake插件以支持数据湖功能, 可以读写对象存储的远程数据, 支持csv, parquet等格式, 支持delta等框架, 并显著提升OLAP性能。
59 1
|
25天前
|
Cloud Native 关系型数据库 分布式数据库
世界第一!阿里云PolarDB刷新全球数据库性能及性价比记录
世界第一!阿里云PolarDB刷新全球数据库性能及性价比记录
|
24天前
|
关系型数据库 分布式数据库 数据库
喜报|PolarDB开源社区荣获“2024数据库国内活跃开源项目”奖
喜报|PolarDB开源社区荣获“2024数据库国内活跃开源项目”奖
|
24天前
|
关系型数据库 分布式数据库 数据库
首届全国大学生计算机系统能力大赛PolarDB数据库创新设计赛(天池杯)圆满收官
首届全国大学生计算机系统能力大赛PolarDB数据库创新设计赛(天池杯)圆满收官
|
26天前
|
数据管理 关系型数据库 MySQL
数据管理服务DMS支持MySQL数据库的无锁结构变更
本文介绍了使用Sysbench准备2000万数据并进行全表字段更新的操作。通过DMS的无锁变更功能,可在不锁定表的情况下完成结构修改,避免了传统方法中可能产生的锁等待问题。具体步骤包括:准备数据、提交审批、执行变更及检查表结构,确保变更过程高效且不影响业务运行。
52 2
|
24天前
|
Cloud Native 关系型数据库 分布式数据库
世界第一!阿里云PolarDB刷新全球数据库性能及性价比记录
世界第一!阿里云PolarDB刷新全球数据库性能及性价比记录
|
26天前
|
Cloud Native 关系型数据库 分布式数据库
世界第一!阿里云PolarDB登顶全球数据库性能及性价比排行榜!
2月26日,阿里云PolarDB在2025开发者大会上登顶全球数据库性能及性价比排行榜。此次突破标志着中国基础软件取得里程碑成就,PolarDB凭借创新的云原生架构,成功应对全球最大规模并发交易峰值,在性能、可扩展性等方面领先全球。
|
1月前
|
存储 关系型数据库 分布式数据库
PolarDB开源数据库进阶课18 通过pg_bulkload适配pfs实现批量导入提速
本文介绍了如何修改 `pg_bulkload` 工具以适配 PolarDB 的 PFS(Polar File System),从而加速批量导入数据。实验环境依赖于 Docker 容器中的 loop 设备模拟共享存储。通过对 `writer_direct.c` 文件的修改,替换了一些标准文件操作接口为 PFS 对应接口,实现了对 PolarDB 15 版本的支持。测试结果显示,使用 `pg_bulkload` 导入 1000 万条数据的速度是 COPY 命令的三倍多。此外,文章还提供了详细的步骤和代码示例,帮助读者理解和实践这一过程。
45 0
|
1月前
|
存储 关系型数据库 分布式数据库
PolarDB开源数据库进阶课16 接入PostGIS全功能及应用举例
本文介绍了如何在PolarDB数据库中接入PostGIS插件全功能,实现地理空间数据处理。此外,文章还提供了使用PostGIS生成泰森多边形(Voronoi diagram)的具体示例,帮助用户理解其应用场景及操作方法。
42 0
|
5天前
|
关系型数据库 MySQL 数据库连接
docker拉取MySQL后数据库连接失败解决方案
通过以上方法,可以解决Docker中拉取MySQL镜像后数据库连接失败的常见问题。关键步骤包括确保容器正确启动、配置正确的环境变量、合理设置网络和权限,以及检查主机防火墙设置等。通过逐步排查,可以快速定位并解决连接问题,确保MySQL服务的正常使用。
110 82

相关产品

  • 云原生数据库 PolarDB