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. |
| 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. |
| 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. |
| 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. |
| 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. |
| 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. |
| The length of time that the .NET/C# Driver waits for a response from the server before timing out. |
| How long a thread waits for a connection to become available in the connection pool before timing out. |
以下代码使用 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 文档: