ruby – MongoDB:什么是连接池和超时?

所以我的Passenger旋转了我的Rails应用程序的5个实例

我使用Connection.new(“localhost”,3000,:pool_size => 1,:timeout => 5)连接到MongoDB

如果我在启动Rails应用程序时只产生开销,而不是按照请求,为什么我需要一个“连接池”?为什么单个进程需要多于1个连接?

超时的目的是什么?为什么我要连接超时?不应该坚持通过Rails流程的生命周期吗?

如此迷茫…

这个问题特定于Ruby和Mongo,但我想它适用于其他语言/数据库.

解决方法

您不需要在此处使用连接池.当您使用Passenger时,只需通过捕获start_worker_process事件确保每个实例都使用单独的连接.这在驱动程序README中有记录.

连接池对某些多线程应用程序非常有用. pool_size是连接将处理的最大并发线程数,timeout是线程在抛出异常之前可以等待可用套接字的最大秒数.

相关文章

validates:conclusion,:presence=>true,:inclusion=>{...
一、redis集群搭建redis3.0以前,提供了Sentinel工具来监控各...
分享一下我老师大神的人工智能教程。零基础!通俗易懂!风趣...
上一篇博文 ruby传参之引用类型 里边定义了一个方法名 mo...
一编程与编程语言 什么是编程语言? 能够被计算机所识别的表...
Ruby类和对象Ruby是一种完美的面向对象编程语言。面向对象编...