PHP8 MongoDB连接处理和持久性
注意: 在 Unix 平台上,MongoDB 驱动程序对使用 fork() 系统调用,而不调用 exec()。建议用户不要 在分叉中重用 MongoDB\Driver\Manager 实例 子进程。
连接和拓扑持久性(PHP 版本从 1.2.0 开始)
自 1.2.0 以来的所有驱动程序版本都保留了 libmongoc 客户端对象 PHP 工作进程,允许它重用数据库连接, 身份验证状态和拓扑信息 多个请求。
当 MongoDB\Driver\Manager::__construct() 为 调用时,从其参数(即 URI 字符串和数组)创建哈希 选项)。驱动程序将尝试查找以前持久化的 » libmongoc 客户端对象 那个哈希。如果找不到哈希的现有客户端,则新客户端 将被创建并保留以备将来使用。可以禁用此行为 通过驱动程序选项。"disableClientPersistence"
每个客户端都包含自己的数据库连接和服务器视图 拓扑(例如独立、副本集、分片集群)。通过持久化 客户端在PHP请求之间,驱动程序能够复用已建立的 数据库连接,并消除了对每个请求的“发现服务器拓扑”的需要。
请看以下示例:
<?php
$managers = [
new MongoDB\Driver\Manager('mongodb://127.0.0.1'),
new MongoDB\Driver\Manager('mongodb://127.0.0.1'),
new MongoDB\Driver\Manager('mongodb://127.0.0.1:27017'),
new MongoDB\Driver\Manager('mongodb://rs1.example.com,rs2.example.com/', ['replicaSet' => 'myReplicaSet']),
];
foreach ($managers as $manager) {
$manager->executeCommand('test', new MongoDB\Driver\Command(['ping' => 1]));
}
?>
前两个 Manager 对象将共享相同的 libmongoc 客户端,因为 它们的构造函数参数是相同的。第三个和第四个对象将 每个都使用自己的客户端。总共将创建三个客户端,并且 执行此脚本的 PHP 工作线程将打开两个与 和 的连接,以及每个 和 的一个连接。 如果驱动程序在发出命令后发现副本集的其他成员,它将打开与 那些服务器也是如此。127.0.0.1rs1.example.comrs2.example.comhello
如果同一个工作线程在第二个请求中再次执行脚本,则三个 客户端将被重用,并且不会建立新的连接。根据 上一个请求是多久前送达的,驱动程序可能需要发出 用于更新其视图的其他命令 拓扑。hello
套接字持久性(PHP 1.2.0 之前的版本)
1.2.0 之前的 PHP 驱动程序版本使用 PHP 的 Streams API 数据库连接,使用 » libmongoc 中的 API 指定 用于套接字通信的自定义处理程序;但是,新的 libmongoc 客户端是 为每个 MongoDB\Driver\Manager 创建。因此, 驱动程序保留单个数据库连接,但不保留身份验证 状态或拓扑信息。这意味着驱动程序需要发出 每个请求开头的命令,用于验证和 » 发现服务器拓扑。
数据库连接由派生自服务器的哈希值持久化 host、port 和用于构造 MongoDB\Driver\Manager 的 URI 字符串。构造函数的数组 选项不包含在此哈希中。
注意: 驱动程序 >= 1.1.8 和 < 1.2.0 的版本不会保留套接字 用于 SSL 连接。参见 » PHPC-720 其他信息。
尽管它在持久SSL连接和拓扑结构方面存在缺点 信息,此版本的驱动程序支持所有 SSL 上下文选项,因为它使用 PHP 的 Streams API。