Apache-高并发下Apache+mongodb的php驱动不稳定如何解决?

发布于 2016-12-16 02:08:29 字数 387 浏览 1288 评论 1

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

测试代码 :

<?php
$db=new Mongo("mongodb://localhost:27017");
$c=$db->selectDB("npm")->selectCollection("user");
$user = $c->findOne(array('userName' => 'admin','passWord'=>'admin'));
if($user){
echo var_dump($user);
}
echo var_dump($db);
?>

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(1

泛泛之交 2017-05-26 23:07:41

1. 可以设置一下php mongo的pool size,在初始化Mongo对象之前

 MongoPool::setSize(100);

以便提高mongo的连接效率,特别是在大并发的情况下。

2. ab命令使用有误

你使用了-n 100,这个数目太小了,一般都要设置在上千次以上
你没有使用-c参数设置并发数,导致ab是根据总数的极限来压并发,这样并不科学
你应该使用

 ab.exe -n 1000 -c 100 http://192.168.15.21/a.php

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

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

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

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文