oid2name <refpurpose>resolve OIDs and file nodes in a <productname>PostgreSQL</productname> data directory</refpurpose> — OIDとPostgreSQLデータディレクトリ内のファイルノードを解決する
oid2name
[option
...]
<application>oid2name</application> is a utility program that helps administrators to examine the file structure used by PostgreSQL. To make use of it, you need to be familiar with the database file structure, which is described in <xref linkend="storage"/>. oid2nameは、管理者がPostgreSQLで使用されるファイル構造を確認することを補助するユーティリティプログラムです。 使用できるようになるためには、第65章で説明されるデータベースファイル構造についての知識が必要です。
The name <quote>oid2name</quote> is historical, and is actually rather misleading, since most of the time when you use it, you will really be concerned with tables' filenode numbers (which are the file names visible in the database directories). Be sure you understand the difference between table OIDs and table filenodes! 「oid2name」という名前は歴史的なものであり、これを使用する場合のほとんどでは、本当はテーブルのファイルノード番号(これはデータベースディレクトリ内で可視なファイル名)が関係しますので、実際誤解されやすいものです。 テーブルのOIDとテーブルファイルノードの違いを確実に理解してください。
<application>oid2name</application> connects to a target database and extracts OID, filenode, and/or table name information. You can also have it show database OIDs or tablespace OIDs. oid2nameは対象データベースに接続し、OID、ファイルノード、テーブル名情報を抽出します。 また、データベースOIDまたはテーブル空間OIDを示すようにさせることもできます。
<application>oid2name</application> accepts the following command-line arguments: oid2nameは以下のコマンドライン引数を受け付けます。
-f filenode
--filenode=filenode
filenode
というファイルノードを持つテーブルの情報を表示します。
-i
--indexes
一覧にインデックスおよびシーケンスを含めます。
-o oid
--oid=oid
oid
というOIDを持つテーブルの情報を表示します。
-q
--quiet
ヘッダを省略します。(スクリプト処理に適しています)
-s
--tablespaces
テーブル空間OIDを表示します。
-S
--system-objects
システムオブジェクト(information_schema
、pg_toast
、pg_catalog
スキーマ内に存在するもの)を含めます。
-t tablename_pattern
--table=tablename_pattern
tablename_pattern
に一致するテーブル(複数可)の情報を表示します。
-V
--version
Print the <application>oid2name</application> version and exit. oid2nameのバージョンを表示し、終了します。
-x
--extended
表示対象の各オブジェクトに関してさらに情報を表示します。テーブル空間名、スキーマ名、OID。
-?
--help
Show help about <application>oid2name</application> command line arguments, and exit. oid2nameのコマンドライン引数の説明を表示し、終了します。
<application>oid2name</application> also accepts the following command-line arguments for connection parameters: またoid2nameは以下の接続用のパラメータに関するコマンドライン引数を受け付けます。
-d database
--dbname=database
接続データベース。
-h host
--host=host
データベースサーバのホスト。
-H host
データベースサーバのホスト。このパラメータの使用はPostgreSQL 12以降で廃止予定です。
-p port
--port=port
データベースサーバのポート。
-U username
--username=username
接続ユーザ名。
To display specific tables, select which tables to show by
using <option>-o</option>, <option>-f</option> and/or <option>-t</option>.
<option>-o</option> takes an OID,
<option>-f</option> takes a filenode,
and <option>-t</option> takes a table name (actually, it's a <literal>LIKE</literal>
pattern, so you can use things like <literal>foo%</literal>).
You can use as many
of these options as you like, and the listing will include all objects
matched by any of the options. But note that these options can only
show objects in the database given by <option>-d</option>.
特定のテーブルを表示するために、-o
、-f
、-t
を使用して表示するテーブルを選択してください。
-o
はOIDを、-f
はファイルノードを、-t
はテーブル名(実際はLIKE
パターンです。ですのでfoo%
などが使用できます)を引数として取ります。
これらのオプションを必要なだけ使用することができます。
一覧には、オプションのいずれかで一致したオブジェクトがすべて含まれます。
しかしこれらのオプションでは、-d
で指定したデータベース内に存在するオブジェクトしか表示しないことに注意してください。
If you don't give any of <option>-o</option>, <option>-f</option> or <option>-t</option>,
but do give <option>-d</option>, it will list all tables in the database
named by <option>-d</option>. In this mode, the <option>-S</option> and
<option>-i</option> options control what gets listed.
-o
、-f
、-t
のいずれも指定せずに-d
を指定した場合、-d
で指定したデータベース上のすべてのテーブルを列挙します。
このモードでは、-S
および-i
スイッチが何を列挙するかを制御します。
If you don't give <option>-d</option> either, it will show a listing of database
OIDs. Alternatively you can give <option>-s</option> to get a tablespace
listing.
-d
も指定しなかった場合、データベースOIDの一覧を示します。
他にも-s
を指定してテーブル空間の一覧を得ることもできます。
PGHOST
PGPORT
PGUSER
Default connection parameters. デフォルトの接続パラメータ。
This utility, like most other <productname>PostgreSQL</productname> utilities, also uses the environment variables supported by <application>libpq</application> (see <xref linkend="libpq-envars"/>). このユーティリティは、他のほとんどのPostgreSQLユーティリティと同様、libpqがサポートする環境変数(32.15参照)も使います。
The environment variable <envar>PG_COLOR</envar> specifies whether to use
color in diagnostic messages. Possible values are
<literal>always</literal>, <literal>auto</literal> and
<literal>never</literal>.
環境変数PG_COLOR
は診断メッセージで色を使うかどうかを指定します。
指定可能な値はalways
、auto
、never
です。
<application>oid2name</application> requires a running database server with non-corrupt system catalogs. It is therefore of only limited use for recovering from catastrophic database corruption situations. oid2nameは破損のないシステムカタログで実行中のデータベースサーバが必要です。 したがって、破滅的にデータベースが破損したような状況からの復旧には限定的にしか役に立ちません。
$ # 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 $ # さて、データベースalvherreの中を見てみよう $ cd $PGDATA/base/17228 $ # get top 10 db objects in the default tablespace, ordered by size $ # デフォルトテーブル空間のデータベースオブジェクトを大きさの順に上位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 $ # What file is 155173? $ # 155173は何のファイルだろう $ oid2name -d alvherre -f 155173 From database "alvherre": Filenode Table Name ---------------------- 155173 accounts $ # you can ask for more than one object $ # 2つ以上のオブジェクトについて問い合わせることもできる $ 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 $ # オプションを複数指定することもできて、-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 $ # テーブル空間に何があるのか見たければ、pg_tblspcディレクトリを使う $ 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"? $ # テーブル空間"fastdisk"にはどのデータベースのオブジェクトがあるのだろうか $ ls -d 155151/* 155151/17228/ 155151/PG_VERSION $ # Oh, what was database 17228 again? $ # おや、データベース17228がまた出てきた $ 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