SQLServer数据库 2012笔记分享-50:理解SQL Server browser
小标 2018-07-06 来源 : 阅读 1303 评论 0

摘要:本文主要向大家介绍了SQLServer数据库 2012笔记分享-50:理解SQL Server browser,通过具体的内容向大家展现,希望对大家学习SQLServer数据库有所帮助。

本文主要向大家介绍了SQLServer数据库 2012笔记分享-50:理解SQL Server browser,通过具体的内容向大家展现,希望对大家学习SQLServer数据库有所帮助。

SQL Server 浏览器程序以 Windows 服务的形式运行。 SQL Server 浏览器侦听对 Microsoft SQL Server 资源的传入请求,并提供计算机上安装的 SQL Server 实例的相关信息。 SQL Server 浏览器可用于执行下列操作:

1. 浏览可用服务器列表

2. 连接到正确的服务器实例

3. 连接到专用管理员连接 (DAC) 端点    

    

先介绍一点背景知识:

在 SQL Server 2000 之前,一台计算机上只能安装一个 SQL Server 实例。 SQL Server 侦听 1433 端口上的传入请求,该端口由官方的 Internet 号码分配机构 (IANA) 分配给 SQL Server。 只有 SQL Server 的一个实例可以使用端口,因此,在 SQL Server 2000 引入了对多个 SQL Server 实例的支持时,SQL Server 解析协议 (SSRP) 是为侦听 UDP 端口 1434 而开发的。 此侦听器服务使用已安装实例的名称以及该实例使用的端口或命名管道响应客户端请求。 为了解决 SSRP 系统的限制,SQL Server 2005 引入了 SQL Server Browser 服务来替换 SSRP。

    

=========================================================

SQL Server Browser 工作原理

启动一个 SQL Server 实例后,如果为 SQL Server 启用了 TCP/IP 协议,服务器将被分配一个 TCP/IP 端口。 如果启用了 Named Pipes 协议,SQL Server 将侦听特定的命名管道。 该特定实例将使用此端口(或“管道”)与客户端应用程序交换数据。 在安装过程中,TCP 1433 端口和管道 \sql\query 将分配给默认实例,但服务器管理员可以随后使用 SQL Server 配置管理器进行更改。 由于只有一个 SQL Server 实例可以使用端口或管道,因此,会将不同的端口号和管道名称分配给命名实例,包括 SQL Server Express。 默认情况下,命名实例和 SQL Server Express 在启用时便配置为使用动态端口,也就是说,当 SQL Server 启动时就分配了可用端口。 如果需要,可以为 SQL Server 实例分配特定端口。 连接时,客户端可以指定特定端口,但是如果端口是动态分配的,端口号可能会在重新启动 SQL Server 时被更改,因此正确的端口号对于客户端来说是不确定的。

在启动后,SQL Server 浏览器将启动并使用 UDP 1434 端口。 SQL Server 浏览器将读取注册表,识别计算机上的所有 SQL Server 实例,并注明它们使用的端口和命名管道。 当一台服务器具有两个或多个网卡时,SQL Server 浏览器会为 SQL Server 返回其遇到的第一个已启用的端口。 SQL Server 浏览器支持 ipv6 和 ipv4。

当 SQL Server 客户端请求 SQL Server 资源时,客户端网络库将使用 1434 端口向服务器发送一条 UDP 消息。 SQL Server 浏览器将用请求的实例的 TCP/IP 端口或命名管道做出响应。 然后,客户端应用程序中的网络库将使用所需实例的端口或命名管道向服务器发送请求来完成连接。 SQL Server 浏览器不返回默认实例的端口信息。

简单来说

安装多实例的时候,每个实例可以侦听独立的SQL TCP/IP端口;默认是1433端口,但是可以修改的;

1433是国际上专门预留给SQL SERVER,Oracle是1521,这个只针对默认实例是这样的;

如果继续安装命名实例,默认使用动态TCP端口1024-65535之间,需要的话也可以设置静态的TCP端口,方便防火墙开放;

设置静态端口要防止本机上的端口冲突;

使用SQL server browser服务来侦听尝试连接SQL server命名实例的网络要求(侦听来自客户端UDP 1434端口的请求),提供指定的命名实例侦听的TCP端口号,如果客户端有缓存以后,就不需要了;

如果只安装了默认实例,则SQL server browser服务安装后是禁用的,因为SQL不需要这个服务;

如果是命令实例安装,则browser服务会设置为自动启动安装

所有实例只有一个browser服务;不管一台服务器上安装了多少个SQL实例,始终都只会有一个browser服务。

右击SQL server browser服务,也可以修改服务的服务账户。

本文由职坐标整理并发布,希望对同学们学习SQL Server有所帮助,更多内容请关注职坐标数据库SQL Server数据库频道!

本文由 @小标 发布于职坐标。未经许可,禁止转载。
喜欢 | 0 不喜欢 | 0
看完这篇文章有何感觉?已经有0人表态,0%的人喜欢 快给朋友分享吧~
评论(0)
后参与评论

您输入的评论内容中包含违禁敏感词

我知道了

助您圆梦职场 匹配合适岗位
验证码手机号,获得海同独家IT培训资料
选择就业方向:
人工智能物联网
大数据开发/分析
人工智能Python
Java全栈开发
WEB前端+H5

请输入正确的手机号码

请输入正确的验证码

获取验证码

您今天的短信下发次数太多了,明天再试试吧!

提交

我们会在第一时间安排职业规划师联系您!

您也可以联系我们的职业规划师咨询:

小职老师的微信号:z_zhizuobiao
小职老师的微信号:z_zhizuobiao

版权所有 职坐标-一站式IT培训就业服务领导者 沪ICP备13042190号-4
上海海同信息科技有限公司 Copyright ©2015 www.zhizuobiao.com,All Rights Reserved.
 沪公网安备 31011502005948号    

©2015 www.zhizuobiao.com All Rights Reserved

208小时内训课程