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

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中的操作(如下图)实际上是从池中找可用的链接。当最大并发连接数很大,那么查找的范围更多,更有可能找到物理链接开启的链接。反之则越少。

所以测试的时候也尽可能将数量设的更多一点。

相关推荐
人鱼传说9 分钟前
docker desktop是一个好东西
运维·docker·容器
Thera77737 分钟前
【Linux C++】彻底解决僵尸进程:waitpid(WNOHANG) 与 SA_NOCLDWAIT
linux·服务器·c++
阿梦Anmory42 分钟前
Ubuntu配置代理最详细教程
linux·运维·ubuntu
呉師傅1 小时前
【使用技巧】Adobe Photoshop 2024调整缩放与布局125%后出现点菜单项漂移问题的简单处理
运维·服务器·windows·adobe·电脑·photoshop
heartbeat..1 小时前
JVM 性能调优流程实战:从开发规范到生产应急排查
java·运维·jvm·性能优化·设计规范
小Tomkk1 小时前
数据库 变更和版本控制管理工具 --Bytebase 安装部署(linux 安装篇)
linux·运维·数据库·ci/cd·bytebase
赌博羊1 小时前
ImportError: /lib/x86_64-linux-gnu/libc.so.6: version `GLIBC_2.32‘ not found
linux·运维·gnu
getapi2 小时前
Ubuntu 22.04 服务器的系统架构是否为 amd64 x86_64
linux·服务器·ubuntu
消失的旧时光-19432 小时前
Linux 入门核心命令清单(工程版)
linux·运维·服务器
艾莉丝努力练剑2 小时前
【Linux:文件】Ext系列文件系统(初阶)
大数据·linux·运维·服务器·c++·人工智能·算法