PostgreSQL數據目錄結構

根目錄介紹

data
├── base                  # use to store database file(SELECT oid, datname FROM pg_database;)
├── global                # under global, all the filenode is hard-code(select oid,relname,relfilenode from pg_class where relfilenode=0 order by oid;)
├── pg_clog               # dir of transaction commit log
│   └── 0000
├── pg_commit_ts
├── pg_dynshmem
├── pg_hba.conf           # client authentication config file
├── pg_ident.conf         # user ident map file
├── pg_logical
│   ├── mappings
│   └── snapshots
├── pg_multixact
│   ├── members
│   │   └── 0000
│   └── offsets
│       └── 0000
├── pg_notify
│   └── 0000
├── pg_replslot
├── pg_serial
├── pg_snapshots         # dir of snapshot file
├── pg_stat
├── pg_stat_tmp          # dir of tmp stat file
│   ├── db_0.stat
│   ├── db_12407.stat
│   ├── db_16384.stat
│   └── global.stat
├── pg_subtrans
│   └── 0000
├── pg_tblspc
├── pg_twophase
├── PG_VERSION           # version file
├── pg_xlog              # dir of xlog file
│   ├── 000000010000000000000001
│   └── archive_status   # status info of xlog archive
├── postgresql.auto.conf
├── postgresql.conf      # config file of postmaster progress
├── postmaster.opts
└── postmaster.pid       # pid file of postmaster progress

global目錄介紹

global名如其意,存放的文件用于存儲全局的系統(tǒng)表信息和全局控制信息肛度。

global下有四種文件:

  1. pg_control
    用于存儲全局控制信息
  2. pg_filenode.map
    用于將當前目錄下系統(tǒng)表的OID與具體文件名進行硬編碼映射(每個用戶創(chuàng)建的數據庫目錄下也有同名文件)傻唾。
  3. pg_internal.init
    用于緩存系統(tǒng)表,加快系統(tǒng)表讀取速度(每個用戶創(chuàng)建的數據庫目錄下也有同名文件)承耿。
  4. 全局系統(tǒng)表文件
    數字命名的文件冠骄,用于存儲系統(tǒng)表的內容。它們在pg_class里的relfilenode都為0加袋,是靠pg_filenode.map將OID與文件硬編碼映射凛辣。(注:不是所有的系統(tǒng)表的relfilenode都為0)
data
├── global                # under global, all the filenode is hard-code(select oid,relname,relfilenode from pg_class where relfilenode=0 order by oid;)
│   ├── 1136              # pg_pltemplate
│   ├── 1137              # pg_pltemplate_name_index
│   ├── 1213              # pg_tablespace
│   ├── 1214              # pg_shdepend
│   ├── 1232              # pg_shdepend_depender_index
│   ├── 1233              # pg_shdepend_reference_index
│   ├── 1260              # pg_authid
│   ├── 1261              # pg_auth_members
│   ├── 1262              # pg_database
│   ├── 2396              # pg_shdescription
│   ├── 2397              # pg_shdescription_o_c_index
│   ├── 2671              # pg_database_datname_index
│   ├── 2672              # pg_database_oid_index
│   ├── 2676              # pg_authid_rolname_index
│   ├── 2677              # pg_authid_oid_index
│   ├── 2694              # pg_auth_members_role_member_index
│   ├── 2695              # pg_auth_members_member_role_index
│   ├── 2697              # pg_tablespace_oid_index
│   ├── 2698              # pg_tablespace_spcname_index
│   ├── 2846              # pg_toast_2396
│   ├── 2847              # pg_toast_2396_index
│   ├── 2964              # pg_db_role_setting
│   ├── 2965              # pg_db_role_setting_databaseid_rol_index
│   ├── 2966              # pg_toast_2964
│   ├── 2967              # pg_toast_2964_index
│   ├── 3592              # pg_shseclabel
│   ├── 3593              # pg_shseclabel_object_index
│   ├── 4060              # pg_toast_3592x
│   ├── 4061              # pg_toast_3592_index
│   ├── 6000              # pg_replication_origin
│   ├── 6001              # pg_replication_origin_roiident_index
│   ├── 6002              # pg_replication_origin_roname_index
│   ├── pg_control        # global control file, use pgcheck -pc to see it.
│   ├── pg_filenode.map   # system table (oid -> filenode) mapping file, use pgcheck -pm to see it.
│   └── pg_internal.init  # system table cache file, use pgcheck -pr to see it.

base目錄介紹

base目錄用于存放數據庫的所有實體文件。例如职烧,我們創(chuàng)建的第一個庫testdb的OID為16384扁誓,那么在data/base下就會產生一個名為16384的目錄防泵,用于存儲testdb的數據文件。

testdb=# select oid,datname from pg_database;
  oid  |  datname
-------+-----------
 12407 | postgres
 16384 | testdb
     1 | template1
 12406 | template0
(4 rows)

base目錄結構

data
├── base                  # use to store database file(SELECT oid, datname FROM pg_database;)
│   ├── 1                 # template database
│   ├── 12406             # template0 database
│   ├── 12407             # postgres database
│   └── 16384             # testdb, first user database
│   │   ├── 3600
│   │   ├── 3600_fsm
│   │   ├── 3600_vm
│   │   ├── 16385
│   │   ├── pg_filenode.map
│   │   ├── pg_internal.init
│   │   └── PG_VERSION
  1. pg_filenode.map 是pg_class里relfilenode為0的系統(tǒng)表蝗敢,OID與文件的硬編碼映射择克。
  2. pg_internal.init 是系統(tǒng)表的cache文件,用于加快讀取前普。默認不存在,查詢系統(tǒng)表后自動產生壹堰。
  3. PG_VERSION 是當前數據庫數據格式對應的版本號
  4. 其它文件是需要到pg_class里根據OID查到對應的relfilenode來與文件名匹配的拭卿。
    例如:tab1的relfilenode是16385,那么16385這個文件就是tab1的數據文件
    testdb=# select oid,relfilenode,relname from pg_class where relname='tab1';
      oid  | relfilenode | relname
    -------+-------------+---------
     16385 |       16385 | tab1
    (1 row)
  1. 空閑空間映射表
    名字以_fsm結尾的文件是數據文件對應的FSM(free space map)文件贱纠,用map方式來標識哪些block是空閑的峻厚。用一個Byte而不是bit來標識一個block。對于一個有N個字節(jié)的block谆焊,它在_fsm文件中第blknum個字節(jié)中記錄的值是(31+N)/32惠桃。通過這種方式標識一個block空閑字節(jié)數。FSM中不是簡單的數組辖试,而是一個三層的樹形結構辜王。FSM文件是在需要用到它時才自動產生的。
  2. 可見性映射表文件
    名字以_vm結尾的文件是數據文件對應的VM(visibility map)罐孝。PostgreSQL中在做多版本并發(fā)控制時是通過在元組頭上標識“已無效”來實現(xiàn)刪除或更新的呐馆,最后通過VACUUM功能來清理無效數據回收空閑空間。在做VACUUM時就使用VM開快速查找包含無效元組的block莲兢。VM僅是個簡單的bitmap,一個bit對應一個block汹来。

注:系統(tǒng)表分為全局系統(tǒng)表和庫級系統(tǒng)表。
全局系統(tǒng)表位于global下改艇,例如:pg_database,pg_tablespace,pg_auth_members這種存儲系統(tǒng)級對象的表收班。
庫級系統(tǒng)表位于數據庫目錄下,例如:pg_type,pg_proc,pg_attribute這種存儲庫級對象的表谒兄。
值得注意的是pg_class位于庫級目錄的里摔桦,但也包含全局系統(tǒng)表信息,因此研發(fā)或運維人員在改動全局系統(tǒng)表信息時需要注意舵变。

表空間目錄介紹

testdb=# select oid,* from pg_tablespace;
  oid  |  spcname   | spcowner | spcacl | spcoptions
-------+------------+----------+--------+------------
  1663 | pg_default |       10 |        |
  1664 | pg_global  |       10 |        |
 49162 | dbspace    |       10 |        |
(3 rows)

每一個Oid都在data/pg_tblspc下對應一個名為Oid的軟鏈接文件酣溃,指向真正的space目錄。

 tree ../data/pg_tblspc/
../data/pg_tblspc/
└── 49162 -> /home/postgres/postgresql-9.6.6/postgres/data/dbspace

在space目錄是如何組織的呢纪隙?

testdb=# create table tab3(a int) tablespace dbspace;
CREATE TABLE

testdb=# select oid,relname,relfilenode from pg_class where relname='tab3';
  oid  | relname | relfilenode
-------+---------+-------------
 57351 | tab3    |       57351
(1 row)

 tree ../data/pg_tblspc/49162
../data/pg_tblspc/49162
└── PG_9.6_201608131
    └── 16384
        └── 57351
最后編輯于
?著作權歸作者所有,轉載或內容合作請聯(lián)系作者
禁止轉載赊豌,如需轉載請通過簡信或評論聯(lián)系作者。
  • 序言:七十年代末绵咱,一起剝皮案震驚了整個濱河市碘饼,隨后出現(xiàn)的幾起案子熙兔,更是在濱河造成了極大的恐慌,老刑警劉巖艾恼,帶你破解...
    沈念sama閱讀 210,978評論 6 490
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件住涉,死亡現(xiàn)場離奇詭異,居然都是意外死亡钠绍,警方通過查閱死者的電腦和手機舆声,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 89,954評論 2 384
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來柳爽,“玉大人媳握,你說我怎么就攤上這事×赘” “怎么了蛾找?”我有些...
    開封第一講書人閱讀 156,623評論 0 345
  • 文/不壞的土叔 我叫張陵迈喉,是天一觀的道長剃根。 經常有香客問我,道長途乃,這世上最難降的妖魔是什么俩功? 我笑而不...
    開封第一講書人閱讀 56,324評論 1 282
  • 正文 為了忘掉前任幻枉,我火速辦了婚禮,結果婚禮上诡蜓,老公的妹妹穿的比我還像新娘展辞。我一直安慰自己,他們只是感情好万牺,可當我...
    茶點故事閱讀 65,390評論 5 384
  • 文/花漫 我一把揭開白布罗珍。 她就那樣靜靜地躺著,像睡著了一般脚粟。 火紅的嫁衣襯著肌膚如雪覆旱。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 49,741評論 1 289
  • 那天核无,我揣著相機與錄音扣唱,去河邊找鬼。 笑死团南,一個胖子當著我的面吹牛噪沙,可吹牛的內容都是我干的。 我是一名探鬼主播吐根,決...
    沈念sama閱讀 38,892評論 3 405
  • 文/蒼蘭香墨 我猛地睜開眼正歼,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了拷橘?” 一聲冷哼從身側響起局义,我...
    開封第一講書人閱讀 37,655評論 0 266
  • 序言:老撾萬榮一對情侶失蹤喜爷,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后萄唇,有當地人在樹林里發(fā)現(xiàn)了一具尸體檩帐,經...
    沈念sama閱讀 44,104評論 1 303
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 36,451評論 2 325
  • 正文 我和宋清朗相戀三年另萤,在試婚紗的時候發(fā)現(xiàn)自己被綠了湃密。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 38,569評論 1 340
  • 序言:一個原本活蹦亂跳的男人離奇死亡四敞,死狀恐怖勾缭,靈堂內的尸體忽然破棺而出,到底是詐尸還是另有隱情目养,我是刑警寧澤,帶...
    沈念sama閱讀 34,254評論 4 328
  • 正文 年R本政府宣布毒嫡,位于F島的核電站癌蚁,受9級特大地震影響,放射性物質發(fā)生泄漏兜畸。R本人自食惡果不足惜努释,卻給世界環(huán)境...
    茶點故事閱讀 39,834評論 3 312
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望咬摇。 院中可真熱鬧伐蒂,春花似錦、人聲如沸肛鹏。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,725評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽在扰。三九已至缕减,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間芒珠,已是汗流浹背桥狡。 一陣腳步聲響...
    開封第一講書人閱讀 31,950評論 1 264
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留皱卓,地道東北人裹芝。 一個月前我還...
    沈念sama閱讀 46,260評論 2 360
  • 正文 我出身青樓,卻偏偏與公主長得像娜汁,于是被迫代替她去往敵國和親嫂易。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 43,446評論 2 348

推薦閱讀更多精彩內容

  • 1. Java基礎部分 基礎部分的順序:基本語法掐禁,類相關的語法炬搭,內部類的語法蜈漓,繼承相關的語法,異常的語法宫盔,線程的語...
    子非魚_t_閱讀 31,597評論 18 399
  • 第四章 數據字典詳解 [TOC] gp 是基于 PostgreSQL開發(fā)的融虽,大部分數據字典是一樣的;gp 也有自動...
    涼秋_不見春暖閱讀 8,102評論 0 3
  • Spring Cloud為開發(fā)人員提供了快速構建分布式系統(tǒng)中一些常見模式的工具(例如配置管理灼芭,服務發(fā)現(xiàn)有额,斷路器,智...
    卡卡羅2017閱讀 134,628評論 18 139
  • 我們每天都花大量的時間看外界彼绷,看別人巍佑,但是用來審視自己的時間太少了,很多時候寄悯,一件事在我們手上做得七扭八歪問題根本...
    小際閱讀 2,276評論 0 0
  • 空夜深靜長步漫萤衰,曲幽羊腸松林傍。偶有意歇望天寰 猜旬,折路取道尋清歡脆栋。柵欄停外人何在?伏案燭臺紙筆亂洒擦。
    朝辭暮返行多遠閱讀 193評論 2 1