0

我正在使用 pecl mongo 1.4.x 驱动程序(http://pecl.php.net/package/mongo/1.4.1),标题中提到的设置用于中等流量服务(每分钟 5K - 10K 请求)。

而且我发现,在 mongoDB 中,Auth 命令占用了大量流量,并且连接请求速率约为每秒 30-50 个。

这会严重影响性能(锁定率上升,内存管理不好)

如果我在一个盒子里做 netstat(我总共有 5-8 个盒子),我会看到每个盒子总共有 2-3K 个 mongo 连接(有些在 WAIT 中,有些在 ESTABLISHED 中)。

我的问题是如何减少与 mongoDB 的连接数,如何正确设置持久连接?

似乎 PECL mongoDB 驱动程序中持久连接的工作方式自 1.2 和 1.3 以来一直在发生变化,并且在 1.4 中的执行方式略有不同。

这是我使用驱动程序调用客户端的方式:
$mongo = new MongoClient(
"host1:11004,host2:11004", array(
'replicaSet' => MG_REPLICASET,
'password'=>"superpasswd",
'username'= >"myuser",
'db'=>"mydb",
'journal' => true,
"readPreference"=> MongoClient::RP_SECONDARY_PREFERRED
) );

4

2 回答 2

3

在 1.4 版本中,所有连接都是持久的,除非你自己关闭它们——你永远不应该这样做。您将看到来自每个 PHP 处理单元的每个 IP/用户名/密码/数据库组合的连接。在您的情况下,每个 PHPFPM 进程。为了减少连接数,您需要使用较少的用户名/密码/数据库组合。但是,如果您的副本集中有 8 个盒子、50 个 FPM 进程和 3 个节点,那么您已经有 1200 个连接 - 甚至没有考虑数据库/用户名/密码的差异。您对此无能为力但它不应该对性能产生太大影响。您更有可能遇到 RAM/慢速磁盘限制。

于 2013-07-24T17:05:25.957 回答
0

我想我找到了一个解决方案来避免过多的 mongo 连接请求。

我们需要将 PHP_FCGI_MAX_REQUESTS(或 php-fpm 中的 pm.max_requests)设置为更大的数字,这样进程就不会太频繁地回收。

另外我需要确保 pm.request_terminate_timeout 不会太小,这样工人就不会经常被杀死。

于 2013-07-30T05:39:12.437 回答