欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

postgres表空间和os的文件的对应关系

程序员文章站 2022-05-21 12:19:00
postgres 自带了两个表空间,pg_default, pg_global表空间pg_default是用来存储系统目录对象、用户表、用户表index、和临时表、临时表index、内部临时表的默认空间。对应存储目录PADATA/base/表空间pgglobal用来存放系统字典表;对应存储目录PADATA/base/表空间pg_global用来存放系统字典表;对应存储目录PADATA/base/表空间pgg​lobal用来存放系统字典表;对应存储目录PADATA/global/pgsql 中表空间/数...

postgres 自带了两个表空间,pg_default, pg_global
表空间pg_default是用来存储系统目录对象、用户表、用户表index、和临时表、临时表index、内部临时表的默认空间。对应存储目录PADATA/base/pgglobalPADATA/base/ 表空间pg_global用来存放系统字典表;对应存储目录PADATA/global/

pgsql 中表空间/数据库/模式 的关系:

  1. 表空间是物理结构,同一表空间下可以有多个数据库
  2. 数据库是逻辑结构,是表/索引/视图/存储过程的集合,一个数据库下可以有多个schema
  3. 模式是逻辑结构,是对数据库的逻辑划分

数据库以oid方式在base目录下存放。

postgres=# select * from pg_tablespace;
 oid  |  spcname   | spcowner | spcacl | spcoptions 
------+------------+----------+--------+------------
 1663 | pg_default |       10 |        | 
 1664 | pg_global  |       10 |        | 
(2 rows)

root@scutech:/var/lib/postgresql/12/main# du -h base
7.8M	base/1
11M	base/16386
11M	base/13432
7.7M	base/13431
7.8M	base/16385
45M	base
root@scutech:/var/lib/postgresql/12/main# 
postgres=# select oid, datname, datlastsysoid, dattablespace from pg_catalog.pg_database order by 1,2;
  oid  |  datname  | datlastsysoid | dattablespace 
-------+-----------+---------------+---------------
     1 | template1 |         13431 |          1663
 13431 | template0 |         13431 |          1663
 13432 | postgres  |         13431 |          1663
 16385 | test      |         13431 |          1663
 16386 | mydb      |         13431 |          1663
(5 rows)

本文地址:https://blog.csdn.net/weixin_43424368/article/details/107315277