0

我在 mongoid.yml 中将 min_pool_size 设置为 100,但在运行 db.serverStatus().connections 时在 mongo 中我只得到 30。有没有办法检查池中有多少连接?

4

2 回答 2

0

连接到 admin 数据库并运行 db.serverStatus():

> var status = db.serverStatus()
> status.connections
  {"current" : 21, "available" : 15979}
> 
于 2019-02-20T16:33:33.590 回答
0

在 Ruby 驱动程序(以及因此 Mongoid)中设置 min_pool_size 并不意味着实际创建了许多网络连接。设置 min_pool_size 会创建那么多驱动连接对象,但它们会按需连接到集群。此行为已在驱动程序的 2.11.0 版本中修复 - 请参阅https://jira.mongodb.org/browse/RUBY-1605

要找出给定服务器实际打开了多少个套接字,首先获取它的连接池:

pool = Mongoid.default_client.cluster.next_primary.pool
# => #<Mongo::Server::ConnectionPool:0x46944310901400 queue=#<Mongo::Server::ConnectionPool::Queue:0x46944310901380 min_size=20 max_size=100 wait_timeout=1 current_size=20>>

然后查看连接中的套接字:

pool.send(:queue).queue.map { |conn| conn.send(:socket) }.compact.count
# => 0

Flight.count

pool.send(:queue).queue.map { |conn| conn.send(:socket) }.compact.count
# => 1

每台服务器都有一个额外的连接/套接字打开,用于监视目的,这是应用程序不可访问的。

请注意,上面发布的所有代码(next_primary、插入连接套接字等)都不是驱动程序公共 API 的一部分,并且可能随时更改。

于 2019-02-21T05:41:46.080 回答