SQL SERVER TELNET 连接失败

内容转自:http://david.btbbt.blog.163.com/blog/static/205989372009973357418/

 

登录远程SQL服务器
一 看ping 服务器IP能否ping通。

  这个实际上是看和远程sql server 2000服务器的物理连接是否存在。如果不行,请检查网络,查看配置,当然得确保远程sql server 2000服务器的IP拼写正确。

  二 在Dos或命令行下输入telnet 服务器IP 端口,看能否连通。

  如telnet 202.114.100.100 1433

  通常端口值是1433,因为1433是sql server 2000的对于Tcp/IP的默认侦听端口。如果有问题,通常这一步会出问题。通常的提示是“……无法打开连接,连接失败"。

  如果这一步有问题,应该检查以下选项。

  1 检查远程服务器是否启动了sql server 2000服务。如果没有,则启动。

  2 检查服务器端有没启用Tcp/IP协议,因为远程连接(通过因特网)需要靠这个协议。检查方法是,在服务器上打开开始菜单->程序->Microsoft SQL Server->服务器网络实用工具,看启用的协议里是否有tcp/ip协议,如果没有,则启用它。

  3 检查服务器的tcp/ip端口是否配置为1433端口。仍然在服务器网络实用工具里查看启用协议里面的tcp/ip的属性,确保默认端口为1433,并且隐藏服务器复选框没有勾上。

  事实上,如果默认端口被修改,也是可以的,但是在客户端做telnet测试时,写服务器端口号时必须与服务器配置的端口号保持一致。如果隐藏服务器复选框被勾选,则意味着客户端无法通过枚举服务器来看到这台服务器,起到了保护的作用,但不影响连接,但是Tcp/ip协议的默认端口将被隐式修改为 2433,在客户端连接时必须作相应的改变。

  4 如果服务器端操作系统打过sp2补丁,则要对windows防火墙作一定的配置,要对它开放1433端口,通常在测试时可以直接关掉windows防火墙(其他的防火墙也关掉最好)。

  5 检查服务器是否在1433端口侦听。如果服务器没有在tcp连接的1433端口侦听,则是连接不上的。检查方法是在服务器的dos或命令行下面输入

  netstat -a -n 或者是netstat -an,在结果列表里看是否有类似 tcp 127.0.0.1 1433 listening 的项。如果没有,则通常需要给sql server 2000打上至少sp3的补丁。其实在服务器端启动查询分析器,输入 select @@version 执行后可以看到版本号,版本号在8.0.2039以下的都需要打补丁。

  如果以上都没问题,这时你再做telnet 服务器ip 1433 测试,将会看到屏幕一闪之后光标在左上角不停闪动。恭喜你,你马上可以开始在企业管理器或查询分析器连接了。

  三 检查客户端设置

  程序->Microsoft SQL Server -> 客户端网络使用工具。像在服务器网络实用工具里一样,确保客户端tcp/ip协议启用,并且默认端口为1433(或其他端口,与服务器端保持一致就行)。

  四 在企业管理器里或查询那分析器连接测试

  企业管理器->右键SQlserver组->新建sqlserver注册->下一步->写入远程IP->下一步 ->选Sqlserver登陆->下一步->写入登陆名与密码(sa,password)->下一步->下一步-> 完成

  查询分析器->文件->连接->写入远程IP->写入登录名和密码(sa,password)->确定

  通常建议在查询分析器里做,因为默认情况下,通过企业管理器注册另外一台SQL Server的超时设置是4秒,而查询分析器是15秒。

  修改默认连接超时的方法:

  企业管理器->工具->选项->在弹出的"SQL Server企业管理器属性"窗口中,点击"高级"选项卡->连接设置->在 登录超时(秒) 后面的框里输入一个较大的数字

  查询分析器->工具->选项->连接->在 登录超时(秒) 后面的框里输入一个较大的数字

  通常就可以连通了,如果提示错误,则进入下一步。

  五 错误产生的原因通常是由于SQL Server使用了"仅 Windows"的身份验证方式,因此用户无法使用SQL Server的登录帐户(如 sa )进行连接。解决方法如下所示:

  1 在服务器端使用企业管理器,并且选择"使用 Windows 身份验证"连接上 SQL Server。

  2 展开"SQL Server组",鼠标右键点击SQL Server服务器的名称,选择"属性",再选择"安全性"选项卡。

  3 在"身份验证"下,选择"SQL Server和 Windows "。

  4 重新启动SQL Server服务。(在dos或命令行下面net stop mssqlserver停止服务,net start mssqlserver启动服务,也是一种快捷的方法)。

  附注:在连接本地服务器时,通常使用的是命名管道协议(在服务器网络实用工具里可以看到启用的协议有这个),默认端口是445,因此在本地能连通是不能说明什么问题的,连接远程服务器是完全不同的协议。

### SQL Server 2019 连接失败解决方案 #### 错误原因分析 当遇到SQL Server数据库连接失败错误时,常见的原因是身份验证模式设置不正确。例如,在尝试使用`sa`账户登录时可能会收到如下错误消息:“Microsoft OLE DB Provider for SQL Server (0x80004005) 用户 'sa' 登录失败。原因: 未与信任 SQL Server 连接相关联。”这表明当前的身份验证方式不允许通过指定的用户名和密码进行认证[^1]。 另外一种情况是SQL Server服务未能正常启动,如在配置管理器中观察到的服务状态为“已停止”,并且更改其状态至“正在运行”的操作也遭遇了障碍,提示信息指出可能存在权限不足或者其他内部错误阻止了服务的成功激活[^2]。 最后,网络层面的因素同样不可忽视。如果目标机器位于局域网外,则需确认防火墙规则允许必要的通信端口开放;同时也要保证客户端能够成功解析并访问服务器地址,以及确保TCP/IP协议栈工作正常以便建立稳定的数据传输链路[^3]。 #### 解决方案概述 针对上述提到的各种潜在问题,可以采取以下措施来排查并修复: - **调整身份验证模式** - 打开SQL Server Management Studio(SSMS),右键点击实例名称选择属性。 - 导航至安全性选项卡,切换混合模式(Mixed Mode Authentication)以支持WindowsSQL Server两种类型的账号登陆。 ```sql ALTER LOGIN sa WITH PASSWORD='YourStrong!Passw0rd'; GO ALTER LOGIN sa ENABLE; GO ``` - **重启SQL Server服务** - 使用管理员权限打开命令行工具(cmd.exe), 输入 `services.msc` 启动服务控制台。 - 查找对应版本的SQL Server条目(比如 "MSSQLSERVER" 或者带有特定实例名的部分),先停止再重新开启该进程。 - **启用远程连接功能** - 在SSMS内展开左侧的对象资源管理器树形结构找到对应的服务器节点。 - 双击进入“属性->连接”页面勾选允许来自其他计算机上的远程连接复选框。 - 修改注册表路径下的参数值(HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Microsoft SQL Server\MSSQL.x\MSSQLServer\SuperSocketNetLib\TcpIp\Ports),将其设为固定监听端口号(如1433),然后保存退出即可生效。 - **检查网络状况** - 尝试利用ping指令测试两台主机间的基础连通性。 - 利用telnet命令模拟简单的socket握手过程(`telnet <server_ip> 1433`),以此判断是否有任何中间件阻碍实际业务流量交互。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值