连接服务文件允许将 libpq 连接参数与单个服务名称关联。然后,可以在 libpq 连接字符串中指定该服务名称,并使用关联的设置。这允许修改连接参数,而无需重新编译使用 libpq 的应用程序。还可以使用 PGSERVICE
环境变量指定服务名称。
服务名称可以在每个用户的服务文件或系统范围的文件中定义。如果用户文件和系统文件中存在相同的服务名称,则用户文件优先。默认情况下,每个用户的服务文件名为 ~/.pg_service.conf
。在 Microsoft Windows 上,它名为 %APPDATA%\postgresql\.pg_service.conf
(其中 %APPDATA%
指的是用户配置文件中的应用程序数据子目录)。可以通过设置环境变量 PGSERVICEFILE
来指定不同的文件名。系统范围的文件名为 pg_service.conf
。默认情况下,它在 PostgreSQL 安装的 etc
目录中搜索(使用 pg_config --sysconfdir
精确识别此目录)。可以通过设置环境变量 PGSYSCONFDIR
来指定另一个目录,但不能指定不同的文件名。
这两个服务文件都使用 “INI 文件” 格式,其中节名称是服务名称,参数是连接参数;有关列表,请参阅 第 32.1.2 节。例如
# comment [mydb] host=somehost port=5433 user=admin
在 PostgreSQL 安装的 share/pg_service.conf.sample
中提供了示例文件。
从服务文件获取的连接参数与从其他来源获取的参数相结合。服务文件设置会覆盖相应的环境变量,而环境变量又可以被连接字符串中直接给定的值覆盖。例如,使用上面的服务文件,连接字符串 service=mydb port=5434
将使用主机 somehost
、端口 5434
、用户 admin
以及由环境变量或内置默认值设置的其他参数。
如果您在文档中看到任何不正确的内容、与您对特定功能的体验不符的内容或需要进一步澄清的内容,请使用 此表单 报告文档问题。