郁闷的SQL2005多实例安装和远程连接
今天项目要求在同一服务器上安装SQL2000和SQL2005,安装过程很简单,SQL2000默认,SQL2005指定实例名称,结果2000ok了,2005本机可以访问,远程死活连不上,md
1.2000默认端口1433,2005需要改改,改了就需要设置SQL Browser,不然over找不到端口
下面是搜索到的内容,看完看第二条:服务器上安装完成后,准备用远程连接SQL服务器试试,结果始终连接不上SQL2005,只能连接上SQL2000.原来SQL2000服务器用的端口始终是1433端口,而SQL2005使用的是动态端口.那如果用程序连接SQL20005服务器的时候,程序如何知道SQL2005服务器用的是什么端口呢?原来SQL2005提供了一个SQL BROWER服务,开启这个服务后,就可以通过查询SQL BROWER服务 就可以知道SQL2005现在正在使用哪个端口.因为项目需要,需要把这个SQL2005的动态端口改成静态的,修改过程如下:
运行SQL配置管理程序,找到SQL的实例名称下面的协议,双击右边的TCP/IP协议,在第二选项卡中IPALL里面输入SQL运行的端口就可以了(注意不能同时填写动态端口和静态端口,否则SQL下次将无法启动),修改完成后重新启动SQL服务即可生效.
2.修改端口后在连接发现仍然不能连接,原来还需要开启SQL2005的远程登陆服务.
在Microsoft SQL Server 2005中默认的是不允许远程登录的,会出现【provider: SQL 网络接口, error: 26 – 定位指定的服务器/实例时出错】的错误,下面的方法可以打开:
配置工具->sql server外围应用配置器->服务和连接的外围应用配置器->打开MSSQLSERVER节点下的Database Engine 节点,先择”远程连接”,接下建议选择”同时使用TCP/IP和named pipes”,确定后,重启数据库服务就可以。
3.远程登陆服务和端口都修改之后连接应该没有问题了吧,结果远程连接SQL2000的时候发现没有问题,但是连接SQL20005依然不行,在SQL2005的客户端连接工具里面需要输入你要连接的SQL服务,SQL2000的直接输入服务器的IP地址即可,那如何输入才能让客户端工具连接到SQL2005的服务呢?既然SQL2005修改了端口,那按照常规的录入格式应该是输入:IP地址+冒号+端口号应该就可以了.结果试了一下发现依然不行.后又修改了客户端的连接的默认端口,结果仍然不行.没办法了只有到网上GOOGLE了一翻,结果终于在一篇英文文章中找到了连接的方法,原来按照常规的格式录入是错误的,
需要改成:IP地址+逗号+端口号才行. #我无语了*&%^@!#%^&%!#
现在一试果然可以.然后在试着通过.NET程序访问看能否连接,结果都可以.
总结:就是因为连接输入的格式错误就害得我弄了一天才找到办法,真是郁闷,不知道SQL2005为什么不用常规的方法,而要把冒号改成逗号连接......
按上面 的操作还不行,试试将连接字符串中的server改成server=.\mssql9。mssql9是实例名,我用这个试成功了,但是IP+端口还是不行,后来发现是“IPALL里面输入SQL运行的端口”,我却弄成IP1和IP2里面去输入了。
Clove 2011-03-23
分享到: | |
没有评论