pgpool配置安装之服务器的配置

server/2025/1/12 5:51:36/

第 1 章.服务器配置

1.1. 设置参数

1.1.1. 参数名称和值

所有参数名称均不区分大小写。每个参数都采用 值为以下五种类型之一:boolean、string、integer、floating point、 或枚举 (enum)。类型决定了设置 参数:

布尔:值可以写成 on、off、true、false、yes、no、1、0(全部不区分大小写)或其中之一的任何明确前缀。

字符串:通常,将值括在单引号中,将任何单个 值内的 quotes 中。如果值 是一个简单的数字或标识符。

数字 (整数和浮点) :仅允许浮点参数使用小数点。 不要使用千位分隔符。不需要报价。

带单位的数值:描述 quant 的数值参数 memory 或 time 具有隐含单位。 单位可以是千字节、兆字节、毫秒、 秒或分钟。 例如:

  search_primary_node_timeout = 6minmemqcache_total_size = 64MB

这些设置之一的未修饰数值将使用 参数的默认单位。

单位名称区分大小写,并且数值和单位之间可以有空格。

有效的内存单位为 kB (KB)、MB (兆字节)、GB (千兆字节) 和 TB (TB)。

有效的时间单位为 ms(毫秒)、s(秒)、min(分钟)、h(小时)和 d(天)。

枚举:枚举类型参数的编写方式与 string 相同 参数,但仅限于具有一组有限的 值。枚举参数值不区分大小写。

1.1.2. 通过配置文件进行参数交互

设置这些参数最基本的方法是编辑文件 pgpool.conf, 它位于 $prefix/etc/pgpool.conf 中,如果它 从源代码安装。此文件可能如下所示的示例如下:

 # This is a commentlisten_addresses = 'localhost'port = 9999serialize_accept = offreset_query_list = 'ABORT; DISCARD ALL'

每行指定一个参数。name 和 之间的等号 value 是可选的。空格无关紧要(除非在带引号的 parameter 值)和空行为 忽视。哈希标记 (#) 指定余数 作为注释。不简单的参数值 标识符或数字必须用单引号引起来。要嵌入单个 quote 在参数值中,写入两个引号 (preferred) 或反斜杠引号。

以这种方式设置的参数为集群提供默认值。 活动会话看到的设置将是这些值,除非它们 被覆盖。以下部分介绍了 管理员或用户可以覆盖这些默认值。

每当主服务器进程 接收 SIGHUP 信号;这个信号最容易 通过命令行运行 pgpool reload 发送。主要的 pgpool 进程也会将此信号传播到它的所有子进程 进程,以便 Next Session 也采用新值。 某些参数只能在服务器启动时设置;对其 配置文件中的条目将被忽略,直到服务器重新启动。 配置文件中的无效参数设置同样 在 SIGHUP 处理期间被忽略(但被记录)。

1.1.3. 管理配置文件内容

Pgpool-II 提供了一个将 pgpool.conf 文件分解为子文件的功能。此功能是 在管理多个服务器或按功能划分时特别有用。include 指令可以像这样使用:

 include = 'filename'

如果文件名不是绝对路径,则将其视为相对路径 添加到包含引用配置文件的目录中。 包含物可以嵌套。

1.1.4. 通过 SQL 客户端进行参数交互

Pgpool-II 还提供了两种 SQL 风格 命令与会话本地配置设置交互。

PGPOOL SHOW 命令允许检查 所有参数的当前值。

PGPOOL SET 命令允许修改 当前值,这些参数可以在本地设置为 会期;它对其他会话没有影响。

1.2. 连接和身份验证

1.2.1. 连接设置

listen_addresses (字符串))
指定服务器所在的 TCP/IP 地址 侦听来自客户端应用程序的连接。 该值采用逗号分隔的主机名列表的形式 和/或数字 IP 地址。特殊条目 * 对应于所有可用的 IP 接口。条目 0.0.0.0 允许侦听所有 IPv4 地址,而 :: 允许侦听所有 IPv6 地址。 如果列表为空,则服务器不侦听任何 IP 接口 完全,在这种情况下,只能使用 Unix 域套接字来连接 到它。 默认值 是 localhost,它 仅允许本地 TCP/IP“环回”连接到 被制造。当客户端身份验证 (第 6.1 节)允许精细的 控制谁可以访问 server, listen_addresses 控制哪些 接口接受连接尝试,这有助于防止 在不安全的网络上重复恶意连接请求 接口。此参数只能在服务器启动时设置。

此参数只能在服务器启动时设置。

port (整数)
使用的端口号 由 Pgpool-II 监听 连接。默认值为 9999。

此参数只能在服务器启动时设置。

unix_socket_directories (字符串))
接受 Pgpool-II 连接的 UNIX 域套接字将被创建的目录。多个套接字 可以通过列出多个目录(以逗号分隔)来创建。违约 是 /tmp。请注意,此套接字可能会被删除 通过 cron 作业。我们建议将此值设置为 /var/run 或此类目录。

此参数只能在服务器启动时设置。

unix_socket_group (字符串))
设置 Unix 域套接字的拥有组。(的拥有用户 sockets 始终是启动 server 的用户。组合 使用参数 unix_socket_permissions 可以是 用作 Unix 域连接的附加访问控制机制。 默认情况下,这是空字符串,它使用 server 用户。

此参数只能在服务器启动时设置。

unix_socket_permissions (整数))
设置 Unix 域套接字的访问权限。Unix 域 套接字使用通常的 Unix 文件系统权限集。参数值 应为以 chmod 和 umask 系统调用。(要使用惯用的八进制格式,请将数字 必须以 0(零)开头。

默认权限为 0777,这意味着任何人都可以 连接。合理的替代方案是 0770 (only user 和 group,另请参阅 unix_socket_group) 和 0700 (仅用户)。(请注意,对于 Unix 域套接字, 只有写入权限才重要,因此设置或撤销没有意义 读取或执行权限。

此参数只能在服务器启动时设置。

pcp_listen_addresses (字符串))
指定 pcp 服务器所在的 TCP/IP 地址 侦听来自客户端应用程序的连接。 该值采用逗号分隔的主机名列表的形式 和/或数字 IP 地址。特殊条目 * 对应于所有可用的 IP 接口。条目 0.0.0.0 允许侦听所有 IPv4 地址,而 :: 允许侦听所有 IPv6 地址。 如果列表为空,则服务器不侦听任何 IP 接口 完全,在这种情况下,只能使用 Unix 域套接字来连接 到它。 默认值 是 localhost,它 仅允许本地 TCP/IP“环回”连接到 被制造。当客户端身份验证 (第 6.1 节)允许精细的 控制谁可以访问 server, pcp_listen_addresses 控制哪些 接口接受连接尝试,这有助于防止 在不安全的网络上重复恶意连接请求 接口。此参数只能在服务器启动时设置。

pcp_port (整数))
PCP 使用的端口号 process 来监听连接。默认值为 9898。

此参数只能在服务器启动时设置。

pcp_socket_dir (字符串))
UNIX 域套接字接受 将创建 PCP 进程的连接。多个套接字 可以通过列出多个目录(以逗号分隔)来创建。 默认值为 /tmp。请注意,此 socket 可能会被 cron 作业删除。我们建议将此项 值设置为 /var/run 或此类目录。

此参数只能在服务器启动时设置。

num_init_children (整数)
的 预分叉的 Pgpool-II 服务器 过程。默认值为 32。num_init_children 也是 并发连接数限制 到 Pgpool-II。如果 超过 num_init_children 个客户端尝试连接到 Pgpool-II,它们 已阻止(未因错误而被拒绝, 如 PostgreSQL),直到 除非设置了 reserved_connections,否则与任何 Pgpool-II 进程的连接都是关闭的 设置为 1 或更多。最高 listen_backlog_multiplier* num_init_children可以排队。

该队列位于内核内部,称为 “listen queue”。这 侦听队列的长度称为 “backlog”。有 某些系统中积压的上限,如果 num_init_children*listen_backlog_multiplier超过该数量,则需要将积压工作设置得更高。 否则,在重负载系统中可能会出现以下问题:

连接到 Pgpool-II 失败

连接到 Pgpool-II 是 由于内核中的重试而变慢。

您可以使用 “netstat -s” 命令。如果您发现类似以下内容:

535 times the listen queue of a socket overflowed

那么 listen 队列肯定是溢出的。你 在这种情况下,应该会增加积压(您将 需要超级用户权限)。

# sysctl net.core.somaxconn
net.core.somaxconn = 128
# sysctl -w net.core.somaxconn = 256

你可以将以下内容添加到 /etc/sysctl.conf 中。

net.core.somaxconn = 256

到 的连接数 每个 PostgreSQL 大致是 max_pool*num_init_children。

但是,取消查询会创建另一个 连接到后端;因此,如果满足以下条件,则无法取消查询 所有连接都在使用中。如果要确保查询可以 be canceled,请将此值设置为预期连接数的两倍。

此外,PostgreSQL 允许并发 非超级用户最多 max_connections 的连接 - superuser_reserved_connections。

总之,max_pool、num_init_children、max_connections、 superuser_reserved_connections必须满足以下公式:

   max_pool*num_init_children <= (max_connections - superuser_reserved_connections) (no query canceling needed)max_pool*num_init_children*2 <= (max_connections - superuser_reserved_connections) (query canceling needed)

此参数只能在服务器启动时设置。

reserved_connections (整数))
当此参数设置为 1 或更大时,传入 不接受来自客户端的连接,并显示错误 消息 “Sorry, too many clients already”,而不是 如果当前来自客户端的连接数 大于 (num_init_children - reserved_connections)。例如 如果 reserved_connections = 1 和 num_init_children = 32,则 来自客户端的第 32 个连接将被拒绝。这 行为相似 到 PostgreSQL 并且适合 来自客户端的连接数为 large 且每个会话可能需要很长时间。在这种情况下 侦听队列的长度可能很长,并且可能会 导致系统不稳定。在这种情况下,设置此 parameter 设置为非 0 是防止监听的好主意 队列变得很长。

如果此参数设置为 0,则没有来自客户端的连接 将被拒绝。默认值为 0。 此参数只能在服务器启动时设置。

1.2.2. 身份验证设置

enable_pool_hba (布尔值))
如果为 true,则 Pgpool-II 将使用 pool_hba.conf 作为客户端 认证。有关如何配置 pool_hba.conf 进行客户端身份验证的详细信息,请参见Section 6.1。 默认值为 false。

可以通过重新加载来更改此参数 Pgpool-II 配置。

pool_passwd (字符串))
指定 的密码文件的路径(绝对或相对) 认证。默认值为 “pool_passwd”。 将相对于目录解释相对路径 配置文件的放置位置。 指定 ‘’ (空) 将禁用 的密码文件。

密码可以使用三种格式存储在 pool_passwd 文件中。 AES256 加密格式、纯文本格式和 md5 格式。Pgpool-II 标识密码格式类型 通过它的前缀,因此 pool_passwd 中的每个密码条目都必须带有前缀 根据密码格式。

要以纯文本格式存储密码,请使用 TEXT 前缀。 例如。要在 pool_passwd 中存储明文密码字符串 “mypassword”,请在密码字符串前面加上 TEXT 前缀。 例如 TEXTmypassword

同样,MD5 哈希密码必须以 MD5 和 AES256 加密的密码类型可以使用 AES 前缀进行存储。 有关使用 AES256 加密密码。

在没有有效前缀的情况下,Pgpool-II 将 将字符串视为纯文本密码。

此参数只能在服务器启动时设置。

allow_clear_text_frontend_auth (布尔值))
如果 PostgreSQL 后端服务器需要 md5 或 SCRAM 身份验证,则某些 用户的身份验证,但该用户的密码没有出现在 “pool_passwd” 文件中,那么启用 allow_clear_text_frontend_auth 将允许 Pgpool-II 使用明文密码 使用前端客户端进行身份验证,以纯文本形式获取密码 并将其用于后端身份验证。

默认值为 false。

可以通过重新加载来更改此参数 Pgpool-II 配置。

注意: allow_clear_text_frontend_auth仅在未启用 enable_pool_hba 时有效

authentication_timeout (整数)
指定超时(以秒为单位) 用于 Pgpool-II 身份验证。指定 0 将禁用超时。 默认值为 60。

可以通过重新加载来更改此参数 Pgpool-II 配置。

1.3. 流程管理

process_management_mode (枚举))
指定 Pgpool-II 子进程的空闲进程管理方法。 有效选项:

表 1-1.可能的进程管理模式

状态描述
静态的所有子节点在启动时都是 pre-forked 的。 子进程的数量是固定的 (num_init_children)。
动态子进程按需生成,最多 num_init_children。 任何时候空闲的子进程数取决于 min_spare_children 和 max_spare_children
默认为 static,与 V4.4 之前的版本兼容。

process_management_mode 在 Pgpool-II V4.4 之前不可用。

有关更多详细信息,请参阅 Section 3.3.3 。

process_management_strategy (enum)
指定进程管理策略以满足备用(空闲)进程计数 有效选项:

表 1-2.可能的流程管理策略

策略描述
lazy使用此策略,将逐步执行缩减 并且仅在冗余进程计数过多时触发 保持高位超过 5 分钟
gentle使用此策略,将逐步执行缩减 并且仅在冗余进程计数过多时触发 保持高位超过 2 分钟
aggressive使用此策略,将积极执行缩减 ,并且在备用进程较高的情况下会更频繁地触发。 此模式使用更快且智能程度稍低的进程选择标准 确定可以提供服务以满足 max_spare_children
默认值为 gentle。

process_management_strategy 在 Pgpool-II V4.4 之前不可用。

min_spare_children (整数))
指定要保留的备用 (空闲) 子进程的最小数量。 如果空闲进程计数低于 min_spare_children, Pgpool-II 将产生新的子进程,除非它达到允许的子进程总上限 (num_init_children)。 默认值为 5。

可以通过重新加载来更改此参数 Pgpool-II 配置。

该参数仅适用于动态流程管理模式。

max_spare_children (整数)
指定要保留的备用 (空闲) 子进程的最大数量。 如果空闲进程数从 max_spare_children 开始增加,Pgpool-II 将杀死过多的子进程。 选择标准是选择具有最少池连接数的进程。 默认值为 10。

可以通过重新加载来更改此参数 Pgpool-II 配置。

该参数仅适用于动态流程管理模式。

1.4. 集群模式

backend_clustering_mode (枚举))
集群模式是同步 PostgreSQL 服务器的方法。设置聚类 模式,可以使用 backend_clustering_mode。在 本节讨论如何设置 clustering mode。有关更多详细信息,请参阅 Section 2.1.1 。

1.4.1. 流式复制模式

此模式是最常用和推荐的群集模式。在这个 mode PostgreSQL 负责 复制每个服务器。要启用此模式,请使用 backend_clustering_mode 的 ‘streaming_replication’ 表示。

backend_clustering_mode = 'streaming_replication'

在此模式下,您最多可以拥有 127 个 Streaming Replication 备用服务器。 此外,可能根本没有备用服务器。

这种模式的缺点是,需要考虑 分发读取查询时的复制延迟。可见性 节点之间的一致性也无法保证。缓解这些 问题 准备了许多额外的参数,但它可能会使 管理任务更难。此外,可能需要一些时间 当主服务器宕机时执行故障转移,并且 Standbys 已升级。如果要避免这些问题,请考虑快照隔离 模式。

参见 Section 1.12 流复制模式的其他参数。

1.4.2. 原生复制模式

这种模式使 Pgpool-II 能够 在 PostgreSQL 后端之间复制数据。要启用此模式,请使用 ‘native_replication’ 作为 backend_clustering_mode。

backend_clustering_mode = 'native_replication'

在此模式下,您最多可以有 127 个备用复制服务器。 此外,可能根本没有备用服务器。

负载平衡(请参阅 Section 1.8 )可以 还可以与复制模式一起使用,以将负载分配到 附加的后端节点。

这种模式的缺点是,节点之间的可见性一致性是 不保证。这可能会导致节点和读取不一致 不一致的数据。如果要避免这些问题,请考虑快照隔离 模式。

以下选项会影响 Pgpool-II 在复制模式下的行为。

replication_stop_on_mismatch (布尔值))
当设置为 on 时,并且所有节点都不回复相同的 packet kind 添加到发送到 所有 PostgreSQL 后端节点, 则 reply 与 多数 被 Pgpool-II. 如果设置了 replication_stop_on_mismatch 设置为 off 并发生类似的情况 Pgpool-II 仅终止 当前用户会话,但不会退化后端 节点。

注意: Pgpool-II 不检查 后端返回的数据并做出决策 仅通过比较结果数据包类型。

启用 replication_stop_on_mismatch是 防止后端之间的数据不一致 节点。例如,您可能希望退化后端 node 如果 UPDATE 语句在一个后端节点上失败 同时传递他人。

默认值为 off。

可以通过重新加载来更改此参数 Pgpool-II 配置。

failover_if_affected_tuples_mismatch (布尔值))
当设置为 on 时,并且所有节点都不回复相同的 INSERT/UPDATE/DELETE 受影响的元组数 query 中,则其回复与 多数 被 Pgpool-II. 如果 failover_if_affected_tuples_mismatch 设置为 off 并且发生类似情况,则 Pgpool-II 仅终止 当前用户会话,但不会退化后端 节点。

注意: 在平局的情况下,当两个或多个组具有相同的 number of nodes,则包含主节点的组 node(具有最小节点 ID 的后端节点)获取 优先。

默认值为 off。

这个参数可以通过重新加载 Pgpool-II 配置来改变。

replicate_select (布尔值))
当设置为 on 时,Pgpool-II 启用 SELECT 查询复制模式。即发送 SELECT 查询 添加到所有后端节点。

表 1-3.对 SELECT 路由load_balance_mode影响的 replicate_select
在这里插入图片描述

默认值为 off。

这个参数可以通过重新加载 Pgpool-II 配置来改变。

insert_lock (布尔值))
当设置为 on 时,Pgpool-II 将 自动锁定表 在 PostgreSQL 上的 INSERT 之前 为此发布了声明。

复制 SERIAL 数据类型的表时,SERIAL column 值可能会在不同的 backends 的此问题的解决方法是显式 在发出 INSERT 之前锁定 table。

因此,为了自动锁定 表 Pgpool-II 执行 以下转换:

   INSERT INTO ...

   BEGIN;LOCK TABLE ...INSERT INTO ...COMMIT;

谨慎:这种方法严重降低了交易的 排比

Pgpool-II V2.2 或更高版本,自动检测表是否具有 SERIAL 列,因此如果 没有 SERIAL 列。

Pgpool-II V3.0 到 Pgpool-II V3.0.4 都使用针对序列关系的行锁,而不是 表锁。这是为了最大限度地减少锁冲突 使用 VACUUM(包括 autovacuum)。 但是,这可能会导致另一个问题。后 事务回绕发生,针对 sequence 关系导致 PostgreSQL 内部错误(更多 准确地说,pg_clog 上的 Access 错误,它使 交易状态)。为了防止 this,PostgreSQL 核心 开发人员决定禁止对 序列,这坏了 当然是 Pgpool-II( PostgreSQL 的“固定”版本作为 9.0.5 发布, 8.4.9、8.3.16 和 8.2.22)。

Pgpool-II V3.0.5 或更高版本使用行锁 针对 pgpool_catalog.insert_lock 表,因为新的 PostgreSQL 不允许对 序列关系。因此insert_lock 中创建表 所有事先通过 Pgpool-II 访问的数据库都是 必填。有关更多详细信息,请参阅 Section 2.8 。如果不存在 insert_lock table 中,Pgpool-II 会锁定 Insert Target Table.此行为是相同的 作为 Pgpool-II V2.2 和 V2.3 系列。

如果你想使用 insert_lock 哪个 与旧版本兼容,您可以指定 LOCK 方法。 有关更多详细信息,请参阅 Section 2.5 。

对于精细 (每个语句) 控制:

将 insert_lock 设置为 true,并在 您执行的 INSERT 语句的开头 不想获取 table lock。

将 insert_lock 设置为 false,并在 INSERT 语句的开头,您为其 想要获取表锁。

注意: 如果启用了 insert_lock,则 PostgreSQL 8.0 在事务、权限、 rules 和 alter_table。

这样做的原因是 Pgpool-II 尝试 LOCK 的 VIEW 进行规则测试,并生成以下内容 错误信息:

! ERROR: current transaction is aborted, commands ignored until
end of transaction block

例如,transactions 测试尝试将 INSERT 插入 一个不存在的表格, 而 Pgpool-II 使 PostgreSQL 获取 表的锁。当然,这会导致 错误。事务将被中止,并且 以下 INSERT 语句产生上述错误 消息。

默认值为 on。

可以通过重新加载来更改此参数 Pgpool-II 配置。

lobj_lock_table (字符串))
指定用于大型对象复制控制的表名。 如果指定,Pgpool-II 将锁定 lobj_lock_table 指定的表并生成 通过查看系统目录pg_largeobject然后调用 lo_create 来创建大型对象 ID 大型物体。 此过程保证 Pgpool-II 在复制模式下的所有 DB 节点中将获得相同的大对象 ID。

注意: PostgreSQL 8.0 及更早版本可以 没有lo_create,所以这个功能 不适用于 PostgreSQL 8.0 及更早版本。

调用 libpq 函数 lo_creat() 会触发此 特征。还可以创建大型对象 通过 Java API (JDBC 驱动程序)、PHP API (pg_lo_create 或类似 API PHP 库(如 PDO)和各种 API 中的相同 API 已知编程语言使用类似的协议 因此应该有效。

此功能不适用于对大型对象的以下操作。

所有使用 lo_create、lo_import_with_oid.

lo_import SELECT 中调用的后端函数。

lo_create SELECT 中调用的后端函数。

注意: 所有 PostgreSQL 用户都必须 具有写入访问权限 lobj_lock_table上,它可以是 在任何 schema 中创建。

创建大型对象锁定表的示例:

   CREATE TABLE public.my_lock_table ();GRANT ALL ON public.my_lock_table TO PUBLIC;

默认值为 ‘’(empty),这将禁用该功能。

1.4.3. 快照隔离模式

此模式类似于本机复制模式,不同之处在于它添加了 节点之间的可见性一致性。实现基于 在研究论文 Pangea 上:一个 Eager 数据库复制中间件保证快照 无需修改数据库服务器即可进行隔离。 要启用此模式,请使用 ‘snapshot_isolation’ 作为 backend_clustering_mode。

backend_clustering_mode = ‘snapshot_isolation’

例如,您可以避免由 可见性不一致。这里 S1 和 S2 表示会话,而 N1 N2 分别表示 PostgreSQL 服务器 1 和 2。

S1/N1: BEGIN;
S1/N2: BEGIN;
S1/N1: UPDATE t1 SET i = i + 1;	-- i = 1
S1/N2: UPDATE t1 SET i = i + 1; -- i = 1
S1/N1: COMMIT;
S2/N1: BEGIN;
S2/N2: BEGIN;
S2/N2: DELETE FROM t1 WHERE i = 1; -- delete 1 row since S1/N2 is not committed yet
S2/N1: DELETE FROM t1 WHERE i = 1; -- delete no row since S1/N1 is committed and i is not 1 anymore
S1/N2: COMMIT;
S2/N1: COMMIT;
S2/N2: COMMIT;

在快照隔离模式下,结果将是以下任一 它们,它永远不会破坏数据库之间的数据一致性 节点。

S1/N1: BEGIN;
S1/N2: BEGIN;
S1/N1: UPDATE t1 SET i = i + 1;	-- i = 1
S1/N2: UPDATE t1 SET i = i + 1; -- i = 1
S2/N1: BEGIN;
S2/N2: BEGIN;
S1/N1: COMMIT;
S1/N2: COMMIT;
S2/N1: DELETE FROM t1 WHERE i = 1; -- delete no row since S1/N1 is committed and i is not 1 anymore
S2/N2: DELETE FROM t1 WHERE i = 1; -- delete no row since S1/N2 is committed and i is not 1 anymore
S2/N1: COMMIT;
S2/N2: COMMIT;
S1/N1: BEGIN;
S1/N2: BEGIN;
S1/N1: UPDATE t1 SET i = i + 1;	-- i = 1
S1/N2: UPDATE t1 SET i = i + 1; -- i = 1
S2/N1: BEGIN;
S2/N2: BEGIN;
S2/N1: DELETE FROM t1 WHERE i = 1; -- delete 1 row since S1/N1 is not committed yet
S2/N2: DELETE FROM t1 WHERE i = 1; -- delete 1 row since S1/N2 is not committed yet
S1/N1: COMMIT;
S1/N2: COMMIT;
S2/N1: COMMIT;
S2/N2: COMMIT;

需要将事务隔离级别设置为 可重复读取。这意味着您需要在 postgresql.conf 中设置它,如下所示:

default_transaction_isolation = 'repeatable read'

1.4.4. 逻辑复制模式

在这种模式下,PostgreSQL 负责复制 每个服务器。要启用此模式,请使用 ‘logical_replication’ 作为 backend_clustering_mode。


backend_clustering_mode = 'logical_replication'

在此模式下,最多可以有 127 个逻辑复制备用服务器。 此外,可能根本没有备用服务器。

这种模式的缺点是,需要考虑 分发读取查询时的复制延迟。可见性 节点之间的一致性也无法保证。也肯定 类型的对象(如 DDL 和大型对象)不会被复制。

1.4.5. Slony 模式

此模式用于将 Pgpool-II 与 Slony-I 耦合。Slony-I 负责 实际数据复制。要启用此模式,请使用 ‘slony’ 作为 backend_clustering_mode。

backend_clustering_mode = 'slony'

在此模式下,您最多可以有 127 个副本服务器。它也是 可能根本没有副本服务器。

这种模式的缺点是,需要考虑 分发读取查询时的复制延迟。可见性 节点之间的一致性也无法保证。也肯定 类型的对象(如 DDL 和大型对象)不会被复制。

引入流式复制和逻辑复制后, 使用 Slony-I 的系统很少。如果没有 特别的原因,不建议使用这种模式。

1.4.6. Raw 模式

在这种模式下,Pgpool-II 不关心数据库同步。 用户有责任让整个系统做有意义的事情。 在该模式下无法进行负载均衡。 要启用此模式,请使用 ‘raw’ 作为 backend_clustering_mode。

backend_clustering_mode = 'raw'

1.5. 后端设置

1.5.1. 后端连接设置

backend_hostname (字符串))
backend_hostname 指定 PostgreSQL 后端为 connected to 的 .它被使用 由 Pgpool-II 进行通信 与服务器一起使用。

对于 TCP/IP 通信,此参数可以采用 hostname 或 IP 地址。如果此 URL 以 slash(/),它指定 Unix 域 通信而不是 TCP/IP;该值是 存储套接字文件的目录。这 backend_hostname为空时的默认行为 (‘’) 用于连接到 Unix 域 套接字。

可以通过在 参数名称 (e.g.backend_hostname0) 的结尾。这 number 称为 “DB node ID”,它从 0. 数据库节点 ID 为 0 的后端将为 称为 “主节点”。定义多个后端时, 即使主节点已关闭(不是 true 在某些模式下)。在本例中,为最年轻的数据库节点 ID alive 将成为新的主节点。

请注意,id 为 0 的 DB 节点没有特殊的 这意味着如果在 Streaming Replication 模式下运行。而 您应该关心数据库节点是 “主节点” 还是 不。有关更多详细信息,请参见 Section 1.8, Section 1.10, Section 1.12 。

如果您打算仅使用 一个 PostgreSQL 服务器,指定 它由 backend_hostname0。

可以通过添加参数行和 重新加载配置文件。但是,现有的 值无法更新,因此您必须 在这种情况下重启 Pgpool-II。

backend_port (整数))
backend_port 指定端口号 的后端。多个后端可以由 在参数名称的末尾添加一个数字 (例如 backend_port0)。如果您计划仅使用 1 个 PostgreSQL 服务器,请通过 backend_port0 指定。

可以通过添加参数行来添加新的后端端口 并重新加载配置文件。但是,现有的 值无法更新,因此您必须 在这种情况下重启 Pgpool-II。

backend_weight (浮点数))
backend_weight 指定负载均衡 的比率。它可以设置为任何整数或 浮点值大于或等于零。 多个后端可以由 在参数名称的末尾添加一个数字 (例如 backend_weight0)。如果您计划只使用一个 PostgreSQL 服务器,通过 backend_weight0 指定。

新backend_weight可以通过以下方式在此参数中添加 重新加载配置文件。但是,这将需要 仅对新建立的客户端会话有效。Pgpool-II V2.2.6, V2.3 或更高版本允许通过重新加载 配置文件。如果您想防止 发送到 standbys 以执行某些管理的任何查询 在 Streaming Replication Mode、Logical Replication Mode 和 Slony 模式下工作。

1.5.2. 后端数据设置

backend_data_directory (字符串))
backend_data_directory 指定 database cluster 目录下。多个后端可以是 通过在参数末尾添加一个数字来指定 名称(例如 backend_data_directory0)。如果您计划使用 只有一个 PostgreSQL 服务器,通过 backend_data_directory0。此参数由在线恢复使用。 如果您不使用在线恢复,则无需设置它。

可以通过添加参数data_directory行并重新加载 配置文件。但是,现有值无法更新,因此 你必须在 那个案子。

backend_flag (字符串))
backend_flag 控制各种后端 行为。可以通过添加 参数名称末尾的 number (例如 backend_flag0)。如果您计划只使用一个 PostgreSQL 服务器,请通过 backend_flag0 指定。

可以通过添加参数行并重新加载 配置文件。目前允许以下操作。多个标志可以 使用 “|” 指定。

表 1-4.后端标志

Flag描述
ALLOW_TO_FAILOVER允许故障转移或分离后端。这 是默认值。不能指定 同时DISALLOW_TO_FAILOVER。
DISALLOW_TO_FAILOVER不允许故障转移或分离后端 当您通过以下方式保护后端时,这非常有用 使用 HA (High Availability) 软件,例如 Heartbeat 或 Pacemaker。不能指定 ALLOW_TO_FAILOVER同时。
ALWAYS_PRIMARY这仅在流式复制中有用 模式。关于 流式复制模式。如果此标志设置为 其中之一 backends,Pgpool-II 将 未通过检查找到主节点 backend 的相反,请始终将 flag 设置为主节点。这适用于 包括 Amazon Aurora 在内的系统 PostgreSQL 兼容性,它 固定主服务器名称。
可以通过重新加载来更改此参数 Pgpool-II 配置。

backend_application_name (字符串))
backend_application_name 指定 接收 WAL 日志的 walreceiver 的应用程序名称 从主节点。因此,在流式之外 replication 模式,则无需设置该参数。 如果您想显示 “replication_state”和“replication_sync_state”列 在 SHOW POOL NODES 和 pcp_node_info 命令中。 此外,delay_threshold_by_time 要求 这个参数也是如此。

例如,假设主节点是 backend0(其主机名 是 “host0”),则有问题的备用节点是 backend1,而 backend_application_name backend1 是 “server1”,则 postgresql.conf 的primary_conninfo参数应如下所示:

primary_conninfo = 'host=host0 port=5432 user=postgres application_name='server1''

recovery_1st_stage_command 应该 生成 Parameter。有关以下内容,请参见 Section 8.2.7.8 命令的完整示例。

可以通过重新加载来更改此参数 Pgpool-II 配置。

1.6. 连接池

Pgpool-II 维护已建立的 连接到 PostgreSQL 服务器,并在 具有相同属性的新连接(即用户名、数据库、 protocol version)的它减少了连接开销, 并提高系统的整体吞吐量。

1.6.1. 连接池设置
connection_cache (布尔值))
设置为 on 时缓存到后端的连接。默认值为 on。但是,即使 connection_cache 处于打开状态,也不会缓存与 template0、template1、postgres 和 regression 数据库的连接。

如果你更改了这个值,你需要重启 Pgpool-II。

max_pool (整数))
缓存连接的最大数量 在每个 Pgpool-II 子级中 过程。Pgpool-II 重用了 cached connection(如果传入连接正在连接) 添加到具有相同用户名和相同 运行时参数。如果没有,Pgpool-II 会创建一个新的 连接到后端。如果缓存的 连接数超过 max_pool,则最早的连接将 被丢弃,并将该槽用于新连接。

默认值为 4。请注意,数量 从 Pgpool-II 进程到后端的连接可能达到 num_init_children * max_pool 总计。

此参数只能在服务器启动时设置。

listen_backlog_multiplier (整数))
指定从前端到 Pgpool-II 的连接队列长度。队列长度(实际上是 listen() 系统调用的 “backlog” 参数)定义为 listen_backlog_multiplier * num_init_children。

注意: 某些系统具有 listen() 系统调用的 backlog 参数的上限。 有关详细信息,请参阅 num_init_children。
默认值为 2。

此参数只能在服务器启动时设置。

serialize_accept (布尔值))
当设置为 on 时,Pgpool-II 启用序列化 在传入的客户端连接上。 在没有序列化的情况下,操作系统内核会唤醒所有 Pgpool-II 子进程来执行 accept() 和其中一个 实际获取传入连接。这里的问题是,因为我的孩子 进程唤醒时,会发生大量的上下文切换,并且 性能受到影响。

这种现象是一个众所周知的经典问题,称为 “雷霆群问题”。这可以通过 序列化 accept() 调用,这样只有一个 Pgpool-II 进程被唤醒 对于传入连接,要执行 accept() 。

但是序列化有其自身的开销,建议使用 仅用于较大的 num_init_children 值。 对于少数num_init_children, serialize accept 可能会降低性能,因为 序列化开销。

注意: 建议在决定是否使用 serialize_accept 之前先做一个基准测试,因为相关性 num_init_children 和 serialize_accept 在不同的环境中可能有所不同。

例 1-1.使用 pgbench 决定是否应使用 serialize_accept

要运行 pgbench,请使用以下内容 命令。

pgbench -n -S -p 9999 -c 32 -C -S -T 300 test

这里,-C 告诉 pgbench 连接 到数据库。-c 32 指定到 Pgpool-II 的并发会话数。 您应该根据系统的要求进行更改。 pgbench 完成后,检查 “包括建立的联系”。

注意: 启用 child_life_time 后,serialize_accept 不起作用。如果需要,请确保将 child_life_time 设置为 0 以打开 serialize_accept。 如果你担心 Pgpool-II 进程内存泄漏 或者任何潜在的问题,你可以改用 child_max_connections。 这纯粹是一个实现限制,将来可能会删除。

默认值为 off。

此参数只能在服务器启动时设置。

child_life_time (整数))
指定 Pgpool-II 子进程在空闲时终止它的时间(以秒为单位)。新的子进程 当 Pgpool-II 立即生成时 因 child_life_time 而终止。child_life_time 是一种防止 Pgpool-II 子项中的内存泄漏和其他意外错误。

注意: child_life_time 不适用于 尚未接受任何连接的进程。

注: 启用 child_life_time 后,serialize_accept 将失效。

默认值为 300(5 分钟),将其设置为 0 将禁用该功能。

此参数只能在服务器启动时设置。

client_idle_limit (整数))
指定在客户端保持空闲状态时断开客户端连接的时间(以秒为单位) 自上次查询以来。 这对于防止 Pgpool-II 的子节点被懒惰的客户端或损坏的 TCP/IP 占用很有用 客户端和 Pgpool-II 之间的连接。

注意: client_idle_limit 在 在线恢复的第二阶段。

默认值为 0,这将关闭该功能。

这个参数可以通过重新加载 Pgpool-II 配置来改变。 您还可以使用 PGPOOL SET 命令来更改 this 参数。

child_max_connections (整数))
指定 Pgpool-II 子进程的生命周期,根据它可以接收的客户端连接数。Pgpool-II 将终止子进程 在服务child_max_connections客户端之后 connections,并立即生成一个新的子进程来取代它。

child_max_connections 在非常繁忙的服务器上很有用, 其中 child_life_time 和 connection_life_time 永远不会触发。防止 PostgreSQL 服务器获取 太大了。

默认值为 0,这将关闭该功能。

此参数只能在服务器启动时设置。

connection_life_time (整数))
指定终止缓存连接的时间(以秒为单位) 添加到 PostgreSQL 后端。此时间用作缓存连接过期时间。

默认值为 0,这意味着不会断开缓存的连接。

此参数只能在服务器启动时设置。

reset_query_list (字符串))
指定要发送的 SQL 命令,用于重置后端连接 退出用户会话时。可以通过分隔每个命令来指定多个命令 通过 “;”。

可用的命令因 PostgreSQL 版本而异。 以下是在不同 PostgreSQL 版本上reset_query_list的一些推荐设置。 但是请注意,应始终包含 ABORT 命令。

表 1-5.在不同 PostgreSQL 版本上reset_query_list的推荐设置

PostgreSQL versionreset_query_list
7.1 or earlier‘ABORT’
7.2 to 8.2‘ABORT; RESET ALL; SET SESSION AUTHORIZATION DEFAULT’
8.3 or later‘ABORT; DISCARD ALL’
注意:当不在 7.4 或更高版本的 PostgreSQL 版本的事务块中时,不会发出 “ABORT”。

默认值为 'ABORT;全部丢弃”。

这个参数可以通过重新加载 Pgpool-II 配置来改变。

1.7. 错误报告和日志记录

1.7.1. 记录位置

log_destination (字符串))
Pgpool-II 支持两个目的地 用于记录 Pgpool-II 消息。 支持的日志目标是 stderr 和 syslog。您也可以将此参数设置为列表 的所需日志目标,如果需要日志消息,请用逗号分隔 在多个目的地上。

   #for example to log on both syslog and stderrlog_destination = 'syslog,stderr'

默认是仅记录到 stderr 。

注意: 在某些系统上,您需要更改 系统的 syslog 守护进程,以便使用 syslog 选项 为了log_destination。Pgpool-II 可以记录到 syslog 设施 LOCAL0 到 LOCAL7 (请参阅syslog_facility),但大多数平台上的默认 syslog 配置将丢弃所有此类消息。 您需要添加如下内容:

 local0.*    /var/log/pgpool.log

到 syslog 守护程序的配置文件中,使其正常工作。

这个参数可以通过重新加载 Pgpool-II 配置来改变。

logging_collector (布尔值))
此参数启用日志记录收集器,这是一个后台进程,用于捕获 记录发送到 stderr 的消息,并将其重定向到日志文件中。

注意: 可以在不使用日志记录收集器的情况下记录到 stderr;日志消息将 只需转到服务器的 stderr 指向的任何位置即可。但是,该方法仅适用于 对于低日志量,因为它没有提供轮换日志文件的便捷方法。

这个参数只能在 Pgpool-II 启动时设置。

logging_collector 在 Pgpool-II V4.2 之前不可用。

log_directory (字符串))
启用 logging_collector 后,此参数将确定 将在其中创建日志文件的目录。

默认值为 /tmp/pgpool_logs。

这个参数只能在 Pgpool-II 启动时设置。

log_filename (字符串))
启用 logging_collector 后,此参数会设置 创建的日志文件的文件名。该值被视为 strftime 模式,因此 %-escapes 可用于指定时变 文件名。 支持的 %-escapes 类似于 Open Group 的 strftime规范中列出的 %-escapes。

如果指定不带转义符的文件名,则应计划使用日志轮换 实用程序,以避免最终填满整个磁盘。

默认值为 pgpool-%Y-%m-%d_%H%M%S.log。

这个参数只能在 Pgpool-II 启动时设置。

log_file_mode (整数))
此参数设置启用 logging_collector 时日志文件的权限。参数值应为以 接受 chmod 和 umask 系统调用。

注意: 要使用惯用的八进制格式,数字必须以 0(零)开头。

这个参数只能在 Pgpool-II 启动时设置。

log_rotation_age (整数))
启用 logging_collector 后,此参数将确定 使用单个日志文件的最长时间,之后会出现新日志 文件。如果指定此值时没有单位,则 它以分钟为单位。默认值为 24 小时。

设置为 0 可禁用基于时间创建新日志文件。

这个参数只能在 Pgpool-II 启动时设置。

log_rotation_size (整数)
启用 logging_collector 后,此参数将确定 单个日志文件的最大大小。在这么多 KB 之后 发出到日志文件中,将创建一个新的日志文件。

设置为 0 可禁用基于大小创建新日志文件。

这个参数只能在 Pgpool-II 启动时设置。

log_truncate_on_rotation (布尔值))
启用 logging_collector 后, 这个参数会导致 Pgpool-II 截断(覆盖), 而不是附加到任何同名的现有日志文件。 但是,仅当打开新文件时才会发生截断,因为 基于时间的轮换,而不是在 startup 或基于大小的轮换期间。 关闭时,在所有情况下都将附加预先存在的文件。 例如,将此设置与pgpool-%H.log等log_filename结合使用将导致生成 24 小时日志 文件,然后循环覆盖它们。

这个参数只能在 Pgpool-II 启动时设置。

syslog_facility (枚举))
另请参阅系统的 syslog 守护程序的文档。 启用日志记录到 syslog 后, 此参数确定要使用的 syslog “facility”。 您可以选择 LOCAL0、LOCAL1、LOCAL2、LOCAL3、LOCAL4、LOCAL5、LOCAL6、LOCAL7; 默认值为 LOCAL0。 另请参阅系统的 syslog 守护程序的文档。

这个参数可以通过重新加载 Pgpool-II 配置来改变。

syslog_ident (字符串))
启用日志记录到 syslog 后,此参数将确定 用于识别 syslog 日志中 Pgpool-II 消息的程序名称。默认为 pgpool

这个参数可以通过重新加载 Pgpool-II 配置来改变。

1.7.2. 何时记录
client_min_messages (enum)
控制发送到客户端的最小消息级别。 有效值为 DEBUG5、DEBUG4、DEBUG3、DEBUG2、DEBUG1、LOG、NOTICE、WARNING 和 ERROR。每个级别包括 它之后的所有级别。默认值为 NOTICE。

这个参数可以通过重新加载 Pgpool-II 配置来改变。 您还可以使用 PGPOOL SET 命令来更改 this 参数。

log_min_messages (枚举))
默认值为 WARNING。 控制向 log 发出的最小消息级别。 有效值为 DEBUG5、DEBUG4、DEBUG3、DEBUG2、DEBUG1、INFO、NOTICE、WARNING、ERROR、LOG、FATAL和 和 PANIC。 每个级别都包含其后的所有级别。 默认值为 WARNING。

这个参数可以通过重新加载 Pgpool-II 配置来改变。 您还可以使用 PGPOOL SET 命令来更改 this 参数。

5.7.3. 记录什么
log_statement (布尔值))
设置为 on,将所有 SQL 语句打印到日志中。

这个参数可以通过重新加载 Pgpool-II 配置来改变。 您还可以使用 PGPOOL SET 命令来更改 this 参数。

log_per_node_statement (布尔值))
与 log_statement 类似,不同之处在于它会打印 logs 的日志。确保 复制或负载平衡正在运行。

这个参数可以通过重新加载 Pgpool-II 配置来改变。 您还可以使用 PGPOOL SET 命令来更改 this 参数。

notice_per_node_statement (布尔值))
与 log_per_node_statement 类似,但 它将每个数据库节点的语句日志分别打印为 一条 NOTICE 消息。使用 default client_min_messages 设置(即 是 NOTICE),日志消息将打印在客户端的终端上 也。这对客户来说很方便,因为它不需要 访问 Pgpool-II 日志文件。注意 那 与 log_per_node_statement 不同,notice_per_node_statement 不打印内部查询(例如,系统目录查询)。 这是因为此功能旨在用于测试 也。由于内部查询往往是不确定的,因此 在测试中打印它们没有帮助。出于同样的原因, 不打印后端进程 ID。

这个参数可以通过重新加载 Pgpool-II 配置来改变。 您还可以使用 PGPOOL SET 命令来更改 this 参数。

log_client_messages (布尔值))
设置为 on,将客户端消息打印到日志中。

这个参数可以通过重新加载 Pgpool-II 配置来改变。 您还可以使用 PGPOOL SET 命令来更改 this 参数。

log_hostname (布尔值))
设置为 on,则打印主机名而不是 IP 地址 在 ps 命令结果和连接日志中 (当 log_connections 处于打开状态时)。

这个参数可以通过重新加载 Pgpool-II 配置来改变。

log_connections (布尔值))
设置为 on,则打印从日志到日志的所有客户端连接。

这个参数可以通过重新加载 Pgpool-II 配置来改变。

log_disconnections (布尔值))
设置为 on,则将所有客户端连接终止打印到日志中。

这个参数可以通过重新加载 Pgpool-II 配置来改变。

log_pcp_processes (布尔值))
设置为 on,启用有关正常 PCP 进程的日志记录 fork 和 exit 状态。默认值为 on。

这个参数可以通过重新加载 Pgpool-II 配置来改变。

log_error_verbosity (enum)
控制为记录的每条消息发出的详细信息量。 有效值为 TERSE、DEFAULT 和 VERBOSE。 每个添加更多字段 添加到显示的消息中。TERSE 不包括 DETAIL、HINT、QUERY 和 CONTEXT 错误信息的日志记录。

这个参数可以通过重新加载 Pgpool-II 配置来改变。 您还可以使用 PGPOOL SET 命令来更改 this 参数。

log_line_prefix (字符串))
这是一个 -style 字符串,在 每个对数行。% 字符开始被替换的 “转义序列” 信息概述如下。 所有无法识别的转义都将被忽略。其他字符将直接复制到 Log 行。默认值为 '%m: %a pid %p: ',它打印时间戳、应用程序名称和进程 ID。printf

表 1-6.log_line_prefix 转义选项

EscapeEffect
%aApplication name. The initial value for child (session process) is “child”. If Clients set application name (either in the startup message or by using SET command), application name will be changed accordingly. In other types of process, application name is a hard coded string.
%pProcess ID (PID)
%PProcess name
%tTime stamp without milliseconds
%mTime stamp with milliseconds
%dDatabase name
%uUser name
%lLog line number for each process
%%‘%’ character
表 1-7.各种进程中的应用程序名称
Process typeapplication name
mainmain
childchild
streaming replication delay check workersr_check_worker
watchdog heart beat senderheart_beat_sender
watchdog heart beat receiverheart_beat_receiver
watchdogwatchdog
watchdog life checklife_check
follow primary childfollow_child
watchdog utilitywatchdog_utility
pcp mainpcp_main
pcp childpcp_child
health check processhealth_check%d (%d is replaced with backend node id)
logger processlogger (Note that the application name “logger” will not be output to the log file managed by logger process)

这个参数可以通过重新加载 Pgpool-II 配置来改变。

1.8. 负载均衡

SELECT 查询的 Pgpool-II 负载均衡 适用于除 Raw 模式之外的任何群集模式。当启用时,Pgpool-II 将写入查询发送到本地复制模式下的主节点,所有 Replication 模式下的后端节点,其他查询会获得 load 在所有后端节点之间保持平衡。负载到哪个节点 平衡机制发送读取查询是在会话中决定的 Start time 的 a 值,除非指定了 statement_level_load_balance,否则在会话结束之前不会更改。然而 但也有一些例外。有关更多详细信息,请参阅下文。

注意: 发送到主节点或由于无法平衡而复制的查询是 也考虑在负载平衡算法中。

注意: 您可以检查哪个数据库节点被分配为负载均衡 node 的 SET POOL NODES 进行分配。

1.8.1. 负载均衡的条件

对于要进行负载均衡的查询,以下所有要求 必须满足:

PostgreSQL 版本 7.4 或更高版本

也 在流式复制模式、本机复制模式或快照隔离模式下

查询不得位于显式声明的事务中 (即不在 BEGIN ~ END 块中)

但是,如果满足以下条件,则可以进行负载均衡 即使在显式事务中

事务隔离级别不是 SERIALIZABLE

事务尚未发出写入查询(直到写入 query 的 intent 请求,则可以进行负载均衡。这里 “write query” 表示非 SELECT DML 或 DDL。在 Pgpool-II 4.1 之前, 具有 write 或 read_only函数列表不被视为写入查询。

如果 write 且 read_only function list 为空,则 SELECT 具有 非 volatile 的函数被视为只读查询。

它不是 SELECT INTO

它不是 SELECT FOR UPDATE 也不是 FOR SHARE

它以 “SELECT” 或 COPY TO STDOUT、EXPLAIN、 解释 分析 选择…ignore_leading_white_space = true 将忽略前导空格。 (使用 write_function_list 或 read_only_function_list 中指定的写入函数的 SELECT 除外)

在流复制模式下,除上述条件外,还必须满足以下条件:

不使用临时表(不复制临时表)

不使用 unlogged 表(不复制 unlogged 表)

不使用系统目录(系统目录信息为 important 且最好避免复制延迟)

注意: 您可以通过插入任意 comments 的 SELECT 查询:

/REPLICATION/ SELECT …

如果要在不抑制负载均衡的情况下使用注释,可以将 allow_sql_comments 设置为 on。 另请参阅replicate_select。

注意: JDBC 驱动程序具有 autocommit 选项。如果 autocommit 为 false,则 JDBC 驱动程序自行发送 “BEGIN” 和 “COMMIT”。在这种情况下 将应用上述有关负载均衡的相同限制。

1.8.2. 编写查询可能会影响负载均衡

通常,如果满足某些条件,则读取查询会进行负载均衡 都满足了。但是,编写查询可能会影响负载 平衡。这里的 “writing queries” 是指除 下面:

SELECT/WITH,而无需编写函数。 volatile 函数被视为写入函数。 您可以使用 write_function_list 或 read_only_function_list 定义自己的编写函数。

SELECT/WITH 不带 FOR UPDATE/SHARE

不带 DML 语句的 WITH

复制到 STDOUT

解释

EXPLAIN ANALYZE 且查询为 SELECT 不包括写入函数

显示

如果出现写入查询,则后续读取查询可能不是 负载均衡。即发送到主节点(在 streaming 中 replication 模式)或主节点(在其他模式下),具体取决于 disable_load_balance_on_write的设置。

1.8.3. 流式复制中的负载均衡

使用流复制和热备用时,请务必 确定哪个查询可以发送到主数据库或备用数据库, 以及哪一个不应该被送到备用数据库。仔细的 Pgpool-II 的 Streaming Replication 模式 处理这个。

我们通过查看来区分哪个查询应该发送到哪个节点 在查询本身。

这些查询应仅发送到主节点

插入、更新、删除、复制自、截断、创建、删除、更改、注释

选择。。。用于分享 |更新

事务隔离级别 SERIALIZABLE 中的 SELECT

LOCK 命令比 ROW EXCLUSIVE MODE 更严格

DECLARE, FETCH, CLOSE

显示

一些事务性命令:

BEGIN READ WRITE、START TRANSACTION 读写

设置事务读写,将会话特征设置为事务读写

设置 transaction_read_only = 关闭

两阶段提交命令:PREPARE TRANSACTION、COMMIT PREPARED、ROLLBACK PREPARED

倾听、取消倾听、通知

真空

一些序列函数(nextval 和 setval)

大型对象创建命令

多语句查询(单行上有多个 SQL 命令)

这些查询可以发送到主节点和备用节点。 如果启用了负载均衡,则可以将这些类型的查询发送到备用节点。 但是,如果设置了 delay_threshold 并且复制延迟高于 delay_threshold,则会将查询发送到主节点。

上面未列出 SELECT

复制到 STDOUT

解释

EXPLAIN ANALYZE 且查询为 SELECT 不包括写入函数

显示

这些查询将同时发送到主节点和备用节点

设置

丢弃

全部解除分配

SAVEPOINT(以及相关命令,例如 RELEASE SAVEPOINT)

在显式事务中:

事务启动命令(如 BEGIN)将发送到主节点 和备用节点。

遵循 SELECT 和一些可以发送到两者的其他查询 primary 或 standby 在事务中或在 standby 节点上执行。

发送无法在备用数据库上执行的命令,例如 INSERT 到主节点。 在其中一个命令之后,甚至 SELECT 也会被发送到主节点 这是因为这些 SELECT 可能希望立即看到 INSERT 的结果。 此行为一直持续到事务关闭或中止。

在扩展协议中,可以确定查询是否可以 在解析查询时发送到 standby 或不处于负载均衡模式。 规则与非扩展协议的规则相同。 例如,将 INSERT 发送到主节点。 接下来的 bind、describe 和 execute 也将被发送到主节点。

注意: 如果 SELECT 语句的解析因负载而发送到备节点 平衡,然后一个 DML 语句,比如 INSERT,被发送到 Pgpool-II, 那么解析的 SELECT 必须在主节点上执行。 因此,我们在主节点上重新解析 SELECT。

最后,Pgpool-II 的解析器认为是 错误发送到主节点。

1.8.4. 负载均衡设置

load_balance_mode (布尔值))
当设置为 on 时,Pgpool-II 启用 对传入的 SELECT 查询进行负载均衡。 即来自客户端的 SELECT 查询被分发到 配置的 PostgreSQL 后端。 默认值为 on。

此参数只能在服务器启动时设置。

ignore_leading_white_space (布尔值))
当设置为 on 时,Pgpool-II 会忽略 负载均衡中 SQL 查询开头的空格。 如果与 DBI/DBD:Pg 等 API 一起使用,则非常有用,其中添加了 空格。

这个参数可以通过重新加载 Pgpool-II 配置来改变。

read_only_function_list (字符串))
指定不更新数据库的函数名称的逗号分隔列表。SELECT 包括 此列表中未指定的函数不进行负载均衡。 这些将在复制模式下的所有数据库节点之间复制。 仅在 Other 模式下发送到主节点。

您可以使用正则表达式来匹配函数名称, 其中 ^ 和 $ 会自动添加到其中。

例 1-2.使用正则表达式

如果您已为所有只读函数添加前缀 使用 ‘get_’ 或 ‘select_’ 时,您可以 按如下方式设置read_only_function_list:

read_only_function_list = 'get_.*,select_.*'

注意: 如果查询可以引用具有和不具有架构的函数 qualification 时,您必须添加两个条目(带和不带 Schema name) 的 Schema 名称)。

#For example:
#If the queries sometime use "f1()" and other times "public.f1()"
#to refer the function f1 then the read_only_function_list
#would be configured as follows.read_only_function_list = "f1,public.f1"

注意: 如果此参数和 write_function_list 为空字符串,则将检查函数的 volatile 属性。如果 属性是 volatile 的,函数被视为写入 功能。这是方便且推荐的方法。然而,这个 第一次需要对 System Catalog 进行一次额外查询 time (在下次使用缓存的查询结果时,并且没有额外的 查询)。如果您不想发送此类查询,请 可以继续使用这个参数。

这个参数可以通过重新加载 Pgpool-II 配置来改变。

write_function_list (字符串))
指定以逗号分隔的函数名称列表,这些函数名称将更新数据库。 包含此列表中指定函数的 SELECT 为 未进行负载均衡。 这些将在复制模式下的所有数据库节点之间复制。 仅在 Other 模式下发送到主节点。

您可以使用正则表达式来匹配函数名称, 其中 ^ 和 $ 会自动添加到其中。

例 1-3.使用正则表达式

如果您已为所有更新函数添加前缀 使用 ‘set_’, ‘update_’, ‘delete_’ 或 ‘insert_’,您可以 设置write_function_list如下:

write_function_list = 'nextval,setval,set_.*,update_.*,delete_.*,insert_.*'

注意: 查询是否可以引用具有和不具有架构的函数 qualification 那么你必须添加两个条目(带和不带 Schema name) 的 Schema 名称)。

#For example:
#If the queries sometime use "f1()" and other times "public.f1()"
#to refer the function f1 then the write_function_list
#would be configured as follows.write_function_list = "f1,public.f1"

注意: write_function_list 和 read_only_function_list 是互斥的,在配置中只能设置两个列表中的一个。

例 1-4.使用 nextval() 和 setval() 进行配置以进入正确的后端

在 Pgpool-IIV3.0 之前,nextval() 和 setval() 被称为写入数据库的函数。 您可以通过设置 write_function_list 和 read_only_function_list 来配置它,如下所示

read_only_function_list = ''
write_function_list = 'nextval,setval,lastval,currval'

注意: 除了 nextval() 和 setval() 之外,PostgreSQL 还包含 lastval() 和 currval()。 虽然 lastval() 和 currval() 不是写入函数类型,但建议将 lastval() 和 currval() 视为写入函数,以避免在以下情况下发生错误 这些函数被意外地进行了负载均衡。

注意: 如果此参数和 read_only_function_list 为空字符串,则将检查函数的 volatile 正确性。如果 属性是 volatile 的,函数被视为写入 功能。这是方便且推荐的方法。然而,这个 第一次需要对 System Catalog 进行一次额外查询 time (在下次使用缓存的查询结果时,并且没有额外的 查询)。如果您不想发送此类查询,请 可以继续使用这个参数。

这个参数可以通过重新加载 Pgpool-II 配置来改变。

primary_routing_query_pattern_list (字符串))
指定以分号分隔的 SQL 模式列表,该 SQL 模式为 应发送到主节点。 与此列表中指定的模式匹配的 SQL 为 未进行负载均衡。 除 Only Native Replication 模式外。

您可以使用正则表达式来匹配 SQL 模式, 其中 ^ 和 $ 会自动添加到其中。 在正则表达式中使用特殊字符时 (如 “'”、“ ”;“、 ”*“、” “(”、 “)”、 “|”、 “+”、 “.”、 “\”、 “?”、 “^”、 “$”、 “{”、“}”、“{”或“}”等) 在 SQL 模式中,您需要使用 “\” 对它们进行转义。 此参数中指定的 SQL 模式不区分大小写。

例 1-5.使用正则表达式

如果以下 SQL 只应发送到主节点,您可以 按如下方式设置primary_routing_query_pattern_list:

SELECT * FROM table_name1;

从 table_name2中选择 col1, col2 其中 col1 LIKE ‘%a%’;

SQL 包括 table_name3

primary_routing_query_pattern_list = 'SELECT \* FROM table_name1\;;SELECT col1, col2 FROM table_name2 WHERE col1 LIKE \'%a%\'\;;.*table_name3.*'

注意: 如果 SQL 同时匹配 write_function_list 和 read_only_function_list,则忽略read_only_function_list设置,并且应仅将 SQL 发送到主节点。

根据 SQL 模式,使用此功能时,性能可能会降低 1-2%。

这个参数可以通过重新加载 Pgpool-II 配置来改变。

user_redirect_preference_list (字符串))
指定 “user-name:node id (ratio)” 对的列表 将 SELECT 查询发送到特定后端 节点。 负载均衡比率指定一个介于 0 和 1 之间的值。默认值为 1.0。

例如,通过指定 “user1:1(0.5)”,Pgpool-II 会将 50% 的 SELECT 查询重定向到 ID 为 1 的后端节点 用户 user1 的连接。

您可以指定多个 “user-name:node id (ratio)” 对 使用逗号 (,) 分隔它们。

用户名也接受正则表达式。 您可以使用特殊关键字作为节点 ID。 如果指定了 “primary”,则查询将发送到主节点,并且 如果指定了 “standby”,则随机选择其中一个备用节点 基于负载均衡比率。

例 1-6.使用 user_redirect_preference_list

如果要配置以下 SELECT 查询路由规则:

从连接路由所有 SELECT 查询 使用用户 postgres 到主后端节点。

从连接中路由 30% 的 SELECT 查询 使用用户 user0 或 user1 到 ID 为 1 的后端节点。 其他 70% 的 SELECT 查询将发送到其他后端节点。

从连接路由所有 SELECT 查询 使用用户 user2 到备用后端节点。

然后user_redirect_preference_list将配置如下:

user_redirect_preference_list = 'postgres:primary,user[01]:1(0.3),user2:standby'

这个参数可以通过重新加载 Pgpool-II 配置来改变。

database_redirect_preference_list (字符串))
指定 “database-name:node id(ratio)” 对的列表 将 SELECT 查询发送到特定后端 节点。 负载均衡比率指定一个介于 0 和 1 之间的值。默认值为 1.0。

例如,通过指定 “test:1(0.5)”,Pgpool-II 会将 50% 的 SELECT 查询重定向到 ID 为 1 的后端节点 与 test 数据库的连接。

您可以指定多个 “database-name:node id(ratio)” 对 使用逗号 (,) 分隔它们。

数据库名称也接受正则表达式。 您可以使用特殊关键字作为节点 ID。 如果指定了 “primary”,则查询将发送到主节点,并且 如果指定了 “standby”,则随机选择其中一个备用节点 基于负载均衡比率。

例 1-7.使用 database_redirect_preference_list

如果要配置以下 SELECT 查询路由规则:

将 postgres 数据库上的所有 SELECT 查询路由到主后端节点。

将 mydb0 或 mydb1 数据库上的 30% SELECT 查询路由到 ID 为 1 的后端节点。 其他 70% 的 SELECT 查询将发送到其他后端节点。

将 mydb2 数据库上的所有 SELECT 查询路由到备用后端节点。

然后database_redirect_preference_list将配置如下:

database_redirect_preference_list = 'postgres:primary,mydb[01]:1(0.3),mydb2:standby'

这个参数可以通过重新加载 Pgpool-II 配置来改变。

app_name_redirect_preference_list (字符串))
指定 “application-name:node id(ratio)” 对的列表 将 SELECT 查询发送到特定后端 节点。 负载均衡比率指定一个介于 0 和 1 之间的值。默认值为 1.0。 您可以指定多个 “application-name:node id(ratio)” 对 使用逗号 (,) 分隔它们。

注意: 在 PostgreSQL V9.0 或更高版本中,“应用程序名称”是指定的名称 由 Client 端连接到 Database 时。

例如,psql 命令的应用程序名称为 “psql”。

注意: Pgpool-II 可以识别应用程序名称 仅在 start-up 数据包中指定。 尽管客户端可以提供应用程序名称 但是 Pgpool-II 不会考虑进行查询路由。

数据库名称也接受正则表达式。 您可以使用特殊关键字作为节点 ID。 如果指定了 “primary”,则查询将发送到主节点,并且 如果指定了 “standby”,则随机选择其中一个备用节点 基于负载均衡比率。

例 1-8.使用 app-name_redirect_preference_list

如果要配置以下 SELECT 查询路由规则:

将所有 SELECT 从 psql 客户端路由到主后端节点。

将 30% 的 SELECT 查询从 myapp1 客户端路由到 ID 为 1 的后端节点。其他 70% 的 SELECT 查询将发送到其他后端节点。

将所有 SELECT 查询从 myapp2 客户端路由到备用后端节点。

然后 app_name_redirect_preference_list 将按如下方式配置:

app_name_redirect_preference_list = 'psql:primary,myapp1:1(0.3),myapp2:standby'

注意: user_redirect_preference_list、database_redirect_preference_list 和 app_name_redirect_preference_list 的优先级是:

app_name_redirect_preference_list > database_redirect_preference_list > user_redirect_preference_list

例如,如果您设置 database_redirect_preference_list = ‘postgres:standby(1.0)’ 和 app_name_redirect_preference_list = ‘myapp1:primary(1.0)’, 来自 postgres 数据库上应用程序 myapp1 的所有 SELECT 都将发送到主后端节点。

注意: 通过指定 user_redirect_preference_list、database_redirect_preference_list 和 app_name_redirect_preference_list, 当多个数据库名称和应用程序名称匹配时, 将使用第一个设置。

例如,如果您设置 database_redirect_preference_list = ‘postgres:primary,postgres:standby’,则将使用 “postgres: primary”。

谨慎
JDBC 驱动程序 PostgreSQL-9.3 及更早版本 不会在启动数据包中发送应用程序名称,即使 应用程序名称是使用 JDBC 驱动程序选项 “ApplicationName” 和 “assumeMinServerVersion=9.0” 指定的。 因此,如果您想通过 JDBC 使用 app_name_redirect_preference_list 功能,请使用 PostgreSQL-9.4 或更高版本的驱动程序。

这个参数可以通过重新加载 Pgpool-II 配置来改变。

allow_sql_comments (布尔值))
当设置为 on 时,Pgpool-II 在识别负载均衡时忽略 SQL 注释 或查询缓存。 当此参数设置为 off 时,SQL 注释 可以有效地防止查询 负载均衡或缓存(Pgpool-II V3.4 之前的行为)。

这个参数可以通过重新加载 Pgpool-II 配置来改变。 您还可以使用 PGPOOL SET 命令来更改 this 参数。

disable_load_balance_on_write (字符串))
指定写入查询出现后的负载均衡行为。 此参数在流式复制中特别有用 模式。当写入查询发送到主服务器时, 更改将应用于备用服务器,但有时间 滞后。因此,如果客户端在写入后立即读取同一行 查询中,客户端可能无法看到 排。如果这是问题所在,则 Client 端应始终读取数据 从主服务器。但是,这实际上会禁用 负载平衡,这会导致性能降低。这 参数允许对 not-clustering-aware 应用程序兼容性和 性能。

如果此参数设置为 off,则读取 即使出现写入查询,查询也会进行负载均衡。这 提供最佳的负载平衡性能,但客户端可能会看到 较旧的数据。这对于 PostgreSQL 参数 synchronous_commit = ‘remote_apply’,或 在本机复制模式下,因为没有复制 延迟。

如果此参数设置为 transaction,并且写入查询出现在显式事务中, 后续读取查询不会进行负载均衡,直到 交易结束。请注意,读取查询不在 explicit transaction 不受 parameter 的影响。这 在大多数情况下,设置会提供最佳平衡,您应该 从这里开始。这是 Pgpool-II 3.7 或更早版本中的默认和相同的行为。

如果设置了该参数 trans_transaction和编写查询 出现在显式事务中,后续读取查询 在事务和后续事务中不进行负载均衡 explicit 事务,直到会话结束。所以这个 参数对于较旧的应用程序更安全,但提供的更少 性能比交易。请注意 不在显式事务中的读取查询不是 受 parameter 影响。

如果该参数设置为 always 且 写入查询出现,后续读取查询不加载 无论他们处于 显式事务。这给出了最高的 与非集群感知应用程序的兼容性以及 最低性能。

如果这个参数被设置为 dml_adaptive Pgpool-II 跟踪 WRITE 语句中引用的每个 TABLE。 显式事务,并且不会对后续的 READ 查询它们正在读取的 TABLE 是否之前被修改过 在同一笔交易中。 可以配置表上的依赖函数、触发器和视图 使用 dml_adaptive_object_relationship_list

dml_adaptive_object_relationship_list (字符串))
为了防止 READ 依赖对象的负载均衡,您可以指定对象名称 后跟冒号 (:) 和逗号 (,) 分隔的依赖对象名称列表。“[对象]:[依赖对象]”在 WRITE 语句发出后的显式事务块中,这将阻止 对包含依赖对象引用的任何 READ 语句进行负载平衡。

例 1-9.配置 dml 自适应对象关系

如果您在 table_1 上安装了触发器,该触发器对每个触发器执行 table_2 INSERT 在 table_1。然后,您需要确保 读取table_2不得在同一事务中进行负载均衡 在 INSERT 后转换为 table_1。 对于此配置,您可以设置

dml_adaptive_object_relationship_list = ‘table_1:table_2’

此参数仅对 disable_load_balance_on_write=‘dml_adaptive’ 有效
注意: 要配置对函数的依赖关系, 该函数必须存在于 write_function_list

statement_level_load_balance (布尔值)
当设置为 on 且 load_balance_mode 设置为 on 时,将为每个读取查询确定负载均衡节点。 当设置为 off 时,负载均衡节点在会话开始时决定 ,并且在会话结束之前不会更改。 例如,在使用连接池的应用程序中,保持连接 对后端服务器开放,因为会话可能会长时间保持, 负载均衡节点在会话结束之前不会更改。 在此类应用程序中,启用 statement_level_load_balance 时, 可以决定每个查询的负载均衡节点,而不是每个会话的负载均衡节点。 默认值为 off。

注意: 在流式复制模式下,某些类型的查询(如 BEGIN/END/COMMIT/ABORT/SET/SAVEPOINT/RELEASE SAVEPOINT/DEALLOCATE ALL/DISCARD 发送到 主节点和负载均衡节点。如果 statement_level_load_balance 处于打开状态,则 查询也会发送到所有备用节点。这不是 通常是个问题。但是,当其中一个备用数据库处于远程状态时 网络,则网络延迟可能会导致 案例。

这个参数可以通过重新加载 Pgpool-II 配置来改变。

1.9. 健康检查

Pgpool-II 定期连接到配置的 PostgreSQL 后端来检测服务器或网络上的任何错误。 此错误检查过程称为 “运行状况检查”。

如果启用了 SSL,则运行状况检查 进程可能会使用 SSL 连接。

如果检测到错误,Pgpool-II 执行故障转移 或退化,具体取决于配置。

谨慎
运行状况检查需要与每个后端节点建立一个额外的连接, 因此,需要相应地调整 postgresql.conf 中的 max_connections。

运行状况检查过程会收集各种统计数据,例如 运行状况检查总数。检查统计信息 data 中,请使用 SHOW POOL_HEALTH_CHECK_STATS 命令。请注意,数据存储在共享内存中 area 的 API 中,它将在 Pgpool-II 启动时初始化。

以下参数名称的末尾也可以有数字后缀 每个名字。后缀对应后端 id,即 在 backend information 中定义,例如 作为 backend_hostname。 例如,health_check_timeout0 应用于 backend 0 的 health_check_timeout 值。

如果没有带 suffix 的参数,则 backend 的值 取自没有后缀的参数名称。在 从这个意义上说,没有后缀的参数名称的工作方式类似于 “global 变量”。

health_check_timeout (整数)
指定如果 TCP 连接在此时间内未成功,则放弃连接到后端 PostgreSQL 的超时时间(以秒为单位)。

此参数用于防止运行状况检查等待 拔下网线的时间很长。 默认值为 20。将其设置为 0 将禁用超时(等待 TCP/IP 超时)。

这个参数可以通过重新加载 Pgpool-II 配置来改变。

health_check_period (整数)
指定运行状况检查之间的间隔(以秒为单位)。 默认值为 0,这意味着运行状况检查已禁用。

这个参数可以通过重新加载 Pgpool-II 配置来改变。

health_check_user (字符串))
指定要执行运行状况检查的 PostgreSQL 用户名。 所有 PostgreSQL 后端中必须存在同一用户。 否则,运行状况检查会导致错误。

这个参数可以通过重新加载 Pgpool-II 配置来改变。

health_check_password (字符串))
指定在 health_check_user 中配置的用于执行运行状况检查的 PostgreSQL 用户名的密码。 用户和密码在所有 PostgreSQL 后端中必须相同。 否则,运行状况检查会导致错误。

如果 health_check_password 为空,Pgpool-II 将首先尝试从文件中获取 health_check_user 的密码pool_passwd然后再使用空密码。

Pgpool-II 接受以下形式 的密码health_check_password 或 pool_passwd 文件中:

AES256-CBC 加密密码
最安全和推荐的密码存储方式。这 密码字符串必须带有前缀 使用 AES。 您可以使用 pg_enc 实用程序创建格式正确的 AES 加密密码字符串。Pgpool-II 需要一个位于 startup 以使用加密的密码。 有关提供 Pgpool-II 的解密密钥

MD5 哈希密码
不如 AES256 安全,但仍然比 clear 好 text 密码。密码字符串必须带有前缀 使用 MD5。请注意,后端 还必须设置 MD5 身份验证。您可以 使用 pg_md5 实用程序创建 格式正确的 MD5 哈希密码字符串。

纯文本密码
未加密,明文密码。你应该避免 以尽可能使用它。密码字符串必须为 前缀为 TEXT。例如,如果 您希望将 myPass 设置为 password 的 Password,您应该 在密码中指定 TEXTmypass 田。在没有有效的 前缀,Pgpool-II 将 将字符串视为纯文本密码。

这个参数可以通过重新加载 Pgpool-II 配置来改变。

health_check_database (字符串))
指定要执行运行状况检查的 PostgreSQL 数据库名称。 默认值为 ‘’(empty),它首先尝试 “postgres” 数据库,然后尝试 “template1” 数据库,直到成功

health_check_database 是在 Pgpool-II V3.5 中引入的。

这个参数可以通过重新加载 Pgpool-II 配置来改变。

health_check_max_retries (整数))
指定在放弃之前要执行的最大重试次数,并且 在运行状况检查失败时启动故障转移。

提示: 此设置在参差不齐的网络中非常有用,因为预计 即使主节点正常,运行状况检查偶尔也会失败。

提示: 建议必须禁用 failover_on_backend_error, 如果要启用 health_check_max_retries。

默认值为 0,这意味着不重试。
这个参数可以通过重新加载 Pgpool-II 配置来改变。

health_check_retry_delay (整数))
指定在两次失败之间休眠的时间(以秒为单位) 运行状况检查重试(除非 health_check_max_retries > 0,否则不使用)。 如果为 0,则立即重试,不会延迟。

这个参数可以通过重新加载 Pgpool-II 配置来改变。

connect_timeout (整数))
指定放弃连接之前的时间量(以毫秒为单位) 到后端。 默认值为 10000 毫秒(10 秒)。浮点网络用户可能希望增加该值。 0 表示无超时。connect()

注意: connect_timeout值不仅用于运行状况检查, 但也用于创建普通连接池。

这个参数可以通过重新加载 Pgpool-II 配置来改变。

1.10. 故障转移和故障恢复

故障转移意味着自动分离 PostgreSQL 后端节点,而 PostgreSQL后端节点不是 可通过 Pgpool-II 访问。这种情况 无论配置参数设置如何,都会自动进行,并且 所谓的自动故障转移过程。Pgpool-II 确认 PostgreSQL 后端节点无法访问 使用以下方法:

常规运行状况检查流程 (有关详细信息,请参见 Section 1.9 详细信息)。健康检查过程尝试连接 从 Pgpool-II 到 PostgreSQL 节点确认 它的健康。如果连接失败,则有可能 网络连接有问题 在 Pgpool-II 和 PostgreSQL 之间, 和/或 PostgreSQL 不起作用 适当地。Pgpool-II 不会 区分每种情况,并只决定 特定 PostgreSQL 节点是 如果运行状况检查失败,则不可用。

连接时出错 更改为 PostgreSQL 或网络级别 与 IT 通信时发生错误。Pgpool-II 将断开连接 到 Client 端的会话 如果 failover_on_backend_error 在 然而,那个案例。

在以下情况下:当客户端已连接时 到 Pgpool-II 并且 PostgreSQL 已关闭 (请注意,如果没有客户端连接 到 Pgpool-II,关闭 PostgreSQL 的 down 不会 触发故障转移)。

此外,在流式复制模式下,关闭 的 PostgreSQL 不会触发 故障转移(如果节点是备用节点且不是负载) 平衡节点偶数 如果 failover_on_backend_shutdown 处于打开状态。

如果配置了 failover_command 并且 发生故障转移,failover_command 执行。应提供failover_command 按用户。从 4.1 开始,提供了故障转移命令的示例脚本 作为 failover.sh.sample,这可能是一个很好的 起点。

failover 命令的主要作用是选择新的主服务器 从现有的备用服务器进行推广。另一个 例如,让管理员知道发生了故障转移 通过发送邮件。

虽然发生故障时可能会发生故障转移,但确实如此 可以手动触发它。这称为 switch 结束。例如,切换 一个 PostgreSQL 进行备份 是可能的。请注意,切换只会将 status 设置为 宕机,并且永远不会使 PostgreSQL 宕机。切换可由 using pcp_detach_node 命令。

通过故障转移分离的 PostgreSQL 节点,或者 switch over 将永远不会返回到之前的状态 (attached state) 在默认设置中自动显示。使用 -D 选项重启 Pgpool-II 或运行 pcp_attach_node 会使其再次进入 attached 状态。它 建议在执行此操作之前确认 SHOW POOL NODES 的 replication_state 是 “streaming”。这 state 表示备用服务器已正确连接到 通过流复制的主服务器和两个数据库都是 同步。

从 4.1 开始,新参数auto_failback可以是 过去会自动执行上述操作。有关详细信息,请参阅 auto_failback。

1.10.1. 故障转移和故障恢复设置

failover_command (字符串))
指定在 PostgreSQL 后端节点分离时要运行的用户命令。Pgpool-II 替换了以下特殊字符 替换为后端特定信息。

表 1-8.failover 命令选项

特殊字符描述
%d已分离节点的数据库节点 ID
%h分离节点的主机名
%p已分离节点的端口号
%D已分离节点的数据库集群目录
%m新的主节点 ID
%H新主节点的主机名
%M旧的主节点 ID
%P旧的主节点 ID
%r新主节点的端口号
%R新主节点的数据库集群目录
%N旧主节点的主机名(Pgpool-II 4.1 或更高版本)
%S旧主节点的端口号 (Pgpool-II 4.1 或更高版本)
%%‘%’ 字符

注意
注意: “主节点”是指具有 “最年轻(或最小)节点 ID” 数据库节点。在流式处理中 复制模式,这可能不同于 主节点。在表 1-8 中, %m 是选定的新主节点 由 Pgpool-II 提供。它是节点 被分配了最小(最小)的节点 ID,即 活 着。例如,如果您有 3 个节点,即节点 0、1、 2. 假设节点 1 是主节点,并且所有节点都运行状况良好 (无宕机节点)。如果节点 1 发生故障,则failover_command 使用 %m = 0 调用。并且,如果所有备用节点都已关闭,并且主节点 发生故障切换,failover_command使用 %m = -1 和 %H,%R,$r = “” 调用。

注意: 执行故障转移时, 基本上 Pgpool-II 杀死了所有 其子进程,该子进程将反过来终止所有 到 Pgpool-II 的 active sessions 来访问。之后 Pgpool-II 调用 failover_command 并在命令完成后 Pgpool-II 启动新的子进程 这将使它再次准备好接受客户端连接。

然而,从 Pgpool-II 3.6 开始,在 steaming 复制模式,客户端会话将不会 如果会话 不使用失败的备用服务器。请注意,如果 查询,则会话将为 断开。如果主服务器宕机,则仍然会 会话将断开连接。运行状况检查超时情况将 也会导致 Full session 断开连接。其他运行状况检查 错误,包括 Retry over Case 不会触发完整会话 断开。

注意: 您可以运行 psql(或任何命令) 在 backend 中检索 脚本,但你不能对 Pgpool-II 本身运行 psql,因为 脚本是从 Pgpool-II 调用的,它需要运行 而 Pgpool-II 正在开发 故障转移。

可以找到完整的 failover_command 示例 在 Section 8.2 中。

这个参数可以通过重新加载 Pgpool-II 配置来改变。

failback_command (字符串))
指定当 PostgreSQL 后端节点连接到 Pgpool-II 时要运行的用户命令。Pgpool-II 将以下特殊字符替换为后端特定信息。 在执行命令之前。

表 1-9.failback 命令选项

特殊字符描述
%d附加节点的数据库节点 ID
%h附加节点的主机名
%p附加节点的端口号
%D附加节点的数据库集群目录
%m新的主节点 ID
%H新主节点的主机名
%M旧的主节点 ID
%P旧的主节点 ID
%r新主节点的端口号
%R新主节点的数据库集群目录
%N旧主节点的主机名(Pgpool-II 4.1 或更高版本)
%S旧主节点的端口号 (Pgpool-II 4.1 或更高版本)
%%‘%’ 字符
注意: 您可以运行 psql(或任何命令) 在 backend 中检索 脚本,但你不能对 Pgpool-II 本身运行 psql,因为 脚本是从 Pgpool-II 调用的,它需要运行 而 Pgpool-II 正在开发 故障回复。

这个参数可以通过重新加载 Pgpool-II 配置来改变。

follow_primary_command (字符串))
指定故障转移后在 主节点故障转移。在备用节点故障转移的情况下, 命令。如果 节点提升请求由pcp_promote_node命令发出。这仅适用于 流式复制模式。

由于命令是在 fork 的子进程中执行的 故障转移后被 Pgpool-II 关闭 已完成,则执行 follow primary 命令不会 阻止服务 Pgpool-II 的。这是一个别名 代码来说明命令的执行方式:

for each backend node
{if (the node is not the new primary)set down node status to shared memory statusmemorize that follow primary command is needed to execute
}
if (we need to executed follow primary command)
{fork a child process(within the child process)for each backend node{if (the node status in shared memory is down)execute follow primary command}
}

Pgpool-II 替换了以下特殊字符 替换为后端特定信息。

表 1-10.follow primary 命令选项

特殊字符描述
%d已分离节点的数据库节点 ID
%h分离节点的主机名
%p已分离节点的端口号
%D已分离节点的数据库集群目录
%m新的主节点 ID
%H新主节点的主机名
%M旧的主节点 ID
%P旧的主节点 ID
%r新主节点的端口号
%R新主节点的数据库集群目录
%N旧主节点的主机名(Pgpool-II 4.1 或更高版本)
%S旧主节点的端口号 (Pgpool-II 4.1 或更高版本)
%%‘%’ 字符
注意: 如果 follow_primary_command 不为空,则在故障转移后 在主节点上以流式复制的原生复制模式完成,Pgpool-II 使除新主节点之外的所有节点退化 并启动新的子进程以再次准备好接受来自客户端的连接。 在此之后,Pgpool-II 执行配置的命令 在 follow_primary_command 中为每个退化的后端节点。

通常follow_primary_command命令 用于通过调用 pcp_recovery_node 命令。在 follow_primary_command,它是 建议检查是否 目标 PostgreSQL 节点正在运行 或者不使用 pg_ctl因为已经停止的节点通常有一个 停止的原因:例如,它被硬件破坏 问题或管理员正在维护节点。如果 node 已停止,请跳过该节点。如果节点正在运行,则停止 首先是节点,然后恢复它。 虽然可以直接恢复 执行 pg_basebackup 或其他命令 您需要 pcp_recovery_node 而不是 执行 pcp_attach_node 注意 Pgpool-II,备用 服务器已准备就绪,可供使用。否则,备用服务器将保持为 down 状态。(由于 pcp_recovery_node 内部执行 pcp_attach_node,因此您不会 需要在 pcp_attach_node 之后执行 恢复。 完整的 follow_primary_command 示例可以 可在 Section 8.2 中找到。

这个参数可以通过重新加载 Pgpool-II 配置来改变。

failover_on_backend_shutdown (布尔值))
当设置为 on 时,Pgpool-II 检测到一个 通过检查特定错误代码 57P01 和 57P02 上的 backend shutdown 事件 在客户端和后端之间建立的会话。如果它 检测到这些错误代码,则会在该节点上触发故障转移。 当设置为 off 时,Pgpool-II 只报告一个错误并在出现错误时断开会话 错误。默认值为 off。

如果没有客户端连接,Pgpool-II 将不会检测到该事件 即使参数为 on。

此外,在流式复制模式下,关闭 的 PostgreSQL 不会触发 故障转移(如果节点是备用节点且不是负载) 平衡节点偶数 如果 failover_on_backend_shutdown 处于打开状态。在 order 查找哪个节点是负载均衡节点,则可以 使用 SHOW POOL NODES 或 pcp_proc_info。

请注意,57P01 不仅通过 shutdown 事件,但也会在后端当前 connected 被 或 SIGTERM 信号杀死。这很烦人,因为它会导致 不需要的故障转移。为避免这种情况,请关闭此参数。pg_terminate_backend

注意: 建议开启后端健康检查 (参见第 1.9 节) 当 failover_on_backend_shutdown 设置为 OFF 时。

此参数可用 在 Pgpool-II 4.3 或更高版本中。这 可以通过重新加载来更改 Pgpool-II 配置。

failover_on_backend_error (布尔值))
当设置为 on 时,Pgpool-II 会考虑读 / 写 错误,因为后端节点失败并触发 断开连接当前会话后,该节点上的故障转移。 当设置为 off 时,Pgpool-II 只报告一个错误 并在出现此类错误时断开会话。

注意: 建议开启后端健康检查 (参见第 1.9 节) 当 failover_on_backend_error 设置为 OFF 时。

这个参数可以通过重新加载 Pgpool-II 配置来改变。

注意: 在 Pgpool-II v4.0 之前, 此配置参数名称为 fail_over_on_backend_error。

search_primary_node_timeout (整数))
指定搜索 发生故障切换场景时的主节点。Pgpool-II 将放弃寻找 primary 节点(如果在此配置的时间内未找到)。 默认值为 300,将此参数设置为 0 表示永远尝试。

该参数仅适用于流式复制模式。

这个参数可以通过重新加载 Pgpool-II 配置来改变。

detach_false_primary (布尔值))
如果设置为 on,则分离 false 主节点。默认值为 关闭。此参数仅在流式复制中有效 模式,对于 PostgreSQL 9.6 或 after since this feature 使用。 如果 PostgreSQL 9.5.x 或更早版本 version 时,不会引发任何错误,只是 feature 是 忽视。pg_stat_wal_receiver

如果没有主节点,则不会执行检查。

如果没有备用节点,并且只有一个主节点 节点,则不会执行任何检查。

如果没有备用节点,并且有多个主节点 nodes 中,保留具有最年轻节点的主节点 id 并分离其余主节点。

如果有一个或多个主数据库和一个或多个备用数据库, 通过以下方式检查主节点和备用节点之间的连接 如果 PostgreSQL 9.6 或更高版本,则使用 USING 。在 在这种情况下,如果主节点连接到所有备用节点, 主数据库被视为 “true” 主数据库。其他初选 被视为 “false” primary,而 false primary 将 如果 detach_false_primary 为 真。如果未找到 “true” primary,则不会发生任何事情。pg_stat_wal_receiver

当 Pgpool-II 启动时, False Primary 的检查仅在 Pgpool-II 主 过程。如果 sr_check_period 更大 小于 0,则将在 流复制延迟检查的相同时间。

注意: sr_check_user必须 是 PostgreSQL 超级用户或 在 pg_monitor 组中使用此功能。自 在 pg_monitor 中制作sr_check_user 组,执行以下 SQL 命令 由 PostgreSQL 超级用户 (将 “sr_check_user” 替换为设置 sr_check_user):

   GRANT pg_monitor TO sr_check_user;

对于 PostgreSQL 9.6,有 无pg_monitor组 而且sr_check_user必须 成为 PostgreSQL 超级用户。

该参数仅适用于流式复制模式。

可以通过重新加载来更改此参数 Pgpool-II 配置。

图 1-1。检测错误的原色

在这里插入图片描述

auto_failback (布尔值))
当设置为 on 时,如果节点状态 已关闭,但流复制正常工作。这在以下情况下很有用 由于临时网络故障,备用节点被 pgpool 降级。

要使用此功能,流复制检查(有关更多详细信息,请参见Section 5.12) 必须启用,并且 PostgreSQL 9.1 或更高版本 作为后端节点是必需的。此功能在主节点上使用。自动故障回复仅在备用节点上执行。 请注意,如果 failback_command 不为空,failback_command也会执行。 如果您计划分离备用节点进行维护,请事先将此参数设置为 off。 否则,可能会违背您的意图重新附加备用节点。pg_stat_replication

默认值为 off。这个参数可以通过重新加载 Pgpool-II 配置来改变。

注意:使用复制槽时,auto_failback 可能不起作用。 流复制可能会停止,因为 failover_command 已执行并且复制槽被 命令。

auto_failback_interval (整数))
指定自动故障回复的执行间隔的最小时间(以秒为单位)。 在指定时间过去之前,不会执行下一次自动故障回复 在上一个自动故障恢复之后。当 Pgpool-II 频繁检测到 backend down 例如,您可以避免重复 故障转移和故障回复,方法是将此参数设置为 Greater Enough 值。 默认值为 60。将此参数设置为 0 表示自动故障回复不会等待。

1.10.2. 在 raw 模式下进行故障转移

如果定义了多个后端服务器,则可以在原始模式下执行故障转移。pgpool-II 通常在正常操作时访问 backend_hostname0 指定的后端。如果 backend_hostname0 由于某种原因失败,Pgpool-II 会尝试访问 backend_hostname1 指定的后端。如果失败,Pgpool-II 会尝试 backend_hostname2、3 等。

1.11. 在线恢复

Pgpool-II 可以同步数据库 节点并附加节点,而无需停止服务。这 功能称为“在线恢复”。在线 恢复可以通过以下方式执行 using pcp_recovery_node 命令。

对于联机恢复,恢复目标节点必须处于分离状态 州。这意味着节点必须由 pcp_detach_node 手动分离或自动分离 由 Pgpool-II 作为 故障转移。

如果要添加 PostgreSQL 服务器 node 中,在添加 pgpool.conf 及其关联的 backend_hostname 参数。这将注册新服务器 作为分离的后端发送到 Pgpool-II 节点,然后执行pcp_recovery_node命令 服务器为 ADD。

注意: 恢复目标 PostgreSQL 服务器不得 正在运行以执行联机恢复。如果 目标 PostgreSQL 服务器已启动, 在开始在线恢复之前,您必须将其关闭。

在线恢复分两个阶段执行。第一阶段是 称为“第一阶段”,第二阶段称为“第二阶段” 阶段”。只有本机复制模式和快照隔离模式需要第二个阶段。 对于其他模式(包括流式复制模式),第二个 stage 未执行,并且您不需要为 recovery_2nd_stage_command 中的舞台。即您可以安全地离开 it 为空字符串。

在第一阶段,备用(副本)节点是使用 PostgreSQL 的pg_basebackup创建的,例如,从 主(主)节点。在执行第一阶段时更新数据 将登录到 PostgreSQL 的 事务日志。

在第二阶段,目标恢复节点启动。这 Transaction Log 将被重放,副本节点将被 与 Master 节点完全同步。

您需要为每个阶段提供脚本。完成示例脚本 在 /etc/pgpool-II/recovery_1st_stage.sample 和 /etc/pgpool-II/recovery_2nd_stage.sample 中提供。 使用这些脚本的安装示例可以在 Section 8.2.7.8 中找到。

仅在第二阶段允许来自客户端的连接 而数据可以在第一阶段更新或检索。

Pgpool-II 在在线恢复中执行以下步骤:

检查站。

执行在线恢复的第一阶段。

等待所有客户端连接都已断开连接(仅在本机复制模式和快照隔离模式下)。

CHECKPOINT(仅在本机复制模式和快照隔离模式下)。

执行联机恢复的第二阶段(仅在本机复制模式和快照隔离模式下)。

启动 postmaster (执行pgpool_remote_start)

pgpool_remote_start是启动 recovery target 的 PostgreSQL 节点的脚本。pgpool_remote_start 接收以下 2 个参数:

要恢复的后端节点的主机名。

主(主)节点的数据库集群的路径。

脚本示例可以在 Section 8.2.7.8 中找到。

注意: 脚本路径和文件名是硬编码的,$PGDATA/pgpool_remote_start 在主(主)节点上执行。

节点附加

注意: 本机复制模式和快照隔离模式下的在线恢复存在限制。 如果安装了 Pgpool-II 本身 在多个主机上不启用 watchdog, 在线恢复无法正常工作, 因为 Pgpool-II 必须停止所有 在线恢复第 2 阶段的客户端。 如果有多个 Pgpool-II 主机, 他们中只有一个人会收到 Online Recovery 命令,并且会 阻止来自客户端的连接。

recovery_user (字符串))
指定要执行联机恢复的 PostgreSQL 用户名。

这个参数可以通过重新加载 Pgpool-II 配置来改变。

recovery_password (字符串))
指定在 recovery_user 中配置的用于执行联机恢复的 PostgreSQL 用户名的密码。

如果 recovery_password 为空,Pgpool-II 将首先尝试从pool_passwd文件中获取 recovery_user 的密码,然后再使用空密码。

您还可以在recovery_password字段中指定 AES256-CBC 加密密码。 要指定 AES 加密密码,密码字符串必须在加密后以 AES 为前缀(使用 aes-256-cbc 算法)和 编码为 base64。

要指定未加密的明文密码,请在密码字符串前加上 TEXT。例如,如果您想将 mypass 设置为 密码,则应在密码字段中指定 TEXTmypass。 在没有有效前缀的情况下,Pgpool-II 会认为 字符串作为纯文本密码。

您还可以使用 pg_enc 实用程序创建格式正确的 AES 加密密码字符串。

注意: Pgpool-II 需要一个有效的解密密钥,位于 startup 以使用加密的密码。 有关提供 Pgpool-II 的解密密钥

这个参数可以通过重新加载 Pgpool-II 配置来改变。

recovery_1st_stage_command (字符串))
指定要由 main (primary) 节点在 在线恢复的第一阶段。命令文件必须放在 database cluster 目录。 例如,如果 recovery_1st_stage_command = ‘sync-command’,那么 Pgpool-II 将 在 $PGDATA 目录中查找命令脚本,并将 尝试执行 $PGDATA/sync-command。

recovery_1st_stage_command 接收以下 7 个参数:

主(主)节点的数据库集群的路径。

要恢复的后端节点的主机名。

要恢复的节点的数据库集群的路径。

主(主)节点的端口号(Pgpool-II 3.4 或更高版本)。

要恢复的节点号(Pgpool-II 4.0 或更高版本)

需要恢复的端口号(Pgpool-II 4.1 或更高版本)

主(主)节点的主机名 (Pgpool-II 4.3 或更高版本)

在主(主)节点的主机名被 使用 hostname 命令。这基本上是可以的 由于脚本在主(主)节点上运行 无论如何。但是,在某些系统中,获得 by hostname 命令与 hostname 定义backend_hostname configuration 参数。 这可能会导致麻烦 detach_false_primary,因为它检查 主节点和备用节点之间的连接 使用 host 参数 in primary_conninfo参数中,即 生成 由 recovery_1st_stage_command。因此 强烈建议使用此参数,而不是 使用 hostname 命令获取 主节点的主机名 在 recovery_1st_stage_command。

注意: Pgpool-II 接受连接和查询 执行recovery_1st_stage命令时, ,以便您可以检索和更新数据。

谨慎
从 PostgreSQL 的角度来看,recovery_1st_stage命令作为 SQL 命令运行。因此recovery_1st_stage如果 PostgreSQL 的 statement_time_out 配置为 小于 recovery_1st_stage_command 所需的时间 完成。

在这种情况下,典型的错误是

   rsync used in the command is killed by signal 2 for example.

这个参数可以通过重新加载 Pgpool-II 配置来改变。

recovery_2nd_stage_command (字符串))
指定主节点在第二个 在线恢复阶段。此命令仅本机复制模式是必需的,因此其他模式不需要 以提供命令文件。命令文件必须放在 database cluster 目录。 例如,如果 recovery_2nd_stage_command = ‘sync-command’,那么 Pgpool-II 将 在 $PGDATA 目录中查找命令脚本,并将 尝试执行 $PGDATA/sync-command。

recovery_2nd_stage_command 接收以下 7 个参数:

主(主)节点的数据库集群的路径。

要恢复的后端节点的主机名。

要恢复的节点的数据库集群的路径。

主(主)节点的端口号(Pgpool-II 3.4 或更高版本)。

要恢复的节点号(Pgpool-II 4.0 或更高版本)

需要恢复的端口号(Pgpool-II 4.1 或更高版本)

主(主)节点的主机名 (Pgpool-II 4.3 或更高版本)

注意: Pgpool-II 在执行过程中不接受客户端连接和查询 recovery_2nd_stage_command命令,然后等待 让现有客户端在执行 命令。 因此,recovery_2nd_stage_command 可能无法执行 如果客户端长时间保持连接。

谨慎
从 PostgreSQL 的角度来看,recovery_2nd_stage命令作为 SQL 命令运行。因此,如果 PostgreSQL 的 statement_time_out 配置为 recovery_2nd_stage 小于 recovery_2nd_stage_command 所需的时间 完成。

这个参数可以通过重新加载 Pgpool-II 配置来改变。

recovery_timeout (整数))
指定取消在线恢复的超时时间(以秒为单位),如果它 未在此时间内完成。 由于 Pgpool-II 不接受连接 在在线恢复的第二阶段,此参数可用于取消 在线恢复,用于管理在线恢复期间的服务停机时间。

这个参数可以通过重新加载 Pgpool-II 配置来改变。

client_idle_limit_in_recovery (整数)
指定在客户端保持空闲状态时断开客户端连接的时间(以秒为单位) 自联机恢复期间的上次查询以来。client_idle_limit_in_recovery 与 client_idle_limit 类似,但仅在 在线恢复的第二阶段。

这对于防止 Pgpool-II 恢复被懒惰的客户端干扰,或者如果 TCP/IP 客户端和 Pgpool-II 之间的连接意外断开(例如电缆被切断)。

注意: client_idle_limit_in_recovery必须小于 recovery_timeout。 否则,recovery_timeout 首先,您将在执行在线恢复时看到以下错误:

 ERROR:  node recovery failed, waiting connection closed in the other pgpools timeout

如果设置为 -1,则当第二个 阶段开始。 默认值为 0,这将关闭该功能。

这个参数可以通过重新加载 Pgpool-II 配置来改变。 您还可以使用 PGPOOL SET 命令来更改 this 参数。

1.12. 流复制检查

Pgpool-II 可以和 PostgreSQL 原生一起工作 Streaming Replication,自 PostgreSQL 9.0 起可用。 配置 Pgpool-II 进行流式 replication,将 backend_clustering_mode 设置为 ‘streaming-replication’。

Pgpool-II 假设 Streaming Replication 在 PostgreSQL 上配置了热备用,这意味着 备用数据库可以处理只读查询。

sr_check_period (整数)
指定检查流的时间间隔(以秒为单位) 复制延迟。 默认值为 10。

这个参数可以通过重新加载 Pgpool-II 配置来改变。

sr_check_user (字符串))
指定要执行流复制检查的 PostgreSQL 用户名。 用户必须具有 LOGIN 权限,并且存在于所有 PostgreSQL 后端。

如果启用了 SSL,则 流式复制检查过程可能会使用 SSL 连接。

注意:即使 sr_check_period 设置为 0(禁用),也会使用 sr_check_user 和 sr_check_password 主服务器的标识。

这个参数可以通过重新加载 Pgpool-II 配置来改变。

sr_check_password (字符串))
指定 sr_check_user PostgreSQL 用户的密码 以执行流复制检查。 如果用户不需要密码,请使用 ‘’ (空字符串)。

如果 sr_check_password 为空,Pgpool-II 将首先尝试从文件中获取 sr_check_user 的密码pool_passwd然后再使用空密码。

Pgpool-II 接受以下形式 的密码sr_check_password 或 pool_passwd 文件中:

AES256-CBC 加密密码
最安全和推荐的密码存储方式。这 密码字符串必须带有前缀 使用 AES。 您可以使用 pg_enc 实用程序创建格式正确的 AES 加密密码字符串。Pgpool-II 需要一个位于 startup 以使用加密的密码。 有关提供 Pgpool-II 的解密密钥

MD5 哈希密码
不如 AES256 安全,但仍然比 clear 好 text 密码。密码字符串必须带有前缀 使用 MD5。请注意,后端 还必须设置 MD5 身份验证。您可以 使用 pg_md5 实用程序创建 格式正确的 MD5 哈希密码字符串。

纯文本密码
未加密,明文密码。你应该避免 以尽可能使用它。密码字符串必须为 前缀为 TEXT。例如,如果 您希望将 myPass 设置为 password 的 Password,您应该 在密码中指定 TEXTmypass 田。在没有有效的 前缀,Pgpool-II 将 将字符串视为纯文本密码。

这个参数可以通过重新加载 Pgpool-II 配置来改变。

sr_check_database (字符串))
指定要执行流复制延迟检查的数据库。 默认值为 “postgres”。

这个参数可以通过重新加载 Pgpool-II 配置来改变。

delay_threshold (整数))
指定备用服务器上复制延迟的最大容忍级别(以 WAL 字节为单位)相对于 主服务器。如果延迟超过这个配置的级别,Pgpool-II 停止向备用服务器发送 SELECT 查询并开始路由 所有内容都发送到主服务器,即使启用了 load_balance_mode,直到备用服务器赶上主服务器。 将此参数设置为 0 将禁用延迟检查。 此延迟阈值检查每 sr_check_period执行一次。 默认值为 0。

这个参数可以通过重新加载 Pgpool-II 配置来改变。

delay_threshold_by_time (整数))
指定复制延迟的最大容差级别 在备用服务器上与主服务器。 如果指定此值时不带单位,则以毫秒为单位。 如果指定的值大于 0,则忽略 delay_threshold。如果延迟 超过这个配置的级别,Pgpool-II 停止向备用服务器发送 SELECT 查询并开始路由 所有内容都发送到主服务器,即使启用了 load_balance_mode,直到备用服务器赶上主服务器。 将此参数设置为 0 将禁用延迟检查。 此延迟阈值检查每 sr_check_period执行一次。 默认值为 0。

采用复制延迟 从 PostgreSQL 的系统 查看pg_stat_replication。replay_lag。这 视图可用 PostgreSQL 10 或 后。如果版本更早 的 PostgreSQL 为 used,Pgpool-II 自动掉落 返回到 delay_threshold,delay_threshold_by_time 将被忽略。

此参数依赖于 backend_application_name正确 set 并匹配 application_name 您的 PostgreSQL 备用数据库的 primary_conninfo。

如果该参数为 enabled、SHOW POOL NODES 和 pcp_node_info 显示复制延迟 秒,而不是字节。

这个参数可以通过重新加载 Pgpool-II 配置来改变。

prefer_lower_delay_standby (布尔值))
此参数仅有效 当 delay_threshold 或 delay_threshold_by_time 设置为 大于 0。当设置为 on 时,如果负载的延迟 平衡节点更大 比 delay_threshold 或 delay_threshold_by_time,Pgpool-II 不会发送读查询 添加到主节点,但延迟最少的 standby 与 backend_weight 设置为大于 0。如果所有备用节点的延迟 大于 delay_threshold 或delay_threshold_by_time主 被选为负载均衡节点 首先,Pgpool-II 向 主要。默认值为 off。

这个参数可以通过重新加载 Pgpool-II 配置来改变。

log_standby_delay (字符串))
指定何时记录复制延迟。下表包含列表 参数的所有有效值。

表 1-11.日志备用延迟选项

ValueDescription
none从不记录待机延迟
always如果备用延迟大于 0,则在每次检查复制延迟时记录备用延迟
if_over_threshold仅当待机延迟超过 delay_threshold或 delay_threshold_by_time值(默认值)时,才记录待机延迟
这个参数可以通过重新加载 Pgpool-II 配置来改变。

1.13. 内存查询缓存

内存查询缓存可以用于 Pgpool-II 的所有模式。 内存中的查询缓存保留 SELECT 结果,并且结果将被重用。 当底层表更新时,相应的缓存条目将被删除(如果 memqcache_auto_cache_invalidation 处于打开状态。这个参数默认是开启的),因此重启 Pgpool-II 是没有必要的。

在内存缓存中保存用户名、数据库名称、SELECT 语句对 及其结果 (以及 Bind 参数,如果 SELECT 是 extended query)的 Zip S S如果相同的用户名、数据库名称和 SELECT 进来,Pgpool-II 返回 缓存。由于没有 SQL 解析或访问 到 PostgreSQL 中,服务 的结果非常快。

注意: 基本上,后面的 SELECT 不会被缓存:

SELECTs including non immutable functions
SELECTs including temp tables, unlogged tables
SELECTs including TIMESTAMP WITH TIMEZONE or TIME WITH TIMEZONE
SELECTs including CAST to TIMESTAMP WITH TIMEZONE or TIME WITH TIMEZONE
SELECTs including SQLValueFunction (CURRENT_TIME, CURRENT_USER etc.)
SELECT result is too large (memqcache_maxcache)
SELECT FOR SHARE/UPDATE
SELECT starting with "/*NO QUERY CACHE*/" comment
SELECT including system catalogs
SELECT uses TABLESAMPLE
SELECT uses row security enabled tables

但是,访问未记录表的 VIEW 和 SELECT 可以是 通过在 cache_safe_memqcache_table_list。

注意: 由于查询缓存和数据库内容之间的一致性可以 丢失,则查询缓存将全部删除,如果 它们被执行:

ALTER DATABASE
ALTER ROLE or USER (except WITH CONNECTION LIMIT and WITH [ENCRYPTED] PASSWORD)
ALTER TABLE
REVOKE

此外,如果执行 SET ROLE 或 SET SESSION AUTHORIZATION,则 不会使用查询缓存,也不会创建新缓存 在会话中。Pgpool-II 假设两个查询缓存 如果会话用户不同,则不同。另一方面 hand,PostgreSQL 管理访问控制 取决于当前用户。因此,这些命令可能会破坏 这两个访问控制之间的一致性。但是,缓存 invalidation by update 命令以相同的方式执行 这些命令未被使用。

另一方面,它可能比正常路径慢 在某些情况下,因为它会增加一些存储缓存的开销。 此外,当一个表被更新时,Pgpool-II 会自动删除所有与 桌子。因此,性能会因 很多更新。如果查询缓存命中率(可以检查 通过使用 SHOW POOL_CACHE) 低于 70%, 您可能希望在 Memory Cache 中禁用。

SELECT 结果基本上是在 SELECT 通常会完成。如果显式事务正在执行,则 SELECT 结果不会注册,直到 事务已提交。同样在扩展查询模式下,计时 的缓存注册因集群模式而异。在流式处理中 复制模式和逻辑 复制模式,则在从前端发送 Sync 消息时注册缓存,并且 response (Ready for query 消息) from backend 的因此,即使命令是从前端发送的, 第二个 Execute (SELECT 1) 将不使用查询缓存。

   Parse (SELECT 1)Bind (SELECT 1)Execute (SELECT 1)Parse (SELECT 1)Bind (SELECT 1)Execute (SELECT 1)Sync

另一方面,在其他集群模式下,由于 第一个 Execute (SELECT 1) 已注册,第二个 Execute (SELECT 1) 将使用查询缓存。

1.13.1. 在内存中启用查询缓存

memory_cache_enabled (布尔值))
设置为 on 将启用内存缓存。 默认值为 off。

此参数只能在服务器启动时设置。

注意: 如果 enable_shared_relcache 设置为 on,则共享关系缓存也将使用查询缓存。此外, 即使 memory_cache_enabled 参数设置为 OFF,也会使用查询缓存。有关关系缓存的更多详细信息,请参阅 Section 1.16 。

1.13.2. 选择缓存存储

memqcache_method (字符串))
指定要用于缓存的存储类型。 下表包含参数的所有有效值的列表。

表 5-12.Memqcache 方法选项

ValueDescription
‘shmem’Use shared memory
‘memcached’Use memcached
一般来说,shmem 更快 比 memcached 的 Mccached 少,因为前者不会 涉及任何网络访问。但是,memqcache_total_size 的上限大小受总数 系统定义的共享内存大小。尺寸较大 在现代 Linux 系统中已经足够了,但在其他系统中可能就足够了 较小的上限。在这种情况下,您需要更改系统 有关最大共享内存大小的设置。有一个 关于共享内存的好解释 在 PostgreSQL 文档中。

如果您不确定要使用哪个memqcache_method,请从 shmem 开始。

默认为 ‘shmem’。

此参数只能在服务器启动时设置。

1.13.3. 常见配置

以下参数对 shmem 和 memcached 类型的查询缓存均有效。

memqcache_expire (整数)
指定查询缓存的生命周期(以秒为单位)。 默认值为 0。这意味着没有缓存过期和缓存保留 在更新表之前有效。

此参数只能在服务器启动时设置。

注: memqcache_expire 和 memqcache_auto_cache_invalidation 彼此正交。

memqcache_auto_cache_invalidation (布尔值))
设置为 on,则自动删除与更新的 table 相关的缓存。 关闭时,不会删除缓存。

默认值为 on。

注意: 此参数 memqcache_auto_cache_invalidation 和 memqcache_expire 彼此正交。

这个参数可以通过重新加载 Pgpool-II 配置来改变。

memqcache_maxcache (整数)
指定要缓存的 SELECT 查询结果的最大大小(以字节为单位)。 数据大小大于此值的结果不会被 Pgpool-II 缓存。 当数据缓存因大小限制而被拒绝时,以下 消息。

   LOG:   pid 13756: pool_add_temp_query_cache: data size exceeds memqcache_maxcache. current:4095 requested:111 memq_maxcache:4096

注意: 对于共享内存 query(‘shmem’) 缓存,memqcache_maxcache必须设置为低于 memqcache_cache_block_size,对于 ‘memcached’,它必须小于 slab 的大小(默认为 1 MB)。

此参数只能在服务器启动时设置。

cache_safe_memqcache_table_list (字符串))
指定一个以逗号分隔的表名列表,其 SELECT 结果应该由 Pgpool-II 缓存。此参数仅 适用于访问未记录表的 VIEW 和 SELECT。 除非指定,否则可以缓存常规表 由 cache_unsafe_memqcache_table_list。

您可以在列表中使用正则表达式来匹配表名 (^ 和 $ 会自动添加到其中)。

注意: 如果查询可以引用具有和不具有架构的表 qualification 那么你必须添加两个条目(带和不带 Schema name) 的 Schema 名称)。

#For example:
#If the queries sometime use "table1" and other times "public.table1"
#to refer the table1 then the cache_safe_memqcache_table_list
#would be configured as follows.cache_safe_memqcache_table_list = "table1,public.table1"

这个参数可以通过重新加载 Pgpool-II 配置来改变。

cache_unsafe_memqcache_table_list (字符串))
指定其 SELECT 的表名的逗号分隔列表 结果不应该被 Pgpool-II 缓存。

您可以在列表中使用正则表达式来匹配表名 (^ 和 $ 会自动添加到其中)、

注意: 如果查询可以引用具有和不具有架构的表 qualification 那么你必须添加两个条目(带和不带 Schema name) 的 Schema 名称)。

#For example:
#If the queries sometime use "table1" and other times "public.table1"
#to refer the table1 then the cache_unsafe_memqcache_table_list
#would be configured as follows.cache_unsafe_memqcache_table_list = "table1,public.table1"

这个参数可以通过重新加载 Pgpool-II 配置来改变。

注意: cache_unsafe_memqcache_table_list优先于cache_safe_memqcache_table_list

memqcache_oiddir (字符串))
指定用于存储 SELECT 查询使用的表的 oid 的目录的完整路径。

memqcache_oiddir 目录包含子目录 对于数据库。目录名称是数据库的 OID。此外,每个 database 目录包含 SELECT 语句使用的每个 table 的文件。 同样,文件名是表的 OID。 这些文件包含指向查询缓存的指针,这些指针用作 删除缓存。

注意: 正常重启 Pgpool-II 不会清除 memqcache_oiddir的内容。

这个参数可以通过重新加载 Pgpool-II 配置来改变。

1.13.4. 使用共享内存的配置

这些是与共享内存一起用作缓存存储的参数。

memqcache_total_size (整数))
指定共享内存高速缓存大小。 默认值为 64MB。

每个缓存都存储在指定的固定大小的块中 由 memqcache_cache_block_size。数字 的块数 由 memqcache_total_size / memqcache_cache_block_size。Any decimal (任意小数) places 被截断,因此块的数量为 整数。如果数字变为 0,则会引发错误。那 是,memqcache_total_size必须更大 比 memqcache_cache_block_size。查询 结果及其管理数据不会存储在多个 块,因此如果查询结果数据长度 + 64 字节更大 memqcache_cache_block_size,它不能 存储在块中,不会被缓存。

当一个块填充了 cache 时,将使用下一个块。 当所有块都已满时,将刷新并重用最旧的块 (请注意,最早的区块不一定包含 最旧的缓存数据,因为每当 找到第一个拟合空间)。而 较小的memqcache_total_size不会升高 错误,则性能会因缓存命中率 减少。缓存命中率可以通过 SHOW POOL_CACHE 的咨询cache_hit_ratio。

此参数只能在服务器启动时设置。

memqcache_max_num_cache (整数))
指定缓存条目数。默认值为 1,000,000。

如果您尝试注册更多 比memqcache_max_num_cache缓存,一个块 包含缓存的数据将被刷新并重新使用。而 较小的 memqcache_max_num_cache 不会 引发错误,性能会因缓存命中 比率降低。缓存命中率可以通过 SHOW POOL_CACHE 的咨询cache_hit_ratio。

注意: 缓存由共享内存中的哈希表管理,以便快速 访问。哈希表空间大小可以通过以下方式计算:memqcache_max_num_cache * 64 字节。数 的哈希条目 在 SHOW POOL_CACHE 的 used_hash_entries。哈希编号 表条目通常 匹配 memqcache_max_num_cache,但可能不匹配 如果 memqcache_max_num_cache 不是 2 的幂。在这种情况下,它四舍五入为大于 2 的幂 比 memqcache_max_num_cache。数量 可以找到正在使用的哈希条目 在 used_hash_entries。

此参数只能在服务器启动时设置。

memqcache_cache_block_size (整数)
指定缓存块大小。 默认值为 1MB。

查询结果及其管理数据不会存储在 多个块,因此如果查询结果数据长度 + 64 字节 大于 memqcache_cache_block_size, 它不能存储在块中,也不会被缓存。

memqcache_cache_block_size 必须至少设置为 512。

此参数只能在服务器启动时设置。

1.13.5. 使用 memcached 的配置

这些是与 memcached 一起用作缓存存储的参数。

memqcache_memcached_host (字符串))
指定 memcached 在其上运行的主机名或 IP 地址。如果 memcached 和 Pgpool-II 位于同一台服务器上,你可以使用 ‘localhost’。

此参数只能在服务器启动时设置。

memqcache_memcached_port (整数)
指定 memcached 的端口号。 默认值为 11211。

此参数只能在服务器启动时设置。

1.14.安全套接层(ssh)

1.14.1. SSL 设置

ssl (布尔值)
当设置为 on 时,Pgpool-II 为前端和后端通信启用 SSL。 默认值为 off。

注意: ssl_key 和 ssl_cert 还必须 配置,以便 SSL 与前端连接一起使用。

注意: 要使 SSL 工作,Pgpool-II 必须构建有 OpenSSL 支持。 参见 Section 2.1 来了解构建 Pgpool-II 的细节。

此参数只能在服务器启动时设置。

ssl_key (字符串))
指定要用于的私钥文件 传入的前端连接。相对路径是相对于 Pgpool-II 配置目录的。 此选项没有默认值,如果未设置,则将对传入的前端连接禁用 SSL。

此参数只能在服务器启动时设置。

ssl_cert (字符串))
指定要使用的公共 x509 证书文件 对于传入的前端连接。相对路径是相对于 Pgpool-II 配置目录的。 此选项没有默认值,如果未设置,则将对传入的前端连接禁用 SSL。

此参数只能在服务器启动时设置。

ssl_ca_cert (字符串))
指定 PEM 格式的 CA 证书文件,该文件可用于验证后端服务器 证书。相对路径是相对于 Pgpool-II 配置目录的。这是 类似于 OpenSSL verify(1) 命令的 -CApath 选项。

此参数只能在服务器启动时设置。

ssl_ca_cert_dir (字符串))
指定包含 PEM 格式 CA 证书文件的目录的路径,该目录可以使用 以验证后端服务器证书。这类似于 OpenSSL verify(1) 命令的 -CApath 选项。

此选项的默认值为 unset,即 no 进行验证。如果满足以下条件,验证仍会进行 此选项未设置,但会为 ssl_ca_cert 提供一个值。

此参数只能在服务器启动时设置。

ssl_crl_file (字符串))
指定包含 SSL 服务器证书的文件 吊销列表 (CRL)。相对路径是相对于 Pgpool-II 配置目录的。 默认值为空,这意味着不会加载任何 CRL 文件。

此参数只能在服务器启动时设置。

ssl_ciphers (字符串))
指定 SSL 密码套件的列表,该 允许 SSL 连接使用。看 OpenSSL 软件包中的 ciphers 手册页 了解此设置的语法和支持的值列表。 只有使用 TLS 版本 1.2 及更低版本的连接会受到影响。 目前没有控制密码选择的设置 由 TLS 版本 1.3 连接使用。 默认值 是 HIGH:MEDIUM:+3DES:!aNULL,这是相同的 作为 PostgreSQL。 请参阅 PostgreSQL 手册以了解原因 该值已选中。

此参数只能在服务器启动时设置。

ssl_prefer_server_ciphers (布尔值))
指定是否使用服务器的 SSL 密码首选项,而不是客户端的 SSL 密码首选项。 默认值为 false。

此参数只能在服务器启动时设置。

ssl_ecdh_curve (字符串))
指定要在 ECDH 密钥中使用的曲线的名称 交换。它需要得到所有连接的客户端的支持。 它不需要与服务器的 Elliptic 使用的曲线相同 曲线键。默认值为 prime256v1。

最常见曲线的 OpenSSL 名称为:prime256v1 (NIST P-256)、secp384r1 (NIST P-384)、secp521r1 (NIST P-521)。 可用曲线的完整列表可以使用命令 openssl ecparam -list_curves 显示。并非全部 在 TLS 中可用。

此参数只能在服务器启动时设置。

ssl_dh_params_file (字符串))
指定包含 Diffie-Hellman 参数的文件的名称 用于所谓的 SSL 密码的临时 DH 系列。默认值为 空。在这种情况下,使用编译的默认 DH 参数。用 如果攻击者设法 破解众所周知的编译 DH 参数。您可以创建自己的 DH 参数文件,其中包含命令 openssl -out dhparams.pem 2048。

此参数只能在服务器启动时设置。

ssl_passphrase_command (字符串))
设置在用于解密的密码时要调用的外部命令 需要获取 SSL 文件,例如私钥。默认情况下, 此参数为空,这意味着如果需要密码,则不会加载 SSL 文件。

该命令必须将密码打印到标准输出中,并且 以代码 0 退出。在参数值中,%p 替换为提示符 字符串。(对于文本 %,请写入 %%。请注意,提示字符串可能会 包含空格,因此请务必充分引用。单个换行符被剥离 从输出的末尾(如果存在)。

该命令实际上不必提示用户输入密码。 它可以从文件中读取它,从钥匙串工具中获取它,或类似的东西。 用户有责任确保所选机制足够安全。

此参数只能在服务器启动时设置。

1.14.2. 生成 SSL 证书

证书处理不在本文档的讨论范围之内。位于 postgresql.org 的“使用 SSL 保护 TCP/IP 连接”页面具有 包含示例命令的指针,用于生成自签名 证书。

1.15. 看门狗

看门狗的配置参数在 pgpool.conf 中描述。 在 pgpool.conf.sample 文件的 WATCHDOG 部分有示例配置。 以下所有选项都需要在 watchdog 进程中指定。

1.15.1. 启用看门狗

use_watchdog (布尔值))
如果打开,则激活 watchdog。默认为 off

此参数只能在服务器启动时设置。

pgpool-II 4.1 或更早版本,因为它需要指定 它自己的 pgpool 节点信息和目标 pgpool 节点信息, 每个 pgpool 节点的设置都不同。 从 Pgpool-II 4.2 开始,所有的配置参数都是 在所有主机上都相同。如果启用了 watchdog 功能,以区分哪个主机 是哪个,则需要 pgpool_node_id 文件。 您需要创建一个 pgpool_node_id 文件并指定 pgpool (看门狗) 节点号 (例如 0, 1, 2 …) 来识别 pgpool (看门狗) 主机。

例 1-10.pgpool_node_id配置

如果您有 3 个 pgpool 节点,其主机名为 server1、server2 和 server3,请在每台主机上创建 pgpool_node_id 文件,如下所示。 当使用 RPM 安装 Pgpool-II 时,pgpool.conf 安装在 /etc/pgpool-II/ 下。

服务器 1

[server1]# cat /etc/pgpool-II/pgpool_node_id
0服务器 2[server2]# cat /etc/pgpool-II/pgpool_node_id
1服务器 3[server3]# cat /etc/pgpool-II/pgpool_node_id
2

1.15.2. 看门狗通信

hostnameX (字符串)
指定 Pgpool-II 服务器的主机名或 IP 地址。 这用于发送/接收查询和数据包, 以及作为 watchdog 节点的标识符。 引用参数名称末尾的数字 作为 “pgpool node id”,它从 0 开始(例如 hostname0)。

此参数只能在服务器启动时设置。

wd_portX (整数))
指定看门狗要使用的端口号 process 来监听连接。默认值为 9000。 引用参数名称末尾的数字 作为 “pgpool node id”,它从 0 开始(例如 wd_port0)。

此参数只能在服务器启动时设置。

pgpool_portX (整数))
指定 Pgpool-II 端口号。 默认值为 9999。 引用参数名称末尾的数字 设置为 “pgpool node id”,并且从 0 开始(例如 pgpool_port0)。

此参数只能在服务器启动时设置。

例 1-11.看门狗配置

如果您有 3 个 pgpool 节点,其主机名为 server1、server2 和 server3, 您可以配置主机名、wd_port 和 pgpool_port,如下所示:

hostname0 = ‘server1’
wd_port0 = 9000
pgpool_port0 = 9999

hostname1 = ‘server2’
wd_port1 = 9000
pgpool_port1 = 9999

hostname2 = ‘server3’
wd_port2 = 9000
pgpool_port2 = 9999

wd_authkey (字符串))
指定用于所有 watchdog 通信的身份验证密钥。 所有 Pgpool-II 必须具有相同的 key。 来自不同密钥的 watchdog 的数据包将被拒绝。 此身份验证也适用于检测信号 当 Heartbeat Mode 用作 LifeCheck 方法时。

因为在 Pgpool-IIV3.5 或更高版本中,wd_authkey 也被用来验证 看门狗 IPC 客户端, 所有与 Pgpool-II 看门狗进程通信的客户端都需要提供这个 wd_authkey 值 对于 JSON 数据中的 “IPCAuthKey” 键 的命令。

默认值为 ‘’ (空),表示禁用 看门狗身份验证。

此参数只能在服务器启动时设置。

1.15.3. 上游服务器连接

上游服务器是 Pgpool-II 服务的客户端(数据库客户端)。 即使 Pgpool-II 还活着并且 连接到 PostgreSQL, 如果与上游服务器的链接断开,Pgpool-II 将无法提供服务。 因此,该看门狗还会监控与上游服务器的连接 来自 Pgpool-II。

trusted_servers (字符串))
指定用于检查上游连接的受信任服务器列表。 例如,Pgpool-II 和上游服务器之间的上游服务器或路由器列表。 列表中的每台服务器都需要响应 ping。 指定以逗号分隔的服务器列表,例如 “hostA,hostB,hostC”。 如果无法访问任何服务器,则看门狗会将其视为 Pgpool-II 失败。 因此,建议指定多个服务器。 请注意,您不应将 PostgreSQL 服务器分配给此参数。

此参数只能在服务器启动时设置。

trusted_server_command (字符串))
指定 Pgpool-II 检查时要运行的用户命令 受信任的服务器响应 ping。字符串中的任何 %h 都将被每个主机替换 名称 指定的 trusted_servers。默认值为 ping -q -c3 %h。

此参数只能在服务器启动时设置。

1.15.4. 虚拟 IP 控制

delegate_ip (字符串))
指定 Pgpool-II 的虚拟 IP 地址 (VIP) 连接 客户端服务器(应用程序服务器等)。当 Pgpool-II 从 standby 切换到 active,则 Pgpool-II 接管这个 贵宾。如果达到法定人数,则不会提出 VIP 不存在。默认值为 ‘’(空):其中 意味着虚拟 IP 永远不会被启动。

此参数只能在服务器启动时设置。

if_cmd_path (字符串))
指定 Pgpool-II 将用于切换系统上虚拟 IP 的命令的路径。 仅设置包含二进制文件的目录的路径, 例如 “/sbin” 或此类目录。 如果 if_up_cmd 或 if_down_cmd 以 “/” 开头, 此参数将被忽略。 默认值为 /sbin。

此参数只能在服务器启动时设置。

if_up_cmd (字符串))
指定用于启动虚拟 IP 的命令。 设置命令和参数,例如 “ip addr add KaTeX parse error: Expected group after '_' at position 4: _IP_̲/24 dev eth0 label eth0:0”。 由于执行此命令需要 root 权限,因此 在 IP 命令上使用 setuid 或 允许 Pgpool-II 启动用户(默认为 postgres 用户) 在没有密码的情况下运行 sudo 命令,并指定它,例如 “/usr/bin/sudo /sbin/ip addr add KaTeX parse error: Expected group after '_' at position 4: _IP_̲/24 dev eth0 label eth0:0”。KaTeX parse error: Expected group after '_' at position 4: _IP_̲ 将被 IP 地址替换 在 delegate_ip 中指定。

默认为 /usr/bin/sudo /sbin/ip addr add KaTeX parse error: Expected group after '_' at position 4: _IP_̲/24 dev eth0 label eth0:0。

此参数只能在服务器启动时设置。

if_down_cmd (字符串))
指定用于关闭虚拟 IP 的命令。 设置命令和参数,例如 “ip addr del KaTeX parse error: Expected group after '_' at position 4: _IP_̲/24 dev eth0”。 由于执行此命令需要 root 权限,因此 在 IP 命令上使用 setuid 或 允许 Pgpool-II 启动用户(默认为 postgres 用户) 在没有密码的情况下执行 sudo 命令,并指定它,例如 “/usr/bin/sudo /sbin/ip addr del KaTeX parse error: Expected group after '_' at position 4: _IP_̲/24 dev eth0”。KaTeX parse error: Expected group after '_' at position 4: _IP_̲ 将被 IP 地址替换 在 delegate_ip 中指定。

默认值为 /usr/bin/sudo /sbin/ip addr del KaTeX parse error: Expected group after '_' at position 4: _IP_̲/24 dev eth0。

此参数只能在服务器启动时设置。

arping_path (字符串))
指定 Pgpool-II 在虚拟 IP 切换后发送 ARP 请求的命令的路径。 仅设置包含二进制文件的目录的路径, 例如 “/usr/sbin” 或类似目录。 如果 arping_cmd 以 “/” 开头, 此参数将被忽略。 默认值为 /usr/sbin。

此参数只能在服务器启动时设置。

arping_cmd (字符串))
指定用于发送 ARP 请求的命令 在虚拟 IP 切换之后。 设置命令和参数,例如 arping -U KaTeX parse error: Expected group after '_' at position 4: _IP_̲ -w 1 -I eth0。 由于执行此命令需要 root 权限,因此 在 IP 命令上使用 setuid 或 允许 Pgpool-II 启动用户(默认为 postgres 用户) 不带密码执行 sudo 命令,并指定 “/usr/bin/sudo /usr/sbin/arping -U KaTeX parse error: Expected group after '_' at position 4: _IP_̲ -w 1 -I eth0” 等。KaTeX parse error: Expected group after '_' at position 4: _IP_̲ 将被 delegate_ip中指定的 IP 地址。

默认值为 /usr/bin/sudo /usr/sbin/arping -U KaTeX parse error: Expected group after '_' at position 4: _IP_̲ -w 1 -I eth0。

此参数只能在服务器启动时设置。

ping_path (字符串))
指定 ping 命令的路径,用于检查虚拟 IP 的启动情况。 设置包含 ping 实用程序的目录的唯一路径, 例如 “/bin” 或此类目录。 默认值为 /bin。

此参数只能在服务器启动时设置。

1.15.5. 升级和降级的行为

关于 Pgpool-II 升级到 active (虚拟 IP 持有者) 时的行为的配置

clear_memqcache_on_escalation (布尔值))
当设置为 on 时,看门狗会清除共享内存中的所有查询缓存 当 pgpool-II 升级为 active 时。这可以防止新的活动 Pgpool-II 使用与旧活动 Pgpool-II 不一致的旧查询缓存。

默认值为 on。

这仅在 memqcache_method 为 ‘shmem’ 时有效。

此参数只能在服务器启动时设置。

wd_escalation_command (字符串))
Watchdog 在升级的节点上执行此命令 领导监督机构。

此命令在启动 虚拟 IP(如果在节点上配置了)。

此参数只能在服务器启动时设置。

wd_de_escalation_command (字符串))
当 Pgpool-II 看门狗节点退出领导节点职责时,看门狗会在该节点上执行此命令。 领导看门狗节点可以退出领导节点, 当领导节点 Pgpool-II 关闭时,检测到网络 blackout 或检测到 lost of quorum。

此命令在关闭虚拟/浮动 IP 地址之前执行 如果在 Watchdog 节点上配置了它。

wd_de_escalation_command 在 Pgpool-II V3.5 之前不可用。

此参数只能在服务器启动时设置。

1.15.6. 控制 Failover 行为

这些设置用于控制启用看门狗时后端节点故障转移的行为。 这些配置的效果仅限于 Pgpool-II 内部发起的故障转移/退化请求,而用户发起的 detach 后端请求 (使用 PCP 命令)绕过这些配置设置。

failover_when_quorum_exists (布尔值))
启用后,Pgpool-II 在后端节点上执行退化/故障转移时将考虑 quorum。

我们可以说“仲裁存在”,如果 live 看门狗节点(即 Number 的 Pgpool-II 节点)可以是 majority 的 watchdog 节点总数。为 例如,假设 Watchdog 节点数为 5。如果 number 为 活动节点数大于或等于 3,则 quorum 存在。另一方面,如果活动节点数为 2 或 lower,则 quorum 不存在,因为它从来都不存在 大多数。

如果 quorum 存在,Pgpool-II 可以在故障检测方面做得更好,因为即使 看门狗节点误检到后端节点故障, 其他主要看门狗节点会拒绝它。Pgpool-II 就是这样工作的 当 failover_require_consensus 处于开启状态时 (默认),但您可以更改它,以便立即 当检测到故障时,将发生故障转移。 一个 Pgpool-II 节点错误地 检测到后端节点失败,将隔离后端 节点。

可以通过使用 --verbose 选项调用pcp_watchdog_info命令来显示 quorum 的存在。 如果 Quorum state 为 QUORUM EXIST 或 QUORUM IS ON THE EDGE,则仲裁存在。 如果 Quorum state 为 QUORUM ABSENT,则仲裁不存在。

在没有 quorum,Pgpool-II 节点 检测到后端失败将隔离失败的 backend 节点,直到 quorum 再次存在。

尽管可以强制分离隔离区 node pcp_detach_node命令,则 无法通过以下方式再次连接节点 using pcp_attach_node 命令。

这 隔离节点的行为类似于分离的后端节点 但与 failed/degenerate backends 不同的是,quarantine status 为 没有传播到看门狗集群中的其他 Pgpool-II 节点,因此即使后端节点在 一个 Pgpool-II 节点上的隔离状态,其他 Pgpool-II 节点可能仍然 继续使用该后端。

尽管隔离和故障转移操作有许多相似之处,但它们在以下方面差异很大 基本方式。隔离操作不会执行 failover_command 并静默地分离有问题的节点,因此在主后端节点被隔离的情况下,Pgpool-II 不会提升备用节点来接管主节点的职责 在主节点被隔离之前,Pgpool-II 不会有 任何可用的主后端节点。

此外,与失败的节点不同,Pgpool-II 保留了健康检查 在隔离的节点上运行,并且一旦被隔离的 节点再次变得可访问,它会自动 重新连接。注意,这仅适用于 Pgpool-II V4.1 或更高版本。如果您使用的是以前的版本,则需要 pcp_attach_node当连接问题 解决。

从 Pgpool-II V4.1 开始,如果 watchdog-leader 节点 无法为主后端节点故障转移建立共识,并且主后端节点进入 quarantine 状态,然后它辞去其 Leader/Coordinator 职责并降低其 wd_priority for next leader election,并让集群选举一些不同的新 leader。

注意: 当 Leader 节点无法构建备用后端节点故障的共识时,它不会采取任何措施 并且 watchdog-leader 上类似隔离的备用后端节点不会触发新的 leader 选举。

如果此参数为 off,则即使 仲裁不存在。

默认值为 on。

failover_when_quorum_exists 在 Pgpool-II V3.7 之前不可用。

此参数只能在服务器启动时设置。

注意:在本机复制模式下不允许启用 failover_when_quorum_exists。

failover_require_consensus (布尔值))
当启用时,Pgpool-II 将在 backend node (如果存在监视器 Quorum) 并且至少需要最小数量的节点 对于故障转移的仲裁投票。

例如,在三节点看门狗集群中,故障转移只会执行到 至少有两个节点要求在特定后端节点上执行故障转移。

如果此参数为 off,则即使 没有达成共识。

默认值为 on。

谨慎
当 failover_require_consensus 为 enabled,则 Pgpool-II 不会 执行故障转移,直到它获得足够的选票 其他 Pgpool-II 节点。原来如此 强烈建议在 所有 Pgpool-II 节点,以确保 正确检测后端节点故障。了解更多 运行状况检查的详细信息, 参见 Section 1.9 。

注意:在本机复制模式下不允许启用 failover_require_consensus。

failover_require_consensus 在 Pgpool-II V3.7 之前不可用。而这只是 启用 failover_when_quorum_exists 时生效

此参数只能在服务器启动时设置。

allow_multiple_failover_requests_from_node (布尔值))
此参数与 failover_require_consensus 结合使用。启用后,单个 Pgpool-II 节点可以为故障转移投下多个选票。

例如,在一个 3 节点看门狗集群中,如果一个 Pgpool-II 节点发送两个 特定后端节点故障转移的故障转移请求,两个请求都将计为单独的 投票赞成故障转移,然后 Pgpool-II 将执行故障转移, 即使它没有得到任何其他 Pgpool-II 节点的投票。

例如,如果在运行状况检查轮次中发现错误 没有得到足够的投票,错误仍然存在,下一轮 的运行状况检查将再投一票。此参数为 如果要检测可能 不会被其他 watchdog 节点找到。

默认值为 off。

allow_multiple_failover_requests_from_node 在 Pgpool-II V3.7 之前不可用。而这只是 在 failover_when_quorum_exists 和 failover_require_consensus 都启用时生效

此参数只能在服务器启动时设置。

enable_consensus_with_half_votes (布尔值))
此参数配置多数规则的计算方式 由 Pgpool-II 用于计算 仲裁和解决故障转移的共识。

注意: 此参数不仅影响 backend 的 Quorum 和 Pgpool-II 本身的故障转移行为。

启用后,故障转移时 quorum 和 consensus 的存在只需要 集群中配置的投票总数。否则,这两者都是 决策需要至少多一票,超过总票数的一半。 对于故障转移,此参数与 failover_require_consensus 结合使用。在这两种情况下,无论是将 决定存在仲裁或就故障转移达成共识 参数仅在 watchdog cluster 配置为偶数时起作用 Pgpool-II 节点的数量。 具有奇数个参与者的 watchdog 集群中的多数规则决策。 它不受此配置参数值的影响。

例如,当在双节点看门狗中启用此参数时 cluster 的 Bean 节点,一个 Pgpool-II 节点需要 存活以使 quorum 存在。如果该参数处于关闭状态,则为 2 个 节点需要处于活动状态才能使 quorum 存在。

在 4 节点 watchdog 集群中启用此参数时, 两个 Pgpool-II 节点需要处于活动状态 使 quorum 存在。如果该参数处于关闭状态,则三个节点 需要处于活动状态才能使 quorum 存在。

通过启用此参数,您应该知道您采用 风险导致脑裂发生。例如,在 4 个节点中 cluster 由节点 A、B、C 和 D 组成,则 cluster 进入两个独立的网络 (A, B) 和 (C, D)。为 (A, B) 和 (C, D) 仲裁仍然存在,因为对于这两个组 4 个活动节点中有 2 个。这两个组选择他们的 自己的 Leader 看门狗,它是一个 split-brain。

默认值为 off。

enable_consensus_with_half_votes不可用 Pgpool-II V4.1 之前的版本。以前的版本有效 就像参数是 on 一样。

此参数只能在服务器启动时设置。

1.15.7. 控制看门狗集群成员资格

默认情况下,看门狗集群由所有看门狗节点组成 在 pgpool.conf 文件中定义的 与节点的当前状态无关。节点 是 LOST、SHUTDOWN 或从未启动,则该节点被视为 watchdog 集群定义,只要它在 配置文件。 用于识别存在的所有多数规则计算 的 Quorum 和解决共识是根据 组成 Watchdog 集群的 Watchdog 节点数。

Pgpool-II V4.3 使能 动态集群定义,通过引入 Member 和 Nonmember 的概念。 如果节点的成员资格从监视程序集群中被撤销, 然后,集群动态地重新校准自身以调整所有 随后的多数规则计算。

所有多数规则计算都是根据 成员 watchdog nodes 而不是已配置节点的总数。

例如:在一个 5 节点集群中(pgpool.conf 有 5 个 watchdog nodes defined )至少需要三个节点处于活动状态才能达到 quorum。 使用动态集群成员机制,集群可以重新调整 本身仅对 MEMBER 节点进行计数 (成员节点不一定需要处于活动状态)。 这意味着实际上是一个 live 节点 还可以满足仲裁要求(取决于成员资格条件设置) 如果在某个时间点,集群只有一个或两个成员节点。

谨慎
使用动态群集成员资格存在导致脑裂的相关风险。 因此,强烈建议仔细检查设置是否需要动态集群 membership 并考虑对相关设置使用保守值。

这些设置配置何时将节点标记为 Nonmember。 将所有这些设置保留为默认值将保留 V4.3 之前的行为。

wd_remove_shutdown_nodes (布尔值))
启用后,SHUTDOWN 节点将立即标记为 Nonmember 并从集群中删除。如果之前关闭的节点再次启动, 它会自动添加到 Cluster 中。

默认值为 off。

wd_lost_node_removal_timeout (整数))
超时(以秒为单位),将 LOST 看门狗节点标记为 Nonmember 并从集群中删除。 当 LOST 节点重新连接到集群时,将恢复其集群成员身份。

将超时设置为 0 将禁用删除 集群中丢失的节点数。

默认值为 0。

wd_no_show_node_removal_timeout (整数)
超时(以秒为单位),如果节点未显示,则将其标记为 Nonmember 在集群初始化时。非成员节点成为集群成员 一旦它启动并连接到集群。

将超时设置为 0 将禁用删除 群集中的 NO-SHOW 节点数。

默认值为 0。

1.15.8. 寿命检查 Pgpool-II

看门狗定期检查 pgpool-II 状态。这称为 “寿命检查”。

wd_lifecheck_method (字符串))
指定寿命检查的方法。这可以是 ‘heartbeat’ (默认)、‘query’ 或 ‘external’。

heartbeat:在此模式下,看门狗发送心跳信号(UDP 数据包) 定期发送到其他 Pgpool-II。同样,看门狗也接收信号 来自其他 Pgpool-II . 如果在一段时间内没有信号,则看门狗认为是失败 的 Pgpool-II .

query:在此模式下,看门狗发送监控查询 到其他 Pgpool-II 并检查响应。 当 Pgpool-II 服务器之间的安装位置很远时,查询可能很有用。

谨慎
在查询模式下,如果您计划使用 watchdog,则需要将 num_init_children 设置得足够大。 这是因为看门狗进程作为客户端连接到 Pgpool-II。

external:此模式禁用构建的 在 Pgpool-II 看门狗的 lifecheck 中 并依赖外部系统提供节点健康检查 本地和远程看门狗节点。

external 模式在 Pgpool-II V3.5 之前的版本中不可用。

此参数只能在服务器启动时设置。

wd_monitoring_interfaces_list (字符串))
指定要由 watchdog 进程监控的网络设备名称的逗号分隔列表 对于网络链接状态。如果列表中的所有网络接口都变为非活动状态 (禁用或拔下电缆),则看门狗会将其视为完全的网络故障 而 Pgpool-II 节点将自杀。 指定 ‘’(空) 列表将禁用网络接口监控。 将其设置为 ‘any’ 可对所有可用网络接口进行监控 但 loopback 除外。默认值为 ‘’ 空列表(禁用监控)。

wd_monitoring_interfaces_list 在 Pgpool-II V3.5 之前的版本中不可用。

此参数只能在服务器启动时设置。

wd_interval (整数))
指定 Pgpool-II 的寿命检查间隔,以秒为单位。(大于或等于 1 的数字)默认值为 10。

此参数只能在服务器启动时设置。

wd_priority (整数))
此参数可用于提升选举中的本地看门狗节点优先级 选择 Leader Watchdog Node (领导看门狗节点)。 将选择具有较高 wd_priority 值的节点 作为 leader watchdog node 当 cluster 将选举其新的 leader 节点时 如果旧的 leader watchdog 节点发生故障。wd_priority 在集群启动时也有效。 当一些看门狗节点同时启动时,会选择wd_priority值较高的节点作为领导节点。 所以我们应该按照wd_priority优先级的顺序启动看门狗节点,以防止 意外节点被选为 leader。 如果每个节点的 wd_priority 具有相同的值,则 Leader 节点将根据 watchdog 的启动时间来决定。

wd_priority 在 Pgpool-II V3.5 之前的版本中不可用。

此参数只能在服务器启动时设置。

wd_ipc_socket_dir (字符串))
UNIX 域套接字所在的目录 接受 Pgpool-II 看门狗的 IPC 连接将被创建。 默认为 ‘/tmp’。 请注意,此套接字可能会被 cron 作业删除。 我们建议将此值设置为 ‘/var/run’ 或此类目录。

wd_ipc_socket_dir 在 Pgpool-II V3.5 之前的版本中不可用。

此参数只能在服务器启动时设置。

1.15.9. Lifecheck Heartbeat 模式配置

heartbeat_hostnameX (字符串))
指定用于发送和接收检测信号的 IP 地址或主机名。 引用参数名称末尾的数字 作为 “pgpool node id”,它从 0 开始(例如 heartbeat_hostname0)。 您可以通过使用分号 (😉) 分隔多个 IP 地址或主机名来指定它们。

heartbeat_hostnameX仅在wd_lifecheck_method设置为“heartbeat”时适用

此参数只能在服务器启动时设置。

heartbeat_portX (整数))
指定用于发送和接收检测信号的端口号。 此处仅指定一个端口号。默认值为 9694。 引用参数名称末尾的数字 作为 “pgpool node id”,它从 0 开始(例如 heartbeat_port0)。

heartbeat_portX仅在wd_lifecheck_method设置为 ‘heartbeat’ 时适用

此参数只能在服务器启动时设置。

heartbeat_deviceX (字符串))
指定用于发送和接收检测信号的网络设备名称。 引用参数名称末尾的数字 作为 “pgpool node id”,它从 0 开始(例如 heartbeat_device0)。 您可以通过使用分号 (😉 分隔多个网络设备来指定它们。

heartbeat_deviceX 只在 Pgpool-II 以 root 用户启动 特权。如果不是,请将其保留为空字符串 (‘’)。

heartbeat_deviceX仅在wd_lifecheck_method设置为 ‘heartbeat’ 时适用

此参数只能在服务器启动时设置。

例 1-12.心跳配置

如果您有 3 个 pgpool 节点,其主机名为 server1、server2 和 server3, 您可以配置 heartbeat_hostname、heartbeat_port 和 heartbeat_device,如下所示:

 heartbeat_hostname0 = 'server1'heartbeat_port0 = 9694heartbeat_device0 = ''heartbeat_hostname1 = 'server2'heartbeat_port1 = 9694heartbeat_device1 = ''heartbeat_hostname2 = 'server3'heartbeat_port2 = 9694heartbeat_device2 = ''

wd_heartbeat_keepalive (整数))
指定发送检测信号之间的间隔时间(以秒为单位)。 默认值为 2。wd_heartbeat_keepalive仅在wd_lifecheck_method设置为“heartbeat”时适用

此参数只能在服务器启动时设置。

wd_heartbeat_deadtime (整数))
指定将远程看门狗节点标记为失败/失效节点之前的时间(以秒为单位), 如果在该时间内未收到检测信号。 默认值为 30 wd_heartbeat_deadtime仅当 wd_lifecheck_method 设置为 ‘heartbeat’ 时适用

此参数只能在服务器启动时设置。

1.15.10. Lifecheck Query 模式配置

wd_life_point (整数)
指定重试 pgpool-II 失败的寿命检查的次数。 有效值可以是大于或等于 1 的数字。 默认值为 3。

wd_life_point仅在wd_lifecheck_method设置为 ‘query’ 时适用

此参数只能在服务器启动时设置。

wd_lifecheck_query (字符串))
指定用于远程 Pgpool-II 生命周期检查的查询。 默认值为 “SELECT 1”。

wd_lifecheck_query仅在wd_lifecheck_method设置为 ‘query’ 时适用

此参数只能在服务器启动时设置。

wd_lifecheck_dbname (字符串))
指定用于 远程 Pgpool-II 的寿命检查。 默认值为 “template1”。

wd_lifecheck_dbname仅在wd_lifecheck_method设置为 ‘query’ 时适用

此参数只能在服务器启动时设置。

wd_lifecheck_user (字符串))
指定用于生命周期的连接的用户名 检查远程 Pgpool-II。 默认值为 “nobody”。

仅当wd_lifecheck_method设置为 ‘query’ 时,wd_lifecheck_user 才适用

此参数只能在服务器启动时设置。

wd_lifecheck_password (字符串))
指定用于远程 Pgpool-II 寿命检查的用户密码。

如果 wd_lifecheck_password 为空,Pgpool-II 将首先尝试从文件中获取 wd_lifecheck_user 的密码pool_passwd然后再使用空密码。

您还可以在字段中指定 AES216-CBC 加密wd_lifecheck_password密码。 要指定 AES 加密密码,密码字符串必须在加密后以 AES 为前缀(使用 aes-256-cbc 算法)和 编码为 base64。

要指定未加密的明文密码,请在密码字符串前加上 TEXT。例如,如果您想将 mypass 设置为 密码,则应在密码字段中指定 TEXTmypass。 在没有有效前缀的情况下,Pgpool-II 会认为 字符串作为纯文本密码。

您还可以使用 pg_enc 实用程序创建格式正确的 AES 加密密码字符串。

注意: Pgpool-II 需要一个有效的解密密钥,位于 startup 以使用加密的密码。 有关提供 Pgpool-II 的解密密钥

wd_lifecheck_password仅在wd_lifecheck_method设置为 ‘query’ 时适用

此参数只能在服务器启动时设置。

默认值为 ‘’(空)。

1.16. 其他配置参数

relcache_expire (整数)
指定关系缓存过期时间(以秒为单位)。 关系缓存用于缓存 PostgreSQL 系统目录的查询结果,Pgpool-II 使用它来获取包括表 结构体并检查表类型(例如,要检查引用的 table 是否为临时表)。缓存在 Pgpool-II 子进程的本地内存空间及其生命周期与子进程相同。 缓存也保存在共享内存中,以便在子级之间共享 进程,如果启用 enable_shared_relcache。 因此,如果使用 ALTER TABLE 或其他方式修改表,则 relcache 将变得不一致。 为此,relcache_expire控制 缓存的生命周期。 默认值为 0,这意味着缓存永不过期。

此参数只能在服务器启动时设置。

relcache_size (整数))
指定 relcache 条目的数量。默认值为 256。 缓存创建时,每个表大约有 10 个条目。所以你可以估计 「使用表的数 * 10」处所需的关联缓存数。

注意: 如果下面的消息经常出现在 Pgpool-II 日志中,你可能需要 增加 relcache_size 以获得更好的性能。

   "pool_search_relcache: cache replacement occurred"

此参数只能在服务器启动时设置。

enable_shared_relcache (布尔值))
通过设置为 on,关系缓存在 Pgpool-II 子进程之间共享,使用 in 内存查询缓存(有关更多信息,请参见Section 5.13.1 详细信息)。默认值为 on。每个子进程都需要访问 来自 PostgreSQL 的系统目录。 通过启用此功能,其他进程可以提取目录 lookup 结果,它应该会减少 查询的频率。即使 系统目录已修改。因此,强烈建议 使用 relcache_expire 参数设置 Time Out Base Cache Invalidation 。

即使 memory_cache_enabled 处于关闭状态,也可以使用此参数。在这种情况下,一些 查询缓存参数(memqcache_method、memqcache_maxcache和每个缓存存储 参数)一起使用。

Pgpool-II 搜索本地关系 cache 优先。如果在缓存中找不到,则共享关系 如果启用了此功能,则搜索 Query Cache。如果是 在 Query Cache 上找到,则会将其复制到 local 关系中 缓存。如果在任何地方都找不到缓存条目,Pgpool-II 对 PostgreSQL 执行查询,结果被存储 放入 Shared Relation Cache 和 Local Cache 中。

此参数只能在服务器启动时设置。

relcache_query_target (枚举))
目标节点,用于发送查询以创建关系缓存 条目。如果设置为 primary,则查询将 发送到主节点。这是默认值,并且 推荐给大多数用户,因为查询可能会获取 最新信息。如果您想降低 主节点,您可以将参数设置为 load_balance_node,这将发送 查询到负载均衡节点。这特别有用 对于这样的系统 其中 Pgpool-II/主服务器是 在大洲 A 期 其他 Pgpool-II/备用服务器是 在其他大洲 B 上,客户端希望从 standby (备用),因为它在地理上更接近。在这个 case 你可以设置 backend_weight0 (这代表 primary) 设置为 0,backend_weight1设置为 1(这表示待机),并将 relcache_query_target load_balance_node。

但请注意,如果您向备用节点发送查询,则 最近创建的表和行可能在 上不可用 由于复制延迟,备用服务器尚未。因此 对于满足以下条件的系统,不建议使用此类配置 数据修改活动很高。

可以通过重新加载来更改此参数 Pgpool-II 配置。

check_temp_table (枚举))
设置为 catalog 或 trace 时,启用临时表 check 在 SELECT 语句中。检查 临时表 Pgpool-II 查询 主/主 PostgreSQL 后端 如果指定了 catalog ,则 增加主/主服务器上的负载。

如果 trace 为 set,Pgpool-II 跟踪临时 创建和删除 table 以获取临时 table 信息。因此,无需访问系统目录。但是,如果 临时表创建不可见 到 Pgpool-II 中(在 functions 中完成 或 triggers,用于 example),Pgpool-II 不能 识别临时表的创建。

如果您绝对确定您的系统从未使用 temporary tables 的 SET ,那么您可以安全地设置为 none。

注意: 为了向后兼容 4.0 或 之前,Pgpool-II 接受 on,这是一样的 作为 catalog 和 off, 这与 none 相同,则它们可能是 在将来的版本中删除。

默认值为 catalog。

可以通过重新加载来更改此参数 Pgpool-II 配置。 您还可以使用 PGPOOL SET 命令 更改当前会话的此参数的值。

check_unlogged_table (布尔值))
设置为 on,在 SELECT 语句中启用无日志记录表检查。要检查未记录的表,Pgpool-II 查询 PostgreSQL 主/主后端的系统目录,该目录会增加 主/主服务器上的负载。 如果您绝对确定您的系统从未使用未记录的表 (例如,您使用的是 PostgreSQL 9.0 或更早版本),那么您 可以安全地关闭 check_unlogged_table。 默认值为 on。

这个参数可以通过重新加载 Pgpool-II 配置来改变。 您还可以使用 PGPOOL SET 命令来更改 this 参数。

pid_file_name (字符串))
指定存储 Pgpool-II 进程 ID 的文件的完整路径。 pid_file_name路径可以指定为相对于 pgpool.conf 文件的位置或绝对路径 默认是 “/var/run/pgpool/pgpool.pid”。

此参数只能在服务器启动时设置。

logdir (字符串)
指定用于存储pgpool_status的目录的完整路径。 默认为 ‘/tmp’。

此参数只能在服务器启动时设置。

health_check_test (布尔值))
谨慎
不要在作品中将此参数设置为 on 环境。此功能仅用于测试目的。

设置为 on, 启用运行状况检查的 Testing Facility。在这种情况下, 运行状况检查过程 Look 转换为 logdir 下的 backend_down_request。该文件可能包含多个 行,每行对应于每个后端。中 文件以后端 ID 开头(必须是以 backend ID 开头的十进制数 替换为 0),然后是 TAB,并以 “down” 结尾。后端是 假设处于宕机状态,并且 Pgpool-II 将启动故障转移。故障转移完成后,“down” 为 通过运行状况检查过程重写为 “already_down” 以防止 重复故障转移。

此功能特别适用于 测试 failover_require_consensus。假设 我们有 3 个 watchdog 节点。每个 watchdog 都会检查 backend 0 的通过在看门狗 0 下的文件中设置 “0 down”, 其他看门狗不同意后端 0 的不健康性,因此 不会发生故障转移。这种部分网络故障可能会 使用此功能进行模拟。

默认值为 off。

此参数只能在服务器启动时设置。


http://www.ppmy.cn/server/157274.html

相关文章

用于与多个数据库聊天的智能 SQL 代理问答和 RAG 系统(3) —— 基于 LangChain 框架的文档检索与问答功能以及RAG Tool的使用

介绍基于 LangChain 框架的文档检索与问答功能&#xff0c;目标是通过查询存储的向量数据库&#xff08;VectorDB&#xff09;&#xff0c;为用户的问题检索相关内容&#xff0c;并生成自然语言的答案。以下是代码逻辑的详细解析&#xff1a; 代码结构与功能 初始化环境与加载…

【centos8 ES】Elasticsearch linux 龙晰8操作系统安装

在龙晰8操作系统上安装 Elasticsearch 的步骤如下&#xff1a; 1. 安装 Java Elasticsearch 需要 Java 环境&#xff0c;建议安装 OpenJDK 11 或更高版本。你可以使用以下命令来安装 OpenJDK&#xff1a; sudo yum install java-11-openjdk-devel2. 下载 Elasticsearch 你可…

13、Ollama OCR

1、介绍 Ollama OCR&#xff0c;是一个强大的OCR&#xff08;光学字符识别&#xff09;工具包。利用 Ollama 的先进视觉语言模型从图像中提取文本&#xff0c;可作为 Python 包和 Streamlit 网络应用程序使用。具有支持多种视觉模型、多种输出格式、批量处理、图像预处理等功能…

leetcode 面试经典 150 题:单词规律

链接单词规律题序号290题型字符串解题方法哈希表难度简单熟练度✅✅✅ 题目 给定一种规律 pattern 和一个字符串 s &#xff0c;判断 s 是否遵循相同的规律。 这里的 遵循 指完全匹配&#xff0c;例如&#xff0c; pattern 里的每个字母和字符串 s 中的每个非空单词之间存在着…

运维实战---多种方式在Linux中部署并初始化MySQL

运维实战—多种方式在Linux中部署并初始化MySQL 前言实验环境介绍一、源码包安装MySQL 1、配置MySQL&编译安装2、初始化数据库3、配置环境变量 二、yum安装MySQL三、rpm安装MySQL 前言 MySQL是常用的关系型数据库&#xff0c;具有以下特点&#xff1a; 1、开源&#xff…

【JavaEE】—— SpringBoot项目集成百度千帆AI大模型(对话Chat V2)

本篇文章在SpringBoot项目中集成百度千帆提供的大模型接口实现Chat问答效果&#xff1a; 一、百度智能云 百度千帆大模型平台是百度智能云推出的一个企业级一站式大模型与AI原生应用开发及服务平台。 注册地址&#xff1a;https://qianfan.cloud.baidu.com/ 注册成功后&…

From Orthogonal Time Frequency Space to Affine Frequency Division Multiplexing

From Orthogonal Time Frequency Space to Affine Frequency Division Multiplexing 《从正交时频空间到仿射频分复用》 下一代无线系统将集成感知与通信&#xff08;ISAC&#xff09;功能&#xff0c;不仅为了实现新的应用&#xff0c;还为了应对高移动性场景以及毫米波&…

linux 服务器清理

起因 服务器报错&#xff1a;no space left on device 翻译&#xff1a;设备上没有剩余空间 解决方法 清理数据&#xff0c;这里有个点要注意&#xff0c; 对于重要文件&#xff0c;一定要备份。 步骤 1 首先&#xff0c;需要确定哪个分区或目录占用了大量空间。 df -h执…