19.2. 文件位置
除了已经提到过的postgresql.conf文件之外,PostgreSQL还使用另外两个手工编辑的配置文件,它们控制客户端认证(其使用在Chapter 20中讨论)。默认情况下,所有三个配置文件都存放在数据库集簇的数据目录中。 本节描述的参数允许配置文件放在别的地方(这么做可以简化管理,特别是如果配置文件被独立放置,可以很容易保证它得到恰当的备份)。
代码语言:javascript复制data_directory (string)
指定用于数据存储的目录。这个选项只能在服务器启动时设置。
代码语言:javascript复制config_file (string)
指定主服务器配置文件(通常叫postgresql.conf)。这个参数只能在postgres命令行上设置。
代码语言:javascript复制hba_file (string)
指定基于主机认证配置文件(通常叫pg_hba.conf)。这个参数只能在服务器启动的时候设置。
代码语言:javascript复制ident_file (string)
指定用于用户名称映射的配置文件(通常叫pg_ident.conf)。这个参数只能在服务器启动的时候设置。另见Section 20.2。
代码语言:javascript复制external_pid_file (string)
指定可被服务器创建的用于管理程序的额外进程 ID(PID)文件。这个参数只能在服务器启动的时候设置。
在默认安装中不会显式设置以上参数。相反,命令行参数-D或者环境变量PGDATA指定数据目录,并且上述配置文件都能在数据目录中找到。
如果你想把配置文件放在别的地方而不是数据目录中,那么postgres -D
命令行选项或者环境变量PGDATA必须指向包含配置文件的目录,并且postgresql.conf
中(或者命令行上)的data_directory参数必须显示数据目录实际存放的地方。
请注意,data_directory将覆盖-D和PGDATA指定的数据目录位置,但是不覆盖配置文件的位置。如果你愿意,可以使用选项config_file、hba_file和/或ident_file单独指定配置文件名称和位置。config_file只能在postgres命令行上指定,但是其他文件可以在主配置文件中设置。如果所有三个参数外加data_directory
被显式地设置,则不必指定-D或PGDATA。
在设置任何这些参数时,相对路径将被解释为相对于postgres启动路径的路径。