大佬教程收集整理的这篇文章主要介绍了Azure Cosmos DB - 间歇性 MongoConnectionException / IOException / SocketException,大佬教程大佬觉得挺不错的,现在分享给大家,也给大家做个参考。
我将 Azure Cosmos DB 4.0 与 MongoDB C# 驱动程序 2.10.4 结合使用。
大多数时候查询工作正常,但我遇到了这样的间歇性错误:
@H_414_2@mongoDB.Driver.Mongoconnectionexception:向服务器发送消息时发生异常。 System.IO.IOException:无法将数据写入传输连接:远程主机强行关闭了现有连接。 System.Net.sockets.socketException: 一个现有的连接被远程主机强行关闭 在 System.Net.sockets.socket.beginSend(... 在 System.Net.sockets.NetworkStream.beginWrite --- 内部异常堆栈跟踪结束 --- 在 System.Net.sockets.NetworkStream.beginWrite 在 System.Net.Security._SslStream.StartWriTing 在 System.Net.Security._SslStream.ProcessWrite 在 System.Net.Security._SslStream.beginWrite发生该错误时,调用需要 10-25 秒才能失败。
我正在使用 new MongoClIEnt(MongoClIEntSetTings.FromConnectionString(cnstr))
构建 MongoClIEnt,并且我使用的是带有这些参数 ?ssl=true&replicaset=globaldb&retrywrites=false
的连接字符串。
我尝试使用 retryWrites=true
(根据 Azure 支持建议),但这没有帮助。
我尝试了不同的设置,但都不起作用(connect=direct
、@H_704_11@maxIDleTimeMS=30000、serverSELEctionTimeout=5000ms
、socketTimeout=10000ms
)。
导致这些异常的原因是什么?
修复是设置/强制使用 TLS 1.2(基于 this Microsoft document):
//return new MongoClient(connectionString);
var setTings = MongoClientSetTings.FromConnectionString(connectionString);
setTings.SslSetTings = new SslSetTings()
{
EnabledSslProtocols = System.Security.Authentication.SslProtocols.Tls12
};
return new MongoClient(setTings);
看起来虽然我的连接字符串有 ssl=true
,但在某些服务器上还不够(错误是间歇性的)。 forcing TLS 1.2 通常可以修复相同的潜在错误,因此我认为在 Mongo 中它可能是相同的问题 - 它确实解决了问题。
以上是大佬教程为你收集整理的Azure Cosmos DB - 间歇性 MongoConnectionException / IOException / SocketException全部内容,希望文章能够帮你解决Azure Cosmos DB - 间歇性 MongoConnectionException / IOException / SocketException所遇到的程序开发问题。
如果觉得大佬教程网站内容还不错,欢迎将大佬教程推荐给程序员好友。
本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。