连接到 Azure 上的 SQL Server 虚拟机(经典部署)

概述

本主题介绍如何连接到运行于 Azure 虚拟机的 SQL Server 实例。 它介绍了一些常规连接方案,并提供了在 Azure VM 中配置 SQL Server 连接的详细步骤

Important

Azure 提供两个不同的部署模型用于创建和处理资源:Resource Manager 和经典模型。 本文介绍如何使用经典部署模型。 Azure 建议大多数新部署使用 Resource Manager 模型。 如果使用的是 Resource Manager VM,请参阅使用 Resource Manager 连接到 Azure 上的 SQL Server 虚拟机

连接方案

将客户端连接到虚拟机上运行的 SQL Server 的方式各不相同,具体取决于客户端的位置与计算机/网络配置。 这些方案包括:

连接到同一云服务中的 SQL Server

通过 Internet 连接到 SQL Server

连接到同一虚拟网络中的 SQL Server

Note

使用下列任一方法进行连接之前,必须遵循本文中的步骤配置连接

连接到同一云服务中的 SQL Server

可以在同一云服务中创建多个虚拟机。 若要了解此虚拟机方案,请参阅如何将虚拟机连接到虚拟网络或云服务。 本方案介绍一台虚拟机上的客户端尝试连接到运行于同一云服务中另一虚拟机的 SQL Server 时的情况。

在此方案中,可使用 VM名称(在门户中也显示为计算机名主机名)进行连接。 这是你在创建 VM 时为其提供的名称。 例如,如果你将 SQL VM 命名为mysqlvm,则同一云服务中的客户端 VM 可以使用以下连接字符串进行连接:

复制

"Server=mysqlvm;Integrated Security=false;User ID=;Password="

通过 Internet 连接到 SQL Server

如果想要通过 Internet 连接到 SQL Server 数据库引擎,则必须创建虚拟机终结点以进行传入 TCP 通信。 此 Azure 配置步骤将传入 TCP 端口通信定向到虚拟机可以访问的 TCP 端口。

若要通过 Internet 进行连接,必须使用 VM 的 DNS 名称和(本文中稍后配置的)VM 终结点端口号。 若要查找 DNS 名称,请导航到 Azure 门户,然后选择“虚拟机(经典)”。 然后选择你的虚拟机。 “DNS 名称”显示在“概述”部分中。

例如,假设一台经典虚拟机名为mysqlvm,其 DNS 名称为mysqlvm7777.chinacloudapp.cn且 VM 终结点为57500。 假设正确配置了连接性,则可从 Internet 上的任意位置使用以下连接字符串访问该虚拟机:

复制

"Server=mycloudservice.chinacloudapp.cn,57500;Integrated Security=false;User ID=;Password="

尽管客户端可通过 Internet 进行连接,但这并不意味着任何人都可以连接到 SQL Server。 外部客户端必须有正确的用户名和密码。 为了提高安全性,请不要对公共虚拟机终结点使用常用的 1433 端口。 如果可能,请考虑在终结点上添加 ACL 以将流量限制到你允许的客户端。 有关在终结点上使用 ACL 的说明,请参阅管理终结点上的 ACL

Note

务必注意,使用此方法与 SQL Server 通信时,Azure 数据中心的所有传出数据都将服从一般出站数据传输定价

连接到同一虚拟网络中的 SQL Server

虚拟网络支持其他方案。 你可以连接同一虚拟网络中的 VM,即使这些 VM 位于不同的云服务中。 使用站点到站点 VPN,可以创建连接 VM 与本地网络和计算机的混合体系结构。

虚拟网络还可让你将 Azure VM 加入域。 这是对 SQL Server 使用 Windows 身份验证的唯一方式。 其他连接方案需要使用用户名和密码进行 SQL 身份验证。

如果要配置域环境和 Windows 身份验证,则不需要使用本文中的步骤来配置公共终结点或 SQL 身份验证和登录名。 在此方案中,你可以在连接字符串中指定 SQL Server VM 名称以连接 SQL Server 实例。 以下示例假设同时已配置 Windows 身份验证,并且用户已获得访问 SQL Server 实例的权限。

复制

"Server=mysqlvm;Integrated Security=true"

在 Azure VM 中配置 SQL Server 连接的步骤

以下步骤演示了如何使用 SQL Server Management Studio (SSMS) 通过 Internet 连接到 SQL Server 实例。 但是,这些步骤同样适用于使你的 SQL Server 虚拟机可以通过本地和 Azure 中运行的应用程序访问。

你必须先完成下列各部分中描述的下列任务,然后才能从其他 VM 或 Internet 连接到 SQL Server 的实例:

为虚拟机创建 TCP 终结点

在 Windows 防火墙中打开 TCP 端口

将 SQL Server 配置为侦听 TCP 协议

配置混合模式的 SQL Server 身份验证

创建 SQL Server 身份验证登录名

确定虚拟机的 DNS 名称

从其他计算机连接到数据库引擎

下图中概述了连接路径:

为虚拟机创建 TCP 终结点

要从 Internet 访问 SQL Server,虚拟机必须具有终结点以侦听传入的 TCP 通信。 此 Azure 配置步骤将传入 TCP 端口通信定向到虚拟机可以访问的 TCP 端口。

Note

如果你在同一云服务或虚拟网络中连接,则不需要创建一个公开访问的终结点。 在这种情况下,你可以继续执行下一步。 有关详细信息,请参阅连接方案

在 Azure 门户中,选择“虚拟机(经典)”。

然后选择 SQL Server 虚拟机。

选择“终结点”,然后单击“终结点”边栏选项卡顶部的“添加”按钮。

在“添加终结点”边栏选项卡上,提供“名称”,例如 SQLEndpoint。

选择“TCP”作为“协议”。

为“公用端口”指定端口号,如“57500”。

为“专用端口”,指定 SQL Server 侦听端口,默认为“1433”。

单击“确定” 以创建终结点。

在 Windows 防火墙中为数据库引擎的默认实例打开 TCP 端口

通过远程桌面连接到虚拟机。 有关连接到 VM 的详细说明,请参阅使用远程桌面打开 SQL VM

登录后,在开始屏幕中,键入“WF.msc”,然后按 ENTER。

在“高级安全 Windows 防火墙”的左窗格中,右键单击“入站规则”,然后在操作窗格中单击“新建规则”。

在“新建入站规则向导”对话框中,在“规则类型”下,选择“端口”,然后单击“下一步”。

在“协议和端口”对话框中,使用默认TCP。 然后,在“特定本地端口”框中,键入数据库引擎实例的端口号(即默认实例对应的端口号1433,或在终结点步骤中为专用端口选择的端口号)。

单击“下一步”。

在“操作”对话框中,选择“允许连接”,然后单击“下一步”。

安全说明:选择“只允许安全连接”可增加安全性。 如果想在环境中配置其他安全性选项,请选择此选项。

在“配置文件”对话框中,选择“公用”、“专用”和“域”。 然后单击“下一步”。

安全说明:选择“公用”允许通过 Internet 进行访问。 只要有可能,就请选择更具限制性的配置文件。

在“名称”对话框中,键入此规则的名称和说明,然后单击“完成”。

根据需要为其他组件打开附加端口。 有关详细信息,请参阅配置 Windows 防火墙以允许 SQL Server 访问

将 SQL Server 配置为侦听 TCP 协议

在连接到虚拟机时,在开始页面中,键入“SQL Server 配置管理器”,然后按 ENTER。

在 SQL Server 配置管理器中,在控制台窗格中,展开“SQL Server 网络配置”。

在控制台窗格中,单击“MSSQLSERVER 的协议”(默认实例名称)。在详细信息窗格中,右键单击“TCP”,然后单击“启用”(如果尚未启用)。

在控制台窗格中,单击“SQL Server 服务”。 在详细信息窗格中,右键单击SQL Server (实例名)(默认实例为“SQL Server (MSSQLSERVER)”),然后单击“重新启动”以停止并重新启动该 SQL Server 实例。**

关闭 SQL Server 配置管理器。

有关启用 SQL Server 数据库引擎的协议的详细信息,请参阅启用或禁用服务器网络协议

配置混合模式的 SQL Server 身份验证

在没有域环境的情况下,SQL Server 数据库引擎无法使用 Windows 身份验证。 若要从其他计算机连接到数据库引擎,请将 SQL Server 的身份验证模式配置为混合。 混合模式身份验证同时允许 SQL Server 身份验证和 Windows 身份验证。

Note

如果你已使用配置的域环境配置了 Azure 虚拟网络,可能没有必要配置混合模式身份验证。

在连接到虚拟机时,在开始页面中,键入“SQL Server Management Studio”,然后单击勾选图标。

Management Studio 在首次打开时,一定会创建用户 Management Studio 环境。 这可能需要一小段时间。

Management Studio 会显示“连接到服务器”对话框。 在“服务器名称”框中,键入要使用对象资源管理器连接到数据库引擎的虚拟机的名称(除了虚拟机名称,还可以使用“(local)”或一个句点作为“服务器名称”)。 选择“Windows 身份验证”,在“用户名”框中保留“your_VM_name\your_local_administrator”。 单击“连接”。

在 SQL Server Management Studio 的“对象资源管理器”中,右键单击 SQL Server 实例的名称(虚拟机名称),然后单击“属性”。

在“安全性”页上,在“服务器身份验证”下,选择“SQL Server 和 Windows 身份验证模式”,然后单击“确定”。

在 SQL Server Management Studio 对话框中,单击“确定”接受重新启动 SQL Server 的要求。

在“对象资源管理器”中,右键单击你的服务器,然后单击“重新启动”。 (如果 SQL Server 代理正在运行,它也必须重新启动。)

在 SQL Server Management Studio 对话框中,单击“是”同意重新启动 SQL Server。

创建 SQL Server 身份验证登录名

若要从其他计算机连接到数据库引擎,你必须创建至少一个 SQL Server 身份验证登录名。

在 SQL Server Management Studio 对象资源管理器中,展开你要在其中创建新登录名的服务器实例所在的文件夹。

右键单击“安全性”文件夹,指向“新建”,然后选择“登录名…”。

在“登录名 - 新建”对话框中的“常规”页上,在“登录名”框中输入新用户的名称。

选择“SQL Server 身份验证”。

在“密码”框中,输入新用户的密码。 在“确认密码”框中再次输入该密码。

选择所需的密码强制选项(“强制实施密码策略”、“强制密码过期”和“用户在下次登录时必须更改密码”)。 如果使用此登录名,则在下次登录时无需更改密码。

从“默认数据库”列表中,为该登录名选择默认数据库。 “master”是此选项的默认值。 如果尚未创建用户数据库,则将此设置保留为“master”。

如果这是你创建的第一个登录名,则你可能希望将此登录名指派为 SQL Server 管理员。 如果是这样,请在“服务器角色”页面上选中“sysadmin”。

Note

sysadmin 固定服务器角色的成员对数据库引擎具有完全控制权限。 应谨慎限制此角色中的成员资格。

单击“确定”。

有关 SQL Server 登录名的详细信息,请参阅创建登录名

确定虚拟机的 DNS 名称

若要从另一台计算机连接到 SQL Server 数据库引擎,必须知道虚拟机的域名系统 (DNS) 名称。 (这是 Internet 用于识别虚拟机的名称。 可以使用 IP 地址,但 IP 地址在 Azure 为冗余或维护而移动资源时可能会变更。 DNS 名称将保持不变,因为可将该名称重定向到新的 IP 地址。)

在 Azure 门户中(或在完成前一步后),选择“虚拟机(经典)”。

选择 SQL VM。

在“虚拟机”边栏选项卡中,复制虚拟机的“DNS 名称”。

从其他计算机连接到数据库引擎

在连接到 Internet 的计算机上,打开 SQL Server Management Studio。

在“连接到服务器”或“连接到数据库引擎”对话框的“服务器名称”框中,按“DNSName,portnumber”的格式输入虚拟机的 DNS 名称(在前一任务中确定)和公共终结点端口号,例如“mysqlvm.chinacloudapp.cn,57500”。

如果不记得之前创建的公共终结点端口号,可以在“虚拟机”边栏选项卡的“终结点”区域中找到。

在“身份验证”框中,选择“SQL Server 身份验证”。

在“登录名”框中,键入在前面的任务中创建的登录名。

在“密码”框中,键入在前面的任务中创建的登录名的密码。

单击“连接”。

后续步骤

如果还打算针对高可用性和灾难恢复使用 AlwaysOn 可用性组,则应考虑实施侦听器。 数据库客户端将连接到侦听器,而不是直接连接到一个 SQL Server 实例。 侦听器将客户端路由到可用性组中的主副本。 有关详细信息,请参阅在 Azure 中配置 AlwaysOn 可用性组的 ILB 侦听器

请务必查看 Azure 虚拟机上运行的 SQL Server 的所有安全最佳实践。 有关详细信息,请参阅Azure 虚拟机中 SQL Server 的安全注意事项

有关其他与在 Azure VM 中运行 SQL Server 相关的主题,请参阅SQL Server on Azure Virtual Machines(Azure 虚拟机上的 SQL Server)。

立即访问http://market.azure.cn

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 158,233评论 4 360
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 67,013评论 1 291
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 108,030评论 0 241
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 43,827评论 0 204
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 52,221评论 3 286
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 40,542评论 1 216
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 31,814评论 2 312
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 30,513评论 0 198
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 34,225评论 1 241
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 30,497评论 2 244
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 31,998评论 1 258
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 28,342评论 2 253
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 32,986评论 3 235
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 26,055评论 0 8
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 26,812评论 0 194
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 35,560评论 2 271
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 35,461评论 2 266

推荐阅读更多精彩内容