docker部署.Net5连接SqlServer出现 error: 31handshake failed
Posted on 2021-07-29 19:58 李朝强 阅读(957) 评论(0) 编辑 收藏 举报之前的文章中,我们介绍了.netcore3.1连接sqlserver数据库时出现类似:A connection was successfully established with the server, but then an error occurred during the pre-login handshake. (provider: TCP Provider, error: 35 - An internal exception was caught),这样的一段错误信息。在我《.NetCore3.1发布在CentOS后连接SqlServer数据库异常(SslException)》这篇文章中有所提及,原因都非常简单,一句话,都是因为“在数据库登录验证阶段使用了 SSL,导致身份验证不通过。允许的 ssl 最低版本和 SQL Server 数据库版不匹配”在当时的情况下,只需要修改容器环境的(/etc/ssl/openssl.cnf)文件中,安全级别对最低协议版本的要求即可,将MinProtocol=TLSv1.2,改为MinProtocol=TLSV1.0即可,重启容器后,该种问题确实得到了解决。但是,情况总有例外。比如,在进行使用.net5部署的项目中,同样的问题,采用同样的处理方法,问题依然存在。在经过上面的调整后,出现了下面的错误:
A connection was successfully established with the server, but then an error occurred during the pre-login handshake. (provider: SSL Provider, error: 31 - Encryption(ssl/tls) handshake failed)
又是TCP握手时发生错误,协议配置仍有问题。
解决这样的问题,问题的根本原因, 还是.net5不支持CipherString = DEFAULT@SECLEVEL=2的配置。
SECLEVEL=2不行,改成1吧,于是将CipherString = DEFAULT@SECLEVEL=1。改完后,重启容器再试,问题依然存在。后来研究发现,
MinProtocol = TLSv1.0 这个配置中TLSv1.0有些问题,于是我将TLSv1.0 改成了TLSv1,.1不要了,重启容器再试,可以了。
关于如何修改SECLEVEL的值,其实很简单,和修改TLSv1.2原理一样,有的朋友,也可以通过docker copy命令,将修改后的文件,拷贝到容器中,替换即可。
~ 2021/07/29随笔
人之为学,如饮河海,大饮则大盈,小饮则小颖!
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· 单线程的Redis速度为什么快?
· SQL Server 2025 AI相关能力初探
· AI编程工具终极对决:字节Trae VS Cursor,谁才是开发者新宠?
· 展开说说关于C#中ORM框架的用法!