Postgresql 中文操作指南
Description
oid2name 是一个实用程序,帮助管理员检查 PostgreSQL 使用的文件结构。要使用它,您需要熟悉数据库文件结构,其中在 Chapter 73 中进行了描述。
Options
oid2name 接受以下命令行参数:
-
-f _filenode—filenode=_filenode
-
显示具有 filenode filenode 的表的 info。
-
-
-i_—indexes_
-
在列表中包含索引和序列。
-
-
-o _oid—oid=_oid
-
显示具有 OID oid 的表的 info。
-
-
-q_—quiet_
-
省略标题(对脚本编制有用)。
-
-
-s_—tablespaces_
-
show tablespace OIDs.
-
-
-S_—system-objects_
-
包括系统对象( information_schema 、 pg_toast 和 pg_catalog 架构中的对象)。
-
-
-t _tablename_pattern—table=_tablename_pattern
-
显示与 tablename_pattern 匹配的表的信息。
-
-
-V_—version_
-
打印 oid2name 版本并退出。
-
-
-x_—extended_
-
显示每个显示对象的信息:表空间名称、架构名称和 OID。
-
-
-?_—help_
-
显示关于 oid2name 命令行参数的帮助,然后退出。
-
oid2name 还接受下列连接参数的命令行参数:
-
-d _database—dbname=_database
-
database to connect to.
-
-
-h _host—host=_host
-
database server’s host.
-
-
-H _host_
-
数据库服务器的主机。从 PostgreSQL 12 起,可使用此参数。
-
-
-p _port—port=_port
-
database server’s port.
-
-
-U _username—username=_username
-
用于连接的用户名。
-
要显示特定表,请使用 -o 、 -f 和/或 -t 选择要显示的表。 -o 接受一个 OID, -f 接受一个文件节点, -t 接受一个表名(实际上,它是一个 LIKE 模式,因此您可以使用 foo% 等内容)。您可以使用尽可能多的这些选项,并且列表将包含由任何选项匹配的所有对象。但请注意,这些选项只能显示 -d 给出的数据库中的对象。
如果您未提供任何 -o 、 -f 或 -t ,但提供了 -d ,它将列出 -d 命名的数据库中的所有表。在此模式中, -S 和 -i 选项控制显示内容。
如果您没有提供 -d ,它将显示数据库 OID 的列表。或者,您可以提供 -s 来获取表空间列表。
Environment
-
PGHOST_PGPORT_PGUSER
-
Default connection parameters.
-
此实用程序与大多数其他 PostgreSQL 实用程序一样,还使用 libpq 支持的环境变量(请参阅 Section 34.15 )。
环境变量 PG_COLOR 指定是否在诊断消息中使用颜色。可能的值是 always 、 auto 和 never 。
Examples
$ # what's in this database server, anyway?
$ 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, let's look into database alvherre
$ cd $PGDATA/base/17228
$ # get top 10 db objects in the default tablespace, ordered by size
$ 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
$ # I wonder what file 155173 is ...
$ oid2name -d alvherre -f 155173
From database "alvherre":
Filenode Table Name
----------------------
155173 accounts
$ # you can ask for more than one object
$ oid2name -d alvherre -f 155173 -f 1155291
From database "alvherre":
Filenode Table Name
-------------------------
155173 accounts
1155291 accounts_pkey
$ # you can mix the options, and get more details with -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
$ # show disk space for every db object
$ 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
...
$ # same, but sort by size
$ 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
...
$ # If you want to see what's in tablespaces, use the pg_tblspc directory
$ cd $PGDATA/pg_tblspc
$ oid2name -s
All tablespaces:
Oid Tablespace Name
-------------------------
1663 pg_default
1664 pg_global
155151 fastdisk
155152 bigdisk
$ # what databases have objects in tablespace "fastdisk"?
$ ls -d 155151/*
155151/17228/ 155151/PG_VERSION
$ # Oh, what was database 17228 again?
$ oid2name
All databases:
Oid Database Name Tablespace
----------------------------------
17228 alvherre pg_default
17255 regression pg_default
17227 template0 pg_default
1 template1 pg_default
$ # Let's see what objects does this database have in the tablespace.
$ cd 155151/17228
$ ls -l
total 0
-rw------- 1 postgres postgres 0 sep 13 23:20 155156
$ # OK, this is a pretty small table ... but which one is it?
$ oid2name -d alvherre -f 155156
From database "alvherre":
Filenode Table Name
----------------------
155156 foo