./configure make su make install adduser postgres mkdir -p /usr/local/pgsql/data chown postgres /usr/local/pgsql/data su - postgres /usr/local/pgsql/bin/initdb -D /usr/local/pgsql/data /usr/local/pgsql/bin/pg_ctl -D /usr/local/pgsql/data -l logfile start /usr/local/pgsql/bin/createdb test /usr/local/pgsql/bin/psql test
长版本是本节的其余部分。
配置
安装过程的第一步是为您的系统配置源代码树并选择所需的选项。这是通过运行 configure
脚本来完成的。对于默认安装,只需输入
./configure
此脚本将运行一系列测试,以确定各种系统依赖变量的值,并检测操作系统的任何怪癖,最后将在构建树中创建几个文件来记录它找到的内容。
您也可以在源代码树之外的目录中运行 configure
,然后在那里进行构建,如果您想让构建目录与原始源代码文件分开的话。这个过程称为 VPATH 构建。方法如下:
mkdir build_dir
cd build_dir
/path/to/source/tree/configure [options go here]
make
默认配置将构建服务器和实用程序,以及所有只需要 C 编译器的客户端应用程序和接口。所有文件默认都将安装在 /usr/local/pgsql
下。
您可以通过向 configure
提供一个或多个命令行选项来自定义构建和安装过程。通常,您会自定义安装位置,或构建的选项功能集。 configure
有大量的选项,在第 17.3.3 节中有描述。
此外,configure
还响应某些环境变量,如第 17.3.4 节中所述。这些提供了自定义配置的其他方式。
构建
要开始构建,请键入以下任一命令:
make
make all
(请记住使用GNU make。)构建将根据您的硬件花费几分钟时间。
如果您想构建所有可构建的内容,包括文档(HTML 和 man 页)以及额外的模块(contrib
),请键入:
make world
如果您想构建所有可构建的内容,包括额外的模块(contrib
),但不包括文档,请键入:
make world-bin
如果您想从另一个 makefile 调用构建而不是手动调用,您必须取消设置 MAKELEVEL
或将其设置为零,例如:
build-postgresql: $(MAKE) -C postgresql MAKELEVEL=0 all
未能这样做可能会导致奇怪的错误消息,通常是关于缺少头文件的。
回归测试
如果您想在安装新构建的服务器之前对其进行测试,可以在此时运行回归测试。回归测试是一套测试,用于验证 PostgreSQL 在您的机器上的运行方式是否符合开发人员的预期。键入:
make check
(这在 root 用户下不起作用;请以非特权用户身份执行。)有关解释测试结果的详细信息,请参阅第 31 章。您可以通过发出相同的命令在之后任何时间重复此测试。
安装文件
如果您正在升级现有系统,请务必阅读第 18.6 节,其中包含有关升级集群的说明。
要安装 PostgreSQL,请输入:
make install
这会将文件安装到步骤 1 中指定的目录。请确保您拥有写入该区域的适当权限。通常您需要以 root 用户身份执行此步骤。或者,您可以提前创建目标目录并安排授予适当的权限。
要安装文档(HTML 和 man 页),请输入:
make install-docs
如果您在上面构建了所有内容,请键入:
make install-world
这也将安装文档。
如果您在上面构建了所有内容但不包括文档,请键入:
make install-world-bin
您可以使用 make install-strip
代替 make install
来在安装可执行文件和库时对其进行剥离。这会节省一些空间。如果您启用了调试支持进行构建,则剥离将有效地移除调试支持,因此只有在不再需要调试时才应执行此操作。 install-strip
试图合理地节省空间,但它不完全了解如何从可执行文件中剥离所有不必要的字节,因此如果您想节省尽可能多的磁盘空间,您将不得不手动处理。
标准安装提供了客户端应用程序开发以及服务器端程序开发(例如 C 编写的自定义函数或数据类型)所需的所有头文件。
仅客户端安装: 如果您只想安装客户端应用程序和接口库,则可以使用以下命令:
make -C src/bin install
make -C src/include install
make -C src/interfaces install
make -C doc install
src/bin
包含一些仅用于服务器的二进制文件,但它们很小。
卸载: 要撤消安装,请使用命令 make uninstall
。但是,这不会删除任何创建的目录。
清理: 安装完成后,您可以通过使用命令 make clean
从源代码树中删除已构建的文件来释放磁盘空间。这将保留 configure
程序创建的文件,以便您以后可以使用 make
重新构建所有内容。要将源代码树重置到分发时的状态,请使用 make distclean
。如果您要在同一个源代码树中为多个平台构建,则必须执行此操作并为每个平台重新配置。(或者,为每个平台使用单独的构建树,以便源代码树保持不变。)
如果您执行了构建,然后发现您的 configure
选项不正确,或者如果您更改了 configure
调查的任何内容(例如,软件升级),那么在重新配置和重新构建之前执行 make distclean
是个好主意。否则,您在配置选择中的更改可能不会传播到所有需要的地方。
configure
选项 #下面将解释 configure
的命令行选项。此列表并非详尽无遗(使用 ./configure --help
获取一个)。此处未涵盖的选项用于高级用例,例如交叉编译,并在标准的 Autoconf 文档中进行了记录。
这些选项控制 make install
将文件放置在哪里。对于大多数情况,--prefix
选项就足够了。如果您有特殊需求,可以使用本节中描述的其他选项来自定义安装子目录。但是请注意,更改不同子目录的相对位置可能会使安装不可移动,这意味着安装后您将无法移动它。(man
和 doc
位置不受此限制的影响。)对于可移动的安装,您可能希望使用稍后描述的 --disable-rpath
选项。
--prefix=PREFIX
#将所有文件安装在 PREFIX
目录而不是 /usr/local/pgsql
下。实际文件将安装在各种子目录中;任何文件都不会直接安装在 PREFIX
目录中。
--exec-prefix=EXEC-PREFIX
#您可以将依赖于体系结构的文件的安装目录放在与 PREFIX
不同的前缀 EXEC-PREFIX
下。这对于在主机之间共享依赖于体系结构的独立文件很有用。如果您省略此项,则 EXEC-PREFIX
将等于 PREFIX
,并且依赖于体系结构和独立的文件都将安装在同一个树下,这可能就是您想要的。
--bindir=DIRECTORY
#指定可执行程序的目录。默认值为
,通常表示 EXEC-PREFIX
/bin/usr/local/pgsql/bin
。
--sysconfdir=DIRECTORY
#设置各种配置文件所在的目录,默认值为
。PREFIX
/etc
--libdir=DIRECTORY
#设置安装库和动态加载模块的位置。默认值为
。EXEC-PREFIX
/lib
--includedir=DIRECTORY
#设置安装 C 和 C++ 头文件的目录。默认值为
。PREFIX
/include
--datarootdir=DIRECTORY
#设置各种只读数据文件的根目录。这仅设置以下一些选项的默认值。默认值为
。PREFIX
/share
--datadir=DIRECTORY
#设置已安装程序使用的只读数据文件的目录。默认值为
。请注意,这与数据库文件将放置的位置无关。DATAROOTDIR
--localedir=DIRECTORY
#设置安装区域数据(特别是消息翻译目录文件)的目录。默认值为
。DATAROOTDIR
/locale
--mandir=DIRECTORY
#随 PostgreSQL 一起提供的 man 页将安装在此目录下的相应 man
子目录中。默认值为 x
。DATAROOTDIR
/man
--docdir=DIRECTORY
#设置安装文档文件(man 页除外)的根目录。这仅设置以下选项的默认值。此选项的默认值是
。DATAROOTDIR
/doc/postgresql
--htmldir=DIRECTORY
#PostgreSQL 的 HTML 格式文档将安装在此目录下。默认值为
。DATAROOTDIR
我们已仔细考虑了将 PostgreSQL 安装到共享安装位置(如 /usr/local/include
)而不会干扰系统其他部分的命名空间。首先,字符串““/postgresql
””会自动追加到 datadir
、sysconfdir
和 docdir
,除非完全展开的目录名已包含字符串““postgres
””或““pgsql
””。例如,如果您选择 /usr/local
作为前缀,则文档将安装在 /usr/local/doc/postgresql
中,但如果前缀是 /opt/postgres
,则它将安装在 /opt/postgres/doc
中。客户端接口的公共 C 头文件安装在 includedir
中,并且是命名空间干净的。内部头文件和服务器头文件安装在 includedir
下的私有目录中。有关如何访问其头文件的信息,请参阅每个接口的文档。最后,如果合适,将在 libdir
下为动态加载的模块创建一个私有子目录。
本节介绍的选项支持构建各种默认未构建的 PostgreSQL 功能。其中大多数之所以是非默认的,仅仅是因为它们需要额外的软件,如第 17.1 节中所述。
--enable-nls[=LANGUAGES
]
#启用本地语言支持(NLS),即能够以非英语语言显示程序的邮件。 LANGUAGES
是可选的空格分隔列表,包含您想要支持的语言代码,例如 --enable-nls='de fr'
。(您的列表与实际提供的翻译集之间的交集将自动计算。)如果您不指定列表,则安装所有可用的翻译。
要使用此选项,您需要 Gettext API 的实现。
--with-perl
#构建 PL/Perl 服务器端语言。
--with-python
#构建 PL/Python 服务器端语言。
--with-tcl
#构建 PL/Tcl 服务器端语言。
--with-tclconfig=DIRECTORY
#Tcl 安装 tclConfig.sh
文件,其中包含构建与 Tcl 接口的模块所需的配置信息。此文件通常在已知位置自动找到,但如果您想使用不同版本的 Tcl,则可以指定要查找 tclConfig.sh
的目录。
--with-llvm
#构建时支持基于 LLVM 的JIT编译(请参阅第 30 章)。这需要安装 LLVM 库。当前所需的最低 LLVM 版本是 14。
llvm-config
将用于查找所需的编译选项。 llvm-config
将在您的 PATH
中搜索。如果找不到所需的程序,请使用 LLVM_CONFIG
指定正确 llvm-config
的路径。例如:
./configure ... --with-llvm LLVM_CONFIG='/path/to/llvm/bin/llvm-config'
LLVM 支持需要兼容的 clang
编译器(如果需要,通过 CLANG
环境变量指定),以及一个工作的 C++ 编译器(如果需要,通过 CXX
环境变量指定)。
--with-lz4
#构建时支持 LZ4 压缩。
--with-zstd
#构建时支持 Zstandard 压缩。
--with-ssl=LIBRARY
#构建时支持SSL(加密)连接。唯一支持的 LIBRARY
是 openssl
,它同时用于 OpenSSL 和 LibreSSL。这需要安装 OpenSSL 包。 configure
将检查所需的头文件和库,以确保您的 OpenSSL 安装足够,然后再继续。
--with-openssl
#过时的 --with-ssl=openssl
等效项。
--with-gssapi
#构建时支持 GSSAPI 身份验证。GSSAPI 需要安装 MIT Kerberos。在许多系统上,GSSAPI 系统(MIT Kerberos 安装的一部分)未安装在默认搜索的目录中(例如 /usr/include
、/usr/lib
),因此除了此选项外,您还必须使用 --with-includes
和 --with-libraries
选项。 configure
将检查所需的头文件和库,以确保您的 GSSAPI 安装足够,然后再继续。
--with-ldap
#构建时支持LDAP 身份验证和连接参数查找(有关更多信息,请参阅第 32.18 节 和 第 20.10 节)。在 Unix 上,这需要安装 OpenLDAP 包。在 Windows 上,使用默认的 WinLDAP 库。 configure
将检查所需的头文件和库,以确保您的 OpenLDAP 安装足够,然后再继续。
--with-pam
#--with-bsd-auth
#构建时支持 BSD 身份验证。(BSD 身份验证框架目前仅在 OpenBSD 上可用。)
--with-systemd
#构建时支持 systemd 服务通知。这会改善与 systemd 启动服务器的集成,但否则没有影响;有关更多信息,请参阅第 18.3 节。使用此选项需要安装 libsystemd 和相关的头文件。
--with-bonjour
#构建时支持 Bonjour 自动服务发现。这需要在您的操作系统中具有 Bonjour 支持。在 macOS 上推荐。
--with-uuid=LIBRARY
#构建 uuid-ossp 模块(提供生成 UUID 的函数),使用指定的 UUID 库。 LIBRARY
必须是以下之一:
bsd
使用 FreeBSD 和其他一些 BSD 派生系统中找到的 UUID 函数
e2fs
使用 e2fsprogs
项目创建的 UUID 库;此库存在于大多数 Linux 系统和 macOS 中,并且也可以在其他平台上获得
ossp
使用 OSSP UUID 库
--with-ossp-uuid
#过时的 --with-uuid=ossp
等效项。
--with-libcurl
#构建时支持 libcurl 以实现 OAuth 2.0 客户端流程。此功能需要 libcurl 版本 7.61.0 或更高版本。使用此选项构建将检查所需的头文件和库,以确保您的 curl 安装足够,然后再继续。
--with-libnuma
#构建时支持 libnuma 以实现基本的 NUMA 支持。仅在实现了 libnuma 库的平台上受支持。
--with-liburing
#构建时支持 liburing,启用 io_uring 支持以实现异步 I/O。
为了检测所需的编译器和链接器选项,PostgreSQL 将查询 pkg-config
。
要使用位于非标准位置的 liburing 安装,您可以设置与 pkg-config
相关的环境变量(请参阅其文档)。
--with-libxml
#构建时支持 libxml2,启用 SQL/XML 支持。此功能需要 libxml2 版本 2.6.23 或更高版本。
为了检测所需的编译器和链接器选项,PostgreSQL 将查询 pkg-config
(如果已安装并知道 libxml2)。否则,如果找到,将使用 libxml2 安装的程序 xml2-config
。首选使用 pkg-config
,因为它能更好地处理多架构安装。
要使用位于非标准位置的 libxml2 安装,您可以设置与 pkg-config
相关的环境变量(请参阅其文档),或者将环境变量 XML2_CONFIG
设置为指向 libxml2 安装附带的 xml2-config
程序,或者设置变量 XML2_CFLAGS
和 XML2_LIBS
。(如果安装了 pkg-config
,那么要覆盖其对 libxml2 位置的理解,您必须设置 XML2_CONFIG
或将 XML2_CFLAGS
和 XML2_LIBS
都设置为非空字符串。)
--with-libxslt
#构建时支持 libxslt,启用 xml2 模块来执行 XML 的 XSL 转换。还必须指定 --with-libxml
。
--with-selinux
#构建时支持 SElinux,启用 sepgsql 扩展。
本节介绍的选项允许禁用某些默认构建的 PostgreSQL 功能,但在必需的软件或系统功能不可用时可能需要关闭它们。除非确实有必要,否则不建议使用这些选项。
--with-includes=DIRECTORIES
#DIRECTORIES
是一个由冒号分隔的目录列表,这些目录将被添加到编译器搜索头文件的列表中。如果您在非标准位置安装了可选包(例如 GNU Readline),则必须使用此选项,并且很可能还要使用相应的 --with-libraries
选项。
示例:--with-includes=/opt/gnu/include:/usr/sup/include
。
--with-libraries=DIRECTORIES
#DIRECTORIES
是一个由冒号分隔的目录列表,用于搜索库。如果您在非标准位置安装了软件包,则很可能需要使用此选项(以及相应的 --with-includes
选项)。
示例:--with-libraries=/opt/gnu/lib:/usr/sup/lib
。
--with-system-tzdata=目录
#PostgreSQL 包含自己的时区数据库,这是进行日期和时间操作所必需的。此时区数据库实际上与许多操作系统(如 FreeBSD、Linux 和 Solaris)提供的 IANA 时区数据库兼容,因此再次安装它是多余的。使用此选项时,将使用 目录
中的系统提供的时区数据库,而不是 PostgreSQL 源代码发行版中包含的数据库。目录
必须指定为绝对路径。/usr/share/zoneinfo
是某些操作系统上可能存在的目录。请注意,安装例程不会检测不匹配或错误的时区数据。如果您使用此选项,建议运行回归测试以验证您指定时区数据的有效性。
此选项主要面向了解其目标操作系统的二进制包分发者。使用此选项的主要优点是,每当许多本地夏令时规则发生更改时,无需升级 PostgreSQL 包。另一个优点是,如果时区数据库文件不需要在安装过程中构建,则可以更直接地交叉编译 PostgreSQL。
--with-extra-version=字符串
#将 字符串
追加到 PostgreSQL 版本号。例如,您可以使用此选项来标记从未发布的 Git 快照构建或包含自定义补丁的二进制文件,并附加一个额外的版本字符串,例如 git describe
标识符或分发包的发行号。
--disable-rpath
#不标记 PostgreSQL 的可执行文件,指示它们应该在安装的库目录中搜索共享库(请参阅 --libdir
)。在大多数平台上,此标记使用库目录的绝对路径,因此如果您以后重新定位安装,它将无用。但是,您需要通过其他方式让可执行文件找到共享库。这通常需要配置操作系统的动态链接器以搜索库目录;有关更多详细信息,请参阅 第 17.5.1 节。
通常,特别是在测试构建中,会使用 --with-pgport
来调整默认端口号。本节中的其他选项仅推荐给高级用户。
--with-pgport=数字
#将 数字
设置为服务器和客户端的默认端口号。默认值为 5432。端口可以随时更改,但如果在此处指定,则服务器和客户端都将具有相同的默认编译值,这可能非常方便。通常,选择非默认值的唯一好理由是您打算在同一台机器上运行多个 PostgreSQL 服务器。
--with-krb-srvnam=名称
#GSSAPI 使用的 Kerberos 服务主体的默认名称。postgres
是默认值。通常没有理由更改此设置,除非您正在为 Windows 环境构建,在这种情况下,它必须设置为大写的 POSTGRES
。
--with-segsize=SEGSIZE
#以千兆字节为单位设置“段大小”。大表被划分为多个操作系统文件,每个文件的大小等于段大小。这可以避免许多平台存在的有关文件大小限制的问题。默认段大小(1 千兆字节)在所有支持的平台上都是安全的。如果您的操作系统支持“大文件”(现在大多数都支持),则可以使用更大的段大小。这有助于减少处理非常大的表时消耗的文件描述符的数量。但请注意,不要选择大于您的平台和您打算使用的文件系统支持的值。您可能希望使用的其他工具(如 tar)也可能设置可用文件大小的限制。建议(但并非绝对必需)此值是 2 的幂。请注意,更改此值会破坏磁盘数据库兼容性,这意味着您不能使用 pg_upgrade
升级到具有不同段大小的构建。
--with-blocksize=BLOCKSIZE
#以千字节为单位设置“块大小”。这是表内的存储和 I/O 单位。默认值 8 千字节适用于大多数情况;但在特殊情况下,其他值可能有用。该值必须是 1 到 32(千字节)之间的 2 的幂。请注意,更改此值会破坏磁盘数据库兼容性,这意味着您不能使用 pg_upgrade
升级到具有不同块大小的构建。
--with-wal-blocksize=BLOCKSIZE
#以千字节为单位设置“WAL 块大小”。这是 WAL 日志内的存储和 I/O 单位。默认值 8 千字节适用于大多数情况;但在特殊情况下,其他值可能有用。该值必须是 1 到 64(千字节)之间的 2 的幂。请注意,更改此值会破坏磁盘数据库兼容性,这意味着您不能使用 pg_upgrade
升级到具有不同 WAL 块大小的构建。
此部分中的大多数选项仅对开发或调试 PostgreSQL 有意义。不建议将其用于生产构建,--enable-debug
除外,它在不幸遇到 bug 时可以用于启用详细的 bug 报告。在支持 DTrace 的平台上,--enable-dtrace
在生产环境中使用也是合理的。
当构建用于在服务器内部开发代码的安装时,建议至少使用 --enable-debug
和 --enable-cassert
选项。
--enable-debug
#使用调试符号编译所有程序和库。这意味着您可以在调试器中运行程序来分析问题。这会显著增加已安装可执行文件的大小,并且在非 GCC 编译器上通常还会禁用编译器优化,导致性能下降。但是,拥有符号对于处理可能出现的任何问题都非常有帮助。目前,此选项仅推荐用于生产安装(如果您使用 GCC)。但如果您正在进行开发工作或运行 beta 版本,则应始终启用它。
--enable-cassert
#在服务器中启用“断言”检查,它会测试许多“不可能发生”的条件。这对于代码开发非常有用,但测试可能会显著降低服务器速度。此外,启用测试不一定会提高服务器的稳定性!断言检查未按严重程度分类,因此相对无害的 bug 也会在触发断言失败时导致服务器重启。此选项不推荐用于生产环境,但您应该在开发工作或运行 beta 版本时启用它。
--enable-tap-tests
#启用使用 Perl TAP 工具的测试。这需要安装 Perl 和 Perl 模块 IPC::Run
。有关更多信息,请参阅 第 31.4 节。
--enable-depend
#启用自动依赖项跟踪。使用此选项,makefiles 会设置好,以便在任何头文件发生更改时都会重新构建所有受影响的目标文件。如果您正在进行开发工作,这很有用,但如果您打算只编译一次并安装,则只是浪费开销。目前,此选项仅适用于 GCC。
--enable-coverage
#如果使用 GCC,所有程序和库都将使用代码覆盖率测试插装进行编译。运行时,它们会在构建目录中生成具有代码覆盖率指标的文件。有关更多信息,请参阅 第 31.5 节。此选项仅用于 GCC 和开发工作。
--enable-profiling
#如果使用 GCC,所有程序和库都将进行编译,以便进行性能分析。在后端退出时,将创建一个子目录,其中包含包含性能分析数据的 gmon.out
文件。此选项仅用于 GCC 和开发工作。
--enable-dtrace
#使用 DTrace 动态跟踪工具的支持编译 PostgreSQL。有关更多信息,请参阅 第 27.5 节。
要指向 dtrace
程序,可以设置环境变量 DTRACE
。这通常是必要的,因为 dtrace
通常安装在 /usr/sbin
下,而这可能不在您的 PATH
中。
传递给 dtrace
程序的额外命令行选项可以在环境变量 DTRACEFLAGS
中指定。在 Solaris 上,要在 64 位二进制文件中包含 DTrace 支持,必须指定 DTRACEFLAGS="-64"
。例如,使用 GCC 编译器
./configure CC='gcc -m64' --enable-dtrace DTRACEFLAGS='-64' ...
使用 Sun 的编译器
./configure CC='/opt/SUNWspro/bin/cc -xtarget=native64' --enable-dtrace DTRACEFLAGS='-64' ...
--enable-injection-points
#使用服务器中的注入点支持编译 PostgreSQL。注入点允许从服务器内的预定义代码路径运行用户定义的代码。这有助于以受控的方式进行测试和并发场景的研究。此选项默认禁用。有关更多详细信息,请参阅 第 36.10.14 节。此选项仅供开发人员用于测试。
--with-segsize-blocks=SEGSIZE_BLOCKS
#以块为单位指定关系段大小。如果同时指定了 --with-segsize
和此选项,则此选项生效。此选项仅供开发人员用于测试段相关代码。
configure
环境变量 #除了上面描述的普通命令行选项外,configure
还响应许多环境变量。您可以在 configure
命令行上指定环境变量,例如
./configure CC=/opt/bin/gcc CFLAGS='-O2 -pipe'
在此用法中,环境变量与命令行选项的区别不大。您也可以提前设置这些变量
export CC=/opt/bin/gcc
export CFLAGS='-O2 -pipe'
./configure
这种用法可能很方便,因为许多程序的配置脚本都以类似的方式响应这些变量。
这些环境变量中最常用的是 CC
和 CFLAGS
。如果您更喜欢与 configure
选择的 C 编译器不同的编译器,可以将变量 CC
设置为您选择的程序。默认情况下,如果可用,configure
会选择 gcc
,否则选择平台默认值(通常是 cc
)。同样,如果需要,您可以使用 CFLAGS
变量覆盖默认的编译器标志。
以下是可以用这种方式设置的重要变量列表
BISON
#Bison 程序
CC
#C 编译器
CFLAGS
#传递给 C 编译器的选项
CLANG
#当使用 --with-llvm
编译时,用于处理内联源代码的 clang
程序的路径
CPP
#C 预处理器
CPPFLAGS
#传递给 C 预处理器的选项
CXX
#C++ 编译器
CXXFLAGS
#传递给 C++ 编译器的选项
DTRACE
#dtrace
程序的安装位置
DTRACEFLAGS
#传递给 dtrace
程序的选项
FLEX
#Flex 程序
LDFLAGS
#链接可执行文件或共享库时使用的选项
LDFLAGS_EX
#仅链接可执行文件的附加选项
LDFLAGS_SL
#仅链接共享库的附加选项
LLVM_CONFIG
#用于定位 LLVM 安装的 llvm-config
程序
MSGFMT
#用于本地化语言支持的 msgfmt
程序
PERL
#Perl 解释器程序。这将用于确定构建 PL/Perl 的依赖项。默认值为 perl
。
PYTHON
#Python 解释器程序。这将用于确定构建 PL/Python 的依赖项。如果未设置,将按以下顺序进行探测:python3 python
。
TCLSH
#Tcl 解释器程序。这将用于确定构建 PL/Tcl 的依赖项。如果未设置,将按以下顺序进行探测:tclsh tcl tclsh8.6 tclsh86 tclsh8.5 tclsh85 tclsh8.4 tclsh84
。
XML2_CONFIG
#用于定位 libxml2 安装的 xml2-config
程序
有时,在 configure
选择的标志集之后添加编译器标志会很有用。一个重要的例子是,gcc 的 -Werror
选项不能包含在传递给 configure
的 CFLAGS
中,因为它会破坏 configure
的许多内置测试。要添加此类标志,请在运行 make
时将其包含在 COPT
环境变量中。COPT
的内容将被添加到 configure
设置的 CFLAGS
、CXXFLAGS
和 LDFLAGS
选项中。例如,您可以这样做
make COPT='-Werror'
或
export COPT='-Werror'
make
如果使用 GCC,最好以至少 -O1
的优化级别进行构建,因为不使用优化(-O0
)会禁用一些重要的编译器警告(例如未初始化变量的使用)。但是,非零优化级别可能会使调试复杂化,因为单步执行编译后的代码通常与源代码行不匹配。如果您在尝试调试优化代码时感到困惑,可以使用 -O0
重新编译感兴趣的特定文件。一种简单的方法是向 make 传递一个选项:make PROFILE=-O0 file.o
。
PostgreSQL makefiles 实际上以相同的方式处理 COPT
和 PROFILE
环境变量。使用哪一个取决于个人偏好,但开发者中一种常见的习惯是使用 PROFILE
进行一次性标志调整,而 COPT
可能会一直保持设置状态。
如果您在文档中发现任何不正确、不符合您对特定功能的使用体验或需要进一步澄清的内容,请使用 此表格 报告文档问题。