文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

SQL Server :已成功与服务器建立连接,但是在登录前的握手期间发生错误。

2023-09-09 10:58

关注

SQL Server 登录数据库报错:已成功与服务器建立连接,但是在登录前的握手期间发生错误。

学习sqlserver的时候,默认的身份验证是windows的身份验证。
而在进一步学习的时候希望改成sqlserver的身份验证。操作流程无非就是选中服务器——》右击属性
在这里插入图片描述
再按如下图选择,当然sqlserver有默认的身份验证账号,sa,操作教程也有,这里不谈。我也是按如此操作的
在这里插入图片描述
当然我画蛇添足的选择,讲最大并发连接数改成了2,导致出现问题:已成功与服务器建立连接,但是在登录前的握手期间发生错误。

在这里插入图片描述
看之前博主说出现该错误的原因就是因为最大并发数的问题,那么修改最大并发数就可以避免该错误,可是问题是,当出现该错误的时候,我们往往操作不了服务器。
经验下来的操作就是,1、不停重启服务器,重启之后试试属性是否可以调试。2、不停断开再连接,连接后试试属性是否可以调试。
修改连接数为0,问题即可解决。

解决了这个问题,那么为什么最大并发数不为0就会出现这个错误?
1、最大并发连接是什么概念?
sqlserver中的最大并发连接数(max pool size)就是你能同时有多少个到sqlserver数据库的连接。
默认是100, 理论最大为32767,
2、为什么数量过低会出现上述错误
来自微软:https://learn.microsoft.com/zh-cn/sql/connect/ado-net/sql-server-connection-pooling?view=sql-server-ver16
在这里插入图片描述
啥意思呢?
就是说我们逻辑上同过程序和数据库建立连接,其实是一种极耗费资源的过程
为了减少资源消耗,提高利用率
sqlserver采用了一个新技术——连接池
这个连接池是什么意思呢?
池程序维持物理连接的所有权。 通过为每个给定的连接配置保留一组活动连接来管理连接。 每当用户在连接上调用 Open 时,池进程就会查找池中可用的连接。 如果某个池连接可用,会将该连接返回给调用者,而不是打开新连接。 应用程序在该连接上调用 Close 时,池进程会将连接返回到活动连接池集中,而不是关闭连接。 连接返回到池中之后,即可在下一个 Open 调用中重复使用。
所以程序当中建立连接,和我们在ssms中的操作(如下图)实际上是从池中找可用的链接。当最大并发连接数很大,那么查找的范围更多,更有可能找到物理链接开启的链接。反之则越少。
在这里插入图片描述
所以测试的时候也尽可能将数量设的更多一点。

来源地址:https://blog.csdn.net/ameacy/article/details/131574895

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-服务器
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯