c# - 如何使用mongo数据库同时打开多个连接
问题描述
我在 Nginx Web 服务器的 Ubuntu OS 中构建 .NET Core 2.1 网站和 Mongo DB、驱动程序并部署在 AWS 服务器上
问题是当流量增加到 1400 个用户时网站关闭。.Net 核心日志为空,服务已启动并正在运行。Nginx 已启动并运行。
但是数据库日志当时打开了许多连接
数据库日志:
2019-04-05T10:41:51.545+0000 I NETWORK [listener] connection accepted from 10.142.0.4:32768 #50628 (999 connections now open)
2019-04-05T10:41:51.545+0000 I NETWORK [listener] connection accepted from 10.142.0.4:32770 #50629 (1000 connections now open)
2019-04-05T10:41:51.545+0000 I NETWORK [listener] connection accepted from 10.142.0.4:32772 #50630 (1001 connections now open)
2019-04-05T10:41:51.545+0000 I NETWORK [listener] connection accepted from 10.142.0.4:32774 #50631 (1002 connections now open)
2019-04-05T10:41:51.545+0000 I NETWORK [listener] connection accepted from 10.142.0.4:32776 #50632 (1003 connections now open)
2019-04-05T10:41:51.545+0000 I NETWORK [listener] connection accepted from 10.142.0.4:32778 #50633 (1004 connections now open)
2019-04-05T10:41:51.545+0000 I NETWORK [listener] connection accepted from 10.142.0.4:32780 #50634 (1005 connections now open)
2019-04-05T10:41:51.545+0000 I NETWORK [listener] connection accepted from 10.142.0.4:32782 #50635 (1006 connections now open)
2019-04-05T10:41:51.546+0000 I NETWORK [listener] connection accepted from 10.142.0.4:32784 #50636 (1007 connections now open)
2019-04-05T10:41:51.546+0000 I NETWORK [listener] connection accepted from 10.142.0.4:32786 #50637 (1008 connections now open)
2019-04-05T10:41:51.546+0000 I NETWORK [listener] connection accepted from 10.142.0.4:32788 #50638 (1009 connections now open)
2019-04-05T10:41:51.552+0000 I NETWORK [listener] connection accepted from 10.142.0.4:32790 #50639 (1010 connections now open)
C#连接数据库的方法:
private IMongoDatabase Connect(string con)
{
try
{
lock (padlock)
{
if (_db == null)
{
var mongoConnectionUrl = new MongoUrl(con);
var seetings = new MongoClientSettings
{
Server = new MongoServerAddress(mongoConnectionUrl.Server.Host, mongoConnectionUrl.Server.Port),
WaitQueueSize = 10000,
MaxConnectionPoolSize = 500,
Credential = MongoCredential.CreateCredential(mongoConnectionUrl.DatabaseName, mongoConnectionUrl.Username, mongoConnectionUrl.Password),
ConnectTimeout = TimeSpan.FromSeconds(60),
SocketTimeout = TimeSpan.FromSeconds(15),
MaxConnectionIdleTime = TimeSpan.FromSeconds(15),
};
void SocketConfigurator(Socket s) => s.SetSocketOption(SocketOptionLevel.Socket, SocketOptionName.KeepAlive, true);
seetings.ClusterConfigurator = builder =>
builder.ConfigureTcp(tcp => tcp.With(socketConfigurator: (Action<Socket>)SocketConfigurator));
MongoClient client = new MongoClient(seetings);
var database = client.GetDatabase(mongoConnectionUrl.DatabaseName);
var pack = new ConventionPack();
pack.Add(new CamelCaseElementNameConvention());
pack.Add(new IgnoreIfDefaultConvention(true));
pack.Add(new IgnoreExtraElementsConvention(true));
ConventionRegistry.Register("camel case", pack, t => true);
_db = database;
}
}
return _db;
}
catch (Exception ex)
{
throw new Exception("Error While connecting to db");
}
}
解决方案
您应该为整个应用程序仅使用一个 MongoClient 实例(如果您有一个数据库/mongo 集群)。根据您调用 Connect 方法的频率,以下行可能会导致打开的连接过多:
MongoClient client = new MongoClient(seetings);
Mongo 文档说:
通常,您只为给定集群创建一个 MongoClient 实例并在您的应用程序中使用它。但是,当且仅当连接字符串相同时,创建多个 MongoClients 仍将共享相同的连接池。
在您的情况下,您使用的是设置对象,所以我不确定 Mongo 是否能够真正合并您的所有客户端,但这应该很容易测试。
推荐阅读
- javascript - Jquery:window.unload 不适用于 chrome 72.0.3626.109
- qt - 在中继器内动态创建 QML 组件
- java - 线程安全对象数组
- c# - 带有 Selenium 的下拉框和 span-Dropdownbox
- database - 对于简单的 Key-Value 模式,Redis 客户端和 Postgres 客户端之间的 YugaBytes 性能如何比较?
- ionic4 - Ionic 4 选项卡样式
- docker - 尽管容器正在运行,但运行 docker -ps 会返回一个空列表
- c# - 项目无法在 Visual Studio 中打开
- java - 如何使用 IText 中的链接从同一 PDF 文件中的一页导航到另一页?
- mongodb - kubernetes-helm:用 xfs 格式格式化 do-block-storage