MongoDB:什么是连接池和超时?
所以我的Passenger旋转了我的Rails应用程序的5个实例
我使用Connection.new(“localhost”,3000,:pool_size => 1,:timeout => 5)连接到MongoDB
如果我在启动Rails应用程序时只产生开销,而不是按照请求,为什么我需要一个“连接池”? 为什么单个进程需要多于1个连接?
超时的目的是什么? 为什么我要连接超时? 不应该坚持通过Rails流程的生命周期吗?
如此迷茫…
这个问题特定于Ruby和Mongo,但我想它适用于其他语言/数据库。
您不需要在此处使用连接池。 当您使用Passenger时,只需通过捕获start_worker_process事件确保每个实例都使用单独的连接。 这在驱动程序README中有记录。
连接池对某些multithreading应用程序非常有用。 pool_size是连接将处理的最大并发线程数,timeout是线程在抛出exception之前可以等待可用套接字的最大秒数。