Oid2name

From PostgreSQL 中文维基, PostgreSQL 中文站, PostgreSQL 中国社区, PostgreSQL Chinese community

Jump to: navigation, search

[编辑] oid2name

目录

oid2name 是一个帮助管理员检查 PostgreSQL 使用的文件结构的工具程序。要使用这个工具,你必须熟悉数据库文件结构,在第53章描述。

注意: 名称 "oid2name" 是历史原因,因为大多数使用它的时候,你实际上要考虑的是表的 filenode 号(也即在数据库目录可见的文件名)。请注意你要理解表的 OID 和表的 filenodes 的区别!

[编辑] 概述

oid2name 连接到一个目标数据库,然后抽取 OID,filenode 和/或表名称信息。你还可以用它显示数据库的 OID 或者表空间的 OID。这个程序由一堆命令行参数控制,如表 F-13 所示。

表 F-13 oid2name 开关
开关 描述
-f filenode 为 filenode 为 filenode 的表显示信息
-t tablename_pattern 为匹配 tablename_pattern 的表显示信息
-s 显示表空间 OID
-S 包括系统对象(那些在 information_schema,pg_toast 和 pg_catalog 模式里的)
-i 在列表里包含索引和序列
-x 给显示的每个对象都显示更多信息:表空间名称,模式名称和 OID
-q 省略信息头(omit headers (useful for scripting)
-d database 要连接的数据库
-H host 数据库服务器的主机
-p port 数据库服务器的端口
-U username 用于连接的用户名

要显示特定的表,用 -o,-f 和/或 -t 选取要显示的表。-o 接收一个 OID,-f 接收一个 filenode,而 -t 接受一个 tablename(实际上是一个 LIKE 模式,这样你就可以用类似 foo% 这样的东西)。你可以使用任意数目的开关,列出来的列表将包含任意开关匹配的所有对象。但是要注意这些开关只能显示 -d 给出的数据库中的对象。

如果你不给出 -o,-f 或者 -t 中任何一个,但是给出了 -d,那么它会列出所有 -d 指定的数据库里面的所有表。在这个模式下,-S 和 -i 开关控制列出的东西。

如果你也不给出 -d,那么它会显示一个数据库 OID 的列表。你也可以给 -s 列出表空间的列表。

[编辑] 例子

$ # 这个数据库里有啥?
$ oid2name
All databases:
    Oid  Database Name  Tablespace
----------------------------------
  17228       alvherre  pg_default
  17255     regression  pg_default
  17227      template0  pg_default
      1      template1  pg_default

$ oid2name -s
All tablespaces:
     Oid  Tablespace Name
-------------------------
    1663       pg_default
    1664        pg_global
  155151         fastdisk
  155152          bigdisk

$ # OK,我们看看数据库 alvherre
$ cd $PGDATA/base/17228

$ # 获取缺省表空间里的头 10 个数据库对象,以大小排序
$ ls -lS * | head -10
-rw-------  1 alvherre alvherre 136536064 sep 14 09:51 155173
-rw-------  1 alvherre alvherre  17965056 sep 14 09:51 1155291
-rw-------  1 alvherre alvherre   1204224 sep 14 09:51 16717
-rw-------  1 alvherre alvherre    581632 sep  6 17:51 1255
-rw-------  1 alvherre alvherre    237568 sep 14 09:50 16674
-rw-------  1 alvherre alvherre    212992 sep 14 09:51 1249
-rw-------  1 alvherre alvherre    204800 sep 14 09:51 16684
-rw-------  1 alvherre alvherre    196608 sep 14 09:50 16700
-rw-------  1 alvherre alvherre    163840 sep 14 09:50 16699
-rw-------  1 alvherre alvherre    122880 sep  6 17:51 16751

$ # 我想知道文件 155173 是啥
$ oid2name -d alvherre -f 155173
From database "alvherre":
  Filenode  Table Name
----------------------
    155173    accounts

$ # 可以一次要求列出多个对象
$ oid2name -d alvherre -f 155173 -f 1155291
From database "alvherre":
  Filenode     Table Name
-------------------------
    155173       accounts
   1155291  accounts_pkey

$ # 你可以混合选项,然后用 -x 获取更多细节
$ oid2name -d alvherre -t accounts -f 1155291 -x
From database "alvherre":
  Filenode     Table Name      Oid  Schema  Tablespace
------------------------------------------------------
    155173       accounts   155173  public  pg_default
   1155291  accounts_pkey  1155291  public  pg_default

$ # 为每个数据库对象显示磁盘空间
$ du [0-9]* |
> while read SIZE FILENODE
> do
>   echo "$SIZE       `oid2name -q -d alvherre -i -f $FILENODE`"
> done
16            1155287  branches_pkey
16            1155289  tellers_pkey
17561            1155291  accounts_pkey
...

$ # 一样,但是用大小排序
$ du [0-9]* | sort -rn | while read SIZE FN
> do
>   echo "$SIZE   `oid2name -q -d alvherre -f $FN`"
> done
133466             155173    accounts
17561            1155291  accounts_pkey
1177              16717  pg_proc_proname_args_nsp_index
...

$ # 如果你想知道表空间里有啥,进入 pg_tblspc 目录
$ cd $PGDATA/pg_tblspc
$ oid2name -s
All tablespaces:
     Oid  Tablespace Name
-------------------------
    1663       pg_default
    1664        pg_global
  155151         fastdisk
  155152          bigdisk

$ # 在表空间 "fastdisk" 里的对象是哪个数据库的?
$ ls -d 155151/*
155151/17228/  155151/PG_VERSION

$ # 哦,什么是数据库 17228?
$ oid2name
All databases:
    Oid  Database Name  Tablespace
----------------------------------
  17228       alvherre  pg_default
  17255     regression  pg_default
  17227      template0  pg_default
      1      template1  pg_default

$ # 让我们看看数据库有啥对象在这个表空间里。
$ cd 155151/17228
$ ls -l
total 0
-rw-------  1 postgres postgres 0 sep 13 23:20 155156

$ # OK,这是一个相当小的表 ... 它是哪个?
$ oid2name -d alvherre -f 155156
From database "alvherre":
  Filenode  Table Name
----------------------
    155156         foo

[编辑] 限制

oid2name 要求一个系统表完好的正在运行的数据库。所以它的唯一的限制就是无法用于恢复灾难崩溃后的数据库。

[编辑] 作者

B. Palmer <bpalmer@crimelabs.net>

Personal tools