MongoClient PHP sript永远运行

时间:2014-02-25 12:10:20

标签: php mongodb

我正在使用PHP mongoclient类连接mongodb远程主机。

我没有写过任何特别简单但简单的连接代码。

$connection_url = "mongodb://{$dbuser}:{$dbpass}@{$dburl}:{$dbport}/{$dbname}";         
$this->m = new MongoClient($connection);

它确实连接到mongodb但是经过一段时间我的应用程序挂起,挂起我的意思是php sript永远运行,没有响​​应,最后apache和我的服务器崩溃。我需要重新启动服务器才能重新启动它。

为什么PHP脚本永远在运行而且mongoserver没有响应。

我将max_execution_time设置为30秒。

MongoClient版本1.4.5

更新:

正如所解释here mongodb的默认连接和套接字时间是永不超时,我想,如果socket从MongoServer端关闭,可能是php MongoClient正在等待。

要确保我已将mongoclient的选项设置为在套接字关闭时不等待超过5秒,如下所示

$connection_url = "mongodb://{$dbuser}:{$dbpass}@{$dburl}:{$dbport}/{$dbname}";
$options = array('connectTimeoutMS' =>5000 , 'socketTimeoutMS' => 5000);
$this->m = new MongoClient($connection, $options);

但这仍然挂起

这是简短的Mongo Log

  

2:4:发现连接   somehost; - ; dbname / user / fd6da21ee7cf37731eb88e250d4a05d6; 1957(寻找   for somehost; - ; dbname / username / fd6da21ee7cf37731eb88e250d4a05d6; 1957)   2:2:mongo_get_read_write_connection:查找STANDALONE连接

     

2:4:发现连接   主机; - ; dbname / username / fd6da21ee7cf37731eb88e250d4a05d6; 1957(寻找   for hostname; - ; dnname / user / fd6da21ee7cf37731eb88e250d4a05d6; 1957)

     

2:2:is_ping:ping   主机名; - ; DBNAME /用户名/ fd6da21ee7cf37731eb88e250d4a05d6; 1957

'is_ping'后没有日志。这意味着我的脚本挂在这里。

更新

以下是挂起时正在使用和运行的进程

ps aux | sort -rk 3,3 | head -n 20
USER       PID %CPU %MEM    VSZ   RSS TTY      STAT START   TIME COMMAND
www-data 32612  0.0  1.1 108372  5604 ?        S    11:05   0:00 /usr/sbin/apache2 -k start
www-data 32390  0.0  1.1 108372  5604 ?        S    11:04   0:00 /usr/sbin/apache2 -k start
www-data 32389  0.0  1.4 109192  7348 ?        S    11:00   0:00 /usr/sbin/apache2 -k start
www-data 32388  0.0  1.4 109192  7376 ?        S    11:00   0:00 /usr/sbin/apache2 -k start
www-data 32387  0.0  1.4 109192  7376 ?        S    11:00   0:00 /usr/sbin/apache2 -k start
www-data 32386  0.0  1.2 108412  6100 ?        S    11:00   0:00 /usr/sbin/apache2 -k start
www-data 32385  0.0  1.8 111692  9432 ?        S    11:00   0:00 /usr/sbin/apache2 -k start
www-data 31833  0.0  1.5 109216  7548 ?        S    02:35   0:00 /usr/sbin/apache2 -k start
www-data 31173  0.0  1.5 108824  7872 ?        S    Mar02   0:00 /usr/sbin/apache2 -k start
www-data 15538  0.0  1.5 109216  7664 ?        S    Mar02   0:00 /usr/sbin/apache2 -k start
www-data 15536  0.0  1.4 109200  7496 ?        S    Mar02   0:00 /usr/sbin/apache2 -k start
www-data 15535  0.0  1.6 110904  8444 ?        S    Mar02   0:00 /usr/sbin/apache2 -k start
www-data 15534  0.0  1.3 108684  6536 ?        S    Mar02   0:00 /usr/sbin/apache2 -k start
whoopsie   847  0.0  0.5 187668  2676 ?        Ssl  Feb24   0:00 whoopsie
syslog     370  0.0  0.6 249676  3060 ?        Sl   Feb24   0:31 rsyslogd -c5
root       984  0.0  0.1  15792   908 tty1     Ss+  Feb24   0:00 /sbin/getty -8 38400 tty1
root       946  0.0  2.0 108348 10120 ?        Ss   Feb24   0:32 /usr/sbin/apache2 -k start
root         9  0.0  0.0      0     0 ?        S    Feb24   0:00 [rcu_bh]
root       879  0.0  0.0      0     0 ?        S<   Feb24   0:00 [kvm-irqfd-clean]

1 个答案:

答案 0 :(得分:0)

听起来像硬件问题或mongodb问题,如果有挂起的php脚本,服务器不需要重启...

但是,您可以尝试将用户名密码db添加到以下选项中:

function __construct($host, $username, $password, $db){
    $this->client = new MongoClient("mongodb://" . $host, array('username' => $username, 'password' => $password, 'db' => $db));
    $this->db = $this->client->selectDB($db);
}