解决SQL Server管理器无法连接远程数据库的问题(转)

摘要:
请记住,在SQL Server服务重新启动之前,所有更改都无法生效!在Windows防火墙中打开SQL Server的端口号时,在多次设置数据库服务器本身之后,我们仍然无法成功建立远程连接。此时,我们应该考虑防火墙是否做错了什么。默认情况下,许多端口号和服务被防火墙禁止,无法远程访问或执行。SQL Server的默认端口号也不例外。启用此服务将影响服务器上已安装的所有SQL Server实例。通常重新创建数据库别名以创建SQL Server别名并在应用程序中使用它。

    add by zhj: 本文最后那个数据库别名没搞明白,在我的测试中没有建别名,是可以的。远程登陆时,服务器名称: 服务器IP,端口号 (如223.42.155.248,52134 如果是默认端口号1433,则可省略端口号)

原文:http://www.cnblogs.com/jaxu/archive/2010/11/23/1884411.html

    许多初学者在使用SQL Server时都会遇到使用SQL Server Management Studio无法连接远程数据库实例的问题,大致的错误描述如下:

An error has occurred while establishing a connection to the server.

(provider: Named Pipes Provider, error: 40 – Could not open a connection to SQL Server) (Microsoft SQL Server, Error: 5)

An error has occurred while establishing a connection to the server.  When connecting to SQL Server 2005, this failure may be caused by the fact that under the default settings SQL Server does not allow remote connections. (provider: Named Pipes Provider, error: 40 – Could not open a connection to SQL Server) (Microsoft SQL Server, Error: 1326)

  意思是说不能在数据库之间建立一个连接,原因是命名管道提供者出现错误。其实这是一个比较典型的数据库服务器设置问题,在局域网或广域网中都可能会遇到,我们只需要对数据库服务器进行一些配置便可以解决这个问题,来看看具体的步骤。

确保服务器端数据库服务已经启动

  开始->所有程序->Microsoft SQL Server 2008->Configutation Tools,打开SQL Server Configuration Manager,点击SQL Server Services,查看数据库服务是否已经启动,如果服务未开启,手动启动它。当然,你还可以通过点击Windows中的开始->控制面板 ->管理者工具->服务,来查看相应的数据库服务是否启动。或者如果服务器和你的机器在同一网络,你还可以通过命令“sqlcmd -L”(注意L要大写)去查看该网络内所有可用的SQL Server服务器。

解决SQL Server管理器无法连接远程数据库的问题(转)第1张
 

在SQL Server Configuration中启用TCP/IP

   多个SQL Server服务器之间通过网络相互通信是需要TCP/IP支持的,为使SQL Server服务器能被远程连接必须确保TCP/IP已经启用。按照前面介绍的步骤打开SQL Server Configuration Manager,然后打开SQL Server Network Configuration,选择你要设置的数据库,然后点击TCP/IP,右键启用。如果有必要,你还可以启用Named Pipes。记住,所有的修改都必须在重启SQL Server服务之后才能生效!

解决SQL Server管理器无法连接远程数据库的问题(转)第2张

在Windows防火墙中打开SQL Server的端口号

  很多时候我们在对数据库服务器本身做了很多次设置后仍然无法成功建立远程连接,这时就要考虑是否是防火墙在作怪。默认情况下,许多端口号和服务 都会被防火墙所禁止而不能远程访问或执行,SQL Server默认的端口号也不例外。我们应该重新设置Windows防火墙给SQL Server添加例外。除非人为修改,默认情况下SQL Server的端口号是1433,将该端口号添加到Windows防火墙中。如果SQL Server存在命名实例,那么也应该将SQL Server browser添加到Windows防火墙中。(有关SQL Server的命名实例将在后面介绍)

  打开Windows控制面板,选择Windows防火墙->Change Settings->Exceptions->Add Port

解决SQL Server管理器无法连接远程数据库的问题(转)第3张
解决SQL Server管理器无法连接远程数据库的问题(转)第4张

  点击Add port...在弹出的对话框中填入:

  Name: SQL

  Port Number: 1433

  Protocol: Select TCP

解决SQL Server管理器无法连接远程数据库的问题(转)第5张
解决SQL Server管理器无法连接远程数据库的问题(转)第6张

在SQL Server管理器中启用远程连接

   这一步通常会被数据库管理员忽略,如果未启用数据库远程连接,数据库实例只允许在本地进行连接而不能被远程连接,启用远程连接同样非常重要。 默认设置中远程连接是被禁止的。如下图,打开SQL Server Management Studio,右键点击数据库实例然后选择属性菜单。

解决SQL Server管理器无法连接远程数据库的问题(转)第7张

   在打开的窗口中,左侧选择Connections,然后勾选"Allow remote connections to this server"。

解决SQL Server管理器无法连接远程数据库的问题(转)第8张

启用SQL Server Browser服务

   如果SQL Server在安装时不是用的默认实例名而是自定义的实例名,并且没有配置特定的TCP/IP端口号,那么按照我们前面的描述SQL Server仍然不能支持远程连接。但如果你启用的SQL Server Browser服务,便可以通过动态TCP/IP端口号进行远程SQL Server连接。启用SQL Server Browser服务非常简单,与启用SQL Server类似,在SQL Server Configuration Manager中右键点击SQL Server Browser,然后选择启用。启用该服务将会影响到服务器上所有已安装的SQL Server实例。

解决SQL Server管理器无法连接远程数据库的问题(转)第9张

在防火墙中为sqlbrowser.exe应用程序创建例外

  我们在前面已经提到了,自定义命名的SQL Server实例要支持远程连接需要启用sqlbrowser服务,Windows防火墙可能会阻止该服务执行。因此,我们必须在Windows防火墙中给sqlbrowser服务添加例外。

  首先找到服务器上安装sqlbrowser.exe程序的路径,如C:Program FilesMicrosoft SQL Server90Sharedsqlbrowser.exe。如果不确定SQL Server安装在什么地方,你可以在Windows搜索一下文件名。与我们在前面介绍的在防火墙中添加SQL TCP/IP端口号的方法类似,给sqlbrowser.exe应用程序添加防火墙例外。

重新创建数据库别名

  创建SQL Server别名并在应用程序中使用它很常见。使用数据库别名可以确保一旦数据库的位置发生了变化,如更换了新的服务器,IP地址发生了变化等,应用程序 中的数据库连接字符串不用修改。否则你更换了数据库的位置,你还要通知所有使用该数据库的应用程序修改源代码或配置文件中的连接字符串,这恐怕是不可能 的。所以,使用数据库别名来配置连接字符串是一个非常明智的选择。另外,你还可以使用相同的别名来指向不同的数据库实例,当修改别名参数时,可以马上实现 数据库之间的切换。创建数据库别名非常简单,在SQL Server Configuration Manager中选择Aliases进行创建。

解决SQL Server管理器无法连接远程数据库的问题(转)第10张

免责声明:文章转载自《解决SQL Server管理器无法连接远程数据库的问题(转)》仅用于学习参考。如对内容有疑问,请及时联系本站处理。

上篇修改linux主机名与配置ssh通过主机名进行远程登录龙芯电脑编译安装openssl下篇

宿迁高防,2C2G15M,22元/月;香港BGP,2C5G5M,25元/月 雨云优惠码:MjYwNzM=

相关文章

php的数据库操作(微擎,tp,yii2)

微擎数据库操作 关键字 查询pdo_get pdo_getcolumn pdo_getall pdo_getslice pdo_fetchcolumn pdo_fetchall 示例: array | boolean pdo_get($tablename, $condition = array(), $fields = array());//表名,条件,...

SQL Server ErrorLog 错误日志(如果数据库所占空间变大)

默认情况下,SQL Server 保存 7 个 ErrorLog 文件,名为: ErrorLog ErrorLog.1 ErrorLog.2 ErrorLog.3 ErrorLog.4 ErrorLog.5 ErrorLog.6 在 APACS OS 版本 6.1 中,ErrorLog 文件保存在 c:\Program Files\Microsoft...

网络编程bind函数详解(转载)

注:该文转载自https://blog.csdn.net/zpznba/article/details/90763798 bind 函数如何选择绑定地址 我们知道bind函数一般用在服务器代码中: struct sockaddr_in bindaddr; bindaddr.sin_family = AF_INET; bindaddr.sin_addr.s_...

MySQL多实例配置(两)

    MySQL操作和维护一个集中的数据库的。它可以由一个单一的执行MySQL在数据库服务器,部署多MySQL示例。这个功能是由mysqld_multi实现。mysqld_multimysqld的服务进程。这些mysqld服务进程程序能够用不同的socket或是监听于不同的端口,同一时候将数据文件分布到不同的磁盘以分散IO。 mysqld_multi提...

Phpstudy+WordPress安装详解

Phpstudy+WordPress安装详解 1.安装phpStudy程序 将下载的phpStudy程序解压到某个分区的根目录中,第一次使用会提示你初始化一下: 之后在主控制界面点击启动即可。 phpstudy目录内容: 2.新建一个数据库 在浏览器址栏中输入:http://localhost/phpmyadmin/ 进入数据库管理工具登录页面,用户名...

Jenkins安装以及邮件配置

Jenkins介绍 Jenkins是一个java开发的、开源的、非常好用持续集成的工具,它能帮我们实现自动化部署环境、测试、打包等等的工作,还可以在构建任务成功或者失败之后给我们发邮件通知。 什么叫持续集成呢,就是能重复、持久的去运行一个任务。 Jenkins下载、安装 Jenkins的下载地址是https://jenkins.io/download/,下...