On this page
clusterdb
clusterdb —集群 PostgreSQL 数据库
Synopsis
clusterdb
[ connection-option
...] [ --verbose
| -v
] [ --table
| -t
table
] ... [ dbname
]
clusterdb
[ connection-option
...] [ --verbose
| -v
] --all
| -a
Description
clusterdb 是用于重新分配 PostgreSQL 数据库中的表的 Util。它查找以前已聚 Cluster 的表,然后将它们再次聚 Cluster 在最后使用的同一索引上。从未集群过的表不受影响。
clusterdb 是 SQL 命令CLUSTER的包装。通过该 Util 和通过其他访问服务器的方法对数据库数据库进行群集之间没有有效的区别。
Options
clusterdb 接受以下命令行参数:
-a
--all
- 集群所有数据库。
[-d] dbname
[--dbname=]dbname
- 指定要集群的数据库的名称。如果未指定此参数并且未使用
-a
(或--all
),则将从环境变量PGDATABASE
中读取数据库名称。如果未设置,则使用为连接指定的用户名。
- 指定要集群的数据库的名称。如果未指定此参数并且未使用
-e
--echo
- 回显 clusterdb 生成并发送到服务器的命令。
-q
--quiet
- 不显示进度消息。
-t table
--table=table
- 仅限群集
table
*。可以通过写入多个-t
开关来集群多个表。
- 仅限群集
-v
--verbose
- 在处理过程中打印详细信息。
-V
--version
- 打印 clusterdb 版本并退出。
-?
--help
- 显示有关 clusterdb 命令行参数的帮助,然后退出。
clusterdb 还接受以下命令行参数作为连接参数:
-h host
--host=host
- 指定运行服务器的计算机的主机名。如果该值以斜杠开头,则将其用作 Unix 域套接字的目录。
-p port
--port=port
- 指定服务器正在侦听连接的 TCP 端口或本地 Unix 域套接字文件 extensions。
-U username
--username=username
- 连接的用户名。
-w
--no-password
- 切勿发出密码提示。如果服务器要求密码验证,而其他方式(例如
.pgpass
文件)无法使用密码,则连接尝试将失败。该选项在没有用户 Importing 密码的批处理作业和脚本中很有用。
- 切勿发出密码提示。如果服务器要求密码验证,而其他方式(例如
-W
--password
- 强制 clusterdb 在连接数据库之前提示 Importing 密码。
此选项从不是必需的,因为如果服务器要求密码验证,则 clusterdb 会自动提示 Importing 密码。但是,clusterdb 将浪费连接尝试,因为它发现服务器需要密码。在某些情况下,值得 Importing-W
以避免额外的连接尝试。
--maintenance-db=dbname
- 指定要连接以发现还应集群的其他数据库的数据库名称。如果未指定,将使用
postgres
数据库,如果不存在,将使用template1
。
- 指定要连接以发现还应集群的其他数据库的数据库名称。如果未指定,将使用
Environment
PGDATABASE
PGHOST
PGPORT
PGUSER
- 默认连接参数
与大多数其他 PostgreSQLUtil 一样,该 Util 也使用 libpq 支持的环境变量(请参见Section 33.14)。
Diagnostics
万一遇到困难,请参见CLUSTER和psql以获取有关潜在问题和错误消息的讨论。数据库服务器必须在目标主机上运行。同样,libpq 前端库使用的任何默认连接设置和环境变量都将适用。
Examples
群集数据库test
:
$ clusterdb test
要将单个表foo
聚集到名为xyzzy
的数据库中:
$ clusterdb --table=foo xyzzy