查看: 7913|回复: 0

PHP使用MongoDB的持久连接

[复制链接]
论坛徽章:
65
生肖徽章2007版:龙
日期:2012-04-26 14:03:05生肖徽章2007版:龙
日期:2012-04-26 14:03:05生肖徽章2007版:龙
日期:2012-04-26 14:03:05生肖徽章2007版:龙
日期:2012-04-26 14:03:05生肖徽章2007版:龙
日期:2012-04-26 14:03:05生肖徽章2007版:龙
日期:2012-04-26 14:03:05蓝锆石
日期:2012-04-26 13:39:45开发板块每日发贴之星
日期:2012-04-26 14:03:05ERP板块每日发贴之星
日期:2012-04-26 14:03:05行业板块每日发贴之星
日期:2012-04-26 14:03:05
跳转到指定楼层
1#
发表于 2012-2-28 16:56 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
一、MongoDB持久连接中关于连接共享的测试
<?php
// creates a persistent connection
$m1 = new Mongo("mongodb://localhost", array("persist" => ""));
// uses the same connection as $m1
$m2 = new Mongo("mongodb://localhost", array("persist" => ""));
// creates a new connection
$m3 = new Mongo("mongodb://127.0.0.1", array("persist" => ""));
// creates a new connection
$m4 = new Mongo("mongodb://127.0.0.1:27017", array("persist" => ""));
// creates a new connection
$m5 = new Mongo("mongodb://localhost", array("persist" => "foo"));
// uses the $m5 connection
$m6 = new Mongo("mongodb://localhost", array("persist" => "foo"));
?>
共享和连接参数+persist后面名称都有关系。

二、单台服务器可能请求的最大的持久连接数(fastcgi模式)
经常反复测试,最大持久连接数和并发数无关;
只和fastcgi启动时所带的-C参数有关,

单台服务器相同连接参数,且持久连接名相同的最大产生64个这样的持久连接,不分域名共享
如$m1 = new Mongo("mongodb://localhost", array("persist" => ""));
在WEB上反复访问,将产生64个持久的MongoDB连接,相同程序,用不同域名访问,并不在继续增加持久连接,但
$m3 = new Mongo("mongodb://127.0.0.1", array("persist" => ""));
形式的将继续产生64个。

三、现状
阿语论坛首先开了持久的MongoDB连接,服务器状态看到

当前持久了82个连接,可用的还有737个,并且这些连接其它站由连接参数问题,即使持久连接名一样,也没办法共享,所以当前这种状态下的连接方式,并不能通用。
未使用持久连接的MMO论坛服务器状态

基本上MongoDB的连接都是在页面访问开始时建立,加载完成后马上释放。
分析服务器启动的fastcgi的脚本,-C 256
并且有云2台,所以一个站点最大要求持久连接数达到512个
以目前MongoDB各站分配不同帐号、密码、指定连接到指定库的方式,这些持久连接都是无法共享的。

四、可能的改变
1、加大MongoDB的最大连接数

但如果各站都使用现在的连接方式,并且都使用持久连接,这值不管多大都未必能满足,并且还会使fastcgi里占大堆未使用的持久连接
2、使用公共的连接方式
程序代码:

程序一:
try{
$Mongo = new Mongo("mongodb://64.151.107.192:27027", array("connect" => false, 'persist'=>'p_97'));


$rs = $Mongo->selectDB("forummo")->authenticate('user_forummo', '***');
var_dump($rs);
echo "MMO<hr />";

  $db = $Mongo->selectDB("admin");
  $ret = $db->command(array("serverStatus" => 1));
  var_dump($ret);
}catch (Exception $e){
var_dump($e->getMessage());
}
程序二:
try{
$Mongo = new Mongo("mongodb://64.151.107.192:27027", array("connect" => false, 'persist'=>'p_97'));

$rs = $Mongo->selectDB("tagmmosite")->authenticate('user_tagmmosite', '***');
var_dump($rs);
echo "TAG<hr />";
  $db = $Mongo->selectDB("admin");
  $ret = $db->command(array("serverStatus" => 1));
  var_dump($ret);
}catch (Exception $e){
var_dump($e->getMessage());
}

以上2程序在114测试机上,定fastcgi为-C 16
远程64.151.107.192:27027
这台MongoDB服务器状态得到
["connections"]=> array(2) { ["current"]=> int(17) ["available"]=> int(802) }
所以要在云上使所有站点可以共享由fastcgi保存的MongoDB的持久连接,就需要各站程序上统一MongoDB的连接方式。
参考程序一、二。

什么是CGI、FastCGI、PHP-CGI、PHP-FPM、Spawn-FCGI?
  什么是CGI
  CGI全称是“公共网关接口”(Common Gateway Interface),HTTP服务器与你的或其它机器上的程序进行“交谈”的一种工具,其程序须运行在网络服务器上。
  CGI可以用任何一种语言编写,只要这种语言具有标准输入、输出和环境变量。如php,perl,tcl等
  什么是FastCGI
  FastCGI像是一个常驻(long-live)型的CGI,它可以一直执行着,只要激活后,不会每次都要花费时间去fork一次(这是 CGI最为人诟病的fork-and-execute 模式)。它还支持分布式的运算, 即 FastCGI 程序可以在网站服务器以外的主机上执行并且接受来自其它网站服务器来的请求。
  FastCGI是语言无关的、可伸缩架构的CGI开放扩展,其主要行为是将CGI解释器进程保持在内存中并因此获得较高的性能。众所周 知,CGI解释器的反复加载是CGI性能低下的主要原因,如果CGI解释器保持在内存中并接受FastCGI进程管理器调度,则可以提供良好的性能、伸缩 性、Fail- Over特性等等。
  FastCGI与CGI特点
  1、如CGI,FastCGI也具有语言无关性.
  2、如CGI, FastCGI在进程中的应用程序,独立于核心web服务器运行,提供了一个比API更安全的环境。(APIs把应用程序的代码与核心的web服务器链接 在一起,这意味着在一个错误的API的应用程序可能会损坏其他应用程序或核心服务器; 恶意的API的应用程序代码甚至可以窃取另一个应用程序或核心服务器的密钥。)
  3、FastCGI技术目前支持语言有:C/C++、Java、Perl、Tcl、Python、SmallTalk、Ruby等。相关模块在Apache, ISS, Lighttpd等流行的服务器上也是可用的。
  4、如CGI,FastCGI的不依赖于任何Web服务器的内部架构,因此即使服务器技术的变化, FastCGI依然稳定不变。
  FastCGI的工作原理
  
  1、Web Server启动时载入FastCGI进程管理器(IIS ISAPI或Apache Module)
  
  2、FastCGI进程管理器自身初始化,启动多个CGI解释器进程(可见多个php-cgi)并等待来自Web Server的连接。
  
  3、当客户端请求到达Web Server时,FastCGI进程管理器选择并连接到一个CGI解释器。Web server将CGI环境变量和标准输入发送到FastCGI子进程php-cgi。
  
   4、FastCGI子进程完成处理后将标准输出和错误信息从同一连接返回Web Server。当FastCGI子进程关闭连接时,请求便告处理完成。FastCGI子进程接着等待并处理来自FastCGI进程管理器(运行在Web Server中)的下一个连接。 在CGI模式中,php-cgi在此便退出了。
  
  在上述情况中,你可以想象CGI通常有多慢。每 一个Web请求PHP都必须重新解析php.ini、重新载入全部扩展并重初始化全部数据结构。使用FastCGI,所有这些都只在进程启动时发生一次。 一个额外的好处是,持续数据库连接(Persistent database connection)可以工作。
  FastCGI的不足
  因为是多进程,所以比CGI多线程消耗更多的服务器内存,PHP-CGI解释器每进程消耗7至25兆内存,将这个数字乘以50或100就是很大的内存数。
  
   Nginx 0.8.46+PHP 5.2.14(FastCGI)服务器在3万并发连接下,开启的10个Nginx进程消耗150M内存(15M*10=150M),开启的64个php- cgi进程消耗1280M内存(20M*64=1280M),加上系统自身消耗的内存,总共消耗不到2GB内存。如果服务器内存较小,完全可以只开启25 个php-cgi进程,这样php-cgi消耗的总内存数才500M。
PHP-FPM、Spawn-FCGI分别是2种fastcgi管理方式
spawn-fcgi是一个通用的FastCGI管理服务器
她同样也是一个PHP FastCGI管理服务器,是只用于PHP的


您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

TOP技术积分榜 社区积分榜 徽章 团队 统计 知识索引树 积分竞拍 文本模式 帮助
  ITPUB首页 | ITPUB论坛 | 数据库技术 | 企业信息化 | 开发技术 | 微软技术 | 软件工程与项目管理 | IBM技术园地 | 行业纵向讨论 | IT招聘 | IT文档
  ChinaUnix | ChinaUnix博客 | ChinaUnix论坛
CopyRight 1999-2011 itpub.net All Right Reserved. 北京盛拓优讯信息技术有限公司版权所有 联系我们 未成年人举报专区 
京ICP备16024965号-8  北京市公安局海淀分局网监中心备案编号:11010802021510 广播电视节目制作经营许可证:编号(京)字第1149号
  
快速回复 返回顶部 返回列表