Overview
在本指南中,您可以学习;了解.NET/ C#驱动程序如何使用连接池来管理与MongoDB 部署的连接,以及如何在应用程序中配置连接池设置。
连接池是由.NET/ C#驱动程序维护的打开数据库连接的缓存。当应用程序请求连接到MongoDB时, .NET/ C#驱动程序会无缝地从池中获取连接,执行操作,然后将连接返回到池中以供重用。
连接池有助于减少应用程序延迟和.NET/ C#驱动程序创建新连接的次数。下图从宏观角度说明了 MongoClient 如何管理连接池:
配置连接池
您可以在 MongoClient对象或连接 URI 中指定以下连接池设置:
| 设置 | 说明 | 
|---|---|
| 
 | The maximum amount of time that the .NET/C# Driver waits when establishing a new
connection before timing out. Data Type:  TimeSpanDefault: 30 seconds Connection URI Example:  connectTimeoutMS=0 | 
| 
 | The maximum number of connections that each pool can establish concurrently.
If this limit is reached, further requests wait until a connection is established
or another in-use connection is checked back into the pool. Data Type:  integerDefault:  2Connection URI Example:  maxConnecting=3 | 
| 
 | The maximum time that a connection can remain idle in the pool. When a connection
exceeds this limit, the .NET/C# Driver closes the connection and removes it from
the pool. Data Type:  TimeSpanDefault: 10 minutes Connection URI Example:  maxIdleTimeMS=60000 | 
| 
 | The maximum time that a connection can be pooled. When a connection exceeds this
limit, the .NET/C# Driver closes the connection and removes it from the pool. Data Type:  TimeSpanDefault: 30 minutes Connection URI Example:  maxLifeTimeMS=50000 | 
| 
 | The maximum number of concurrent connections that the pool maintains.
If the maximum pool size is reached, further requests wait until a connection
becomes available. Data Type:  integerDefault:  100Connection URI Example:  maxPoolSize=150 | 
| 
 | The minimum number of concurrent connections that the pool maintains. If
the number of open connections falls below this value due to network errors,
the .NET/C# Driver attempts to create new connections to maintain this minimum. Data Type:  integerDefault:  0Connection URI Example:  minPoolSize=3 | 
| 
 | The length of time that the .NET/C# Driver waits for a response from the server
before timing out. Data Type:  TimeSpanDefault: OS default Connection URI Example:  socketTimeoutMS=100000 | 
| 
 | How long a thread waits for a connection to become available in the connection pool
before timing out. Data Type:  TimeSpanDefault: 2 minutes Connection URI Example:  waitQueueTimeoutMS=100000 | 
以下代码使用 MaxConnectionPoolSize 参数创建最大连接池大小为 50 的客户端:
var settings = MongoClientSettings.FromConnectionString("<connection URI>"); settings.MaxConnectionPoolSize = 50; var client = new MongoClient(settings); 
以下代码创建一个配置与前面的示例相同的客户端,但使用了连接 URI:
var settings = MongoClientSettings.FromConnectionString("<hostname>?maxPoolSize=50"); var client = new MongoClient(settings); 
更多信息
要学习;了解有关连接池的更多信息,请参阅MongoDB Server手册中的 连接池概述。
API 文档
要进一步了解本指南所讨论的任何方法或类型,请参阅以下 API 文档: