我在 mongoid.yml 中将 min_pool_size 设置为 100,但在运行 db.serverStatus().connections 时在 mongo 中我只得到 30。有没有办法检查池中有多少连接?
问问题
730 次
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 回答