我正在尝试用 Mason 用 Perl 编写一个网站。我使用以下内容设置服务器: - Apache 和 mod_perl 和 Mason - CGI::Session 用于管理会话 - MongoDB 用于数据库。
我担心的是,每次我连接到我的 MongoDB 数据库时,连接都会保持活动状态,直到我重新启动 httpd 服务。因此,如果达到最大连接数,我将无法再打开连接。
有没有人有办法:
- 要么关闭连接(这可能不是一个好主意)?
- 要么有一个了解架构的全局数据库连接池吗?
我正在尝试用 Mason 用 Perl 编写一个网站。我使用以下内容设置服务器: - Apache 和 mod_perl 和 Mason - CGI::Session 用于管理会话 - MongoDB 用于数据库。
我担心的是,每次我连接到我的 MongoDB 数据库时,连接都会保持活动状态,直到我重新启动 httpd 服务。因此,如果达到最大连接数,我将无法再打开连接。
有没有人有办法:
只要您的MongoClient
实例存在,MongoDB 驱动程序就会使连接保持活动状态。在类似的环境mod_perl
中,Perl 解释器是一个持久进程,全局变量将一直存在,直到它们被销毁。
如果您不希望连接是持久的,请创建一个MongoClient
对象,其范围将在 HTTP 请求周期完成时结束。当对象被垃圾收集时,连接将被关闭。
如果您使用有关如何创建客户端对象的更多详细信息更新您的问题,我可以提供更详细的答案。
我最近一直在和这个作斗争。我想出了一个对我有用的非常简单的解决方案。它可能不是最好的,但似乎完美地完成了这项工作。
我们使用 Mojolicious 作为在 apache2/mod_perl 下运行的 API 框架,并且我们发现新连接的建立速度比 perl MongoDB 驱动程序清理它们的速度更快,因为我们的网页正在调用 API 来获取新数据。
所以,我提出了一个简单的...
use strict;
use warnings;
use MongoDB;
our $conn;
if(!defined($conn)){
$log->info("Creating new DB connection");
$conn = MongoDB::MongoClient->new;
}
else{
$log->info("DB connection already exists");
}
sub fetchData {
# Do Mongo get/find stuff in here
my $dbh = $mongoConn->get_database($db);
my $collection = $dbh->get_collection($col);
my $cursor = $collection->find($q)->fields($fieldsObj);
my @result = $cursor->all;
return @result;
}
显然我已经省略了错误捕获,并且 else 不是必需的,但希望这将有助于像我这样寻找解决方案的人。