php 量 高并发 nosql,nosql - 高并发下Apache+mongodb的php驱动不稳定

我的环境 : Apache/2.2.21 (Win32) PHP/5.4.3

6a14b504f2de8321eb18ed38a45a440f.png

388d3098554aed00075592303c201740.png

测试代码 :

selectDB("npm")->selectCollection("user");

$user = $c->findOne(array('userName' => 'admin','passWord'=>'admin'));

if($user){

echo var_dump($user);

}

echo var_dump($db);

?>

使用apache并发测试工具 ab.exe 测试,测试命令如下

D:\Apache2.2\bin>ab.exe -n 100 http://192.168.15.21/a.php

测试结果:

Concurrency Level: 1

Time taken for tests: 0.266 seconds

Complete requests: 100

Failed requests: 58

(Connect: 0, Receive: 0, Length: 58, Exceptions: 0)

Write errors: 0

Total transferred: 888192 bytes

HTML transferred: 870668 bytes

Requests per second: 376.47 [#/sec] (mean)

Time per request: 2.656 [ms] (mean)

Time per request: 2.656 [ms] (mean, across all concurrent requests)

Transfer rate: 3265.41 [Kbytes/sec] received

php错误信息:

[13-Jun-2012 07:40:26 UTC] PHP Notice: Unknown: localhost:27017: pool done (0x3877a10) in Unknown on line 0

回复内容:

我的环境 : Apache/2.2.21 (Win32) PHP/5.4.3

6a14b504f2de8321eb18ed38a45a440f.png

388d3098554aed00075592303c201740.png

测试代码 :

selectDB("npm")->selectCollection("user");

$user = $c->findOne(array('userName' => 'admin','passWord'=>'admin'));

if($user){

echo var_dump($user);

}

echo var_dump($db);

?>

使用apache并发测试工具 ab.exe 测试,测试命令如下

D:\Apache2.2\bin>ab.exe -n 100 http://192.168.15.21/a.php

测试结果:

Concurrency Level: 1

Time taken for tests: 0.266 seconds

Complete requests: 100

Failed requests: 58

(Connect: 0, Receive: 0, Length: 58, Exceptions: 0)

Write errors: 0

Total transferred: 888192 bytes

HTML transferred: 870668 bytes

Requests per second: 376.47 [#/sec] (mean)

Time per request: 2.656 [ms] (mean)

Time per request: 2.656 [ms] (mean, across all concurrent requests)

Transfer rate: 3265.41 [Kbytes/sec] received

php错误信息:

[13-Jun-2012 07:40:26 UTC] PHP Notice: Unknown: localhost:27017: pool done (0x3877a10) in Unknown on line 0

首先建议你设置一下php mongo的pool size,在你初始化Mongo对象之前MongoPool::setSize(100);

这样可以提高mongo的连接效率,特别是在大并发的情况下。另外,你的ab命令使用有误你使用了-n 100,这个数目太小了,一般都要设置在上千次以上

你没有使用-c参数设置并发数,导致ab是根据总数的极限来压并发,这样并不科学

你应该使用ab.exe -n 1000 -c 100 http://192.168.15.21/a.php

这样是在100的并发下,完成1000次请求。你可以根据自己的情况调整这两个参数。

最后要说的是,有时候出现报错,并不是不稳定,每个服务器都有它的极限,比如你现在用的是windows xp来测试服务器性能,它的硬件,还有软件优化程度(比如半开连接数),都会很大的影响最终性能。

如果你想科学的测试服务器性能,建议使用专门的服务器,并选用经过标准优化了的linux操作系统。

Try the lastest version of mongo php driver

Check this out:

https://github.com/mongodb/mongo-php-...

本文原创发布php中文网,转载请注明出处,感谢您的尊重!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值