前言:

本节讲解关于SQL Server 存储方面的内容,相对于其他小节而言这节比较短。本节会提供一些关于使用群集或者非群集系统过程中对存储的利用建议。当然,重点还是集中在对于一个标准的AlwaysOn可用组配置过程中,对存储的选择和配置上面。

AlwaysOn的部署首先建立在一个Windows Server Failover Cluster(WSFC)上。并且每个服务器通常有一个独立的SQL Server实例。另外,每个服务器使用其本地存储来存放独立的SQL Server实例的数据库文件(数据文件、日志文件、备份文件等)。虽然所有伙伴节点都属于同一个群集,但是不需要基于硬盘见证或者故障转移实例,也没有共享存储的要求。从而避免了FCI中的共享存储单点故障风险。但是AlwaysOn可用组可以使用FCI作为可用副本。这个不仅又重新引入单点故障的风险,也增加了群集对节点的复杂度。

言归正传,现在来看一下存储系统的核心内容:

  • 本地存储(Localized)
  • 网络存储(Networked)
下面来详细介绍一下:

本地附加存储(Locally Attached Storage):


这种模式下,本地存储是直接连到服务器上,硬盘直接插入硬件背板(backplane),然后连到服务器的主板上。较老的配置可能会包含将通过68/80针电缆连接到PCI总线的扩展RAID控制器上。
下图是一个典型的本地存储示意图。这是相对来说路径断和复杂度低的,可提供快速硬盘访问的方式。背板有一个输入输出BIOS,可以用于控制横跨本地硬盘的RAID阵列的硬盘冗余功能,但是由于硬件服务器的限制,通常最大只有16个硬盘可用。


这是典型的没有网络存储的节点中的单独存储示意图,在WSFC中,没有独立的存储共享给其他节点。这也使得查分节点的物理位置过程中,不需要对存储进行复制。



网络存储(Network Storage):


网络存储可以作为资源提供给多个计算机系统。有一个中央存储库通过降低很狂每个服务器的多个阵列的接触点从而更为简单地管理这些硬盘。如下图所示,通常系统中有很多服务器通过光纤(Fibre Channel,FC)网络互联,通常也称为“Fabric”。计算机通过一个Host Bus Adapter(HBA卡,主机总线适配器是网络与交换,是能插入计算机或大型主机的板卡),实际上HBA卡类似于一个网卡。
各个服务器也可以通过iSCSI网络进行互联,这个网络相对较新但带宽受限(1Gbps)。它运行在标准的、隔离的TCP\IP网络。服务器通常使用专用网卡,只用于iSCSI和TCP通信从而降低负载,意味着iSCSI的流量控制被分摊出来。现代iSCSI已经可以处理上限为10Gbps的带宽数据。对iSCSI配置的好处之一是它币传统的FC网络更加经济。但是,也不总是这样。



当有很多服务器发送请求给存储进程并从中接收结果时,可以快速发现在FC网络中产生了多少流量。正如TCP\IP网络那样,你会发现FC网络会被堵满。然后存储区域的网络会因此产生性能问题。在复杂的SAN配置中,会有多个交换机连接大量的网线和额外电源需求。如上图,可以看到这种情况下数据流动路径和复杂度都明显变大。
在这么长的路径和复杂路由中提出I/O请求,会消耗很多事件和其他开销。关于整合的存储,这类系统能提供什么呢?这类存储可以更容易地调配和交付资源给大规模的数据。然后就像虚拟化,不是每个实体都可以用。
这种模式的存储也常用于SQL Server 的FCI中,LUNs从磁盘阵列中划出来,而且数量巨大。这里的缺点是阵列可能被以128KB的块大小格式化。这个大小对于SQL Server来说并非最优化。其优点是,当被合理配置后,存储请求几乎可以不到末端阵列。因为请求可以直接发生在高速内存缓冲区,然后缓存的数据在合适的时间点被刷到硬盘从而降低对性能的影响。在停电时,后备电源也会把缓存中的数据刷新到硬盘以免数据丢失。
另外还有一种网络存储可用于在高可用节点中共享存储又避免多个主机连接的开销。这种存储类型称为Direct Attached Storage(DAS,直接附加存储),这类系统专门为可以使用基于私有光纤连接、基本上可以归到本地化的应用而设计。下面是一个典型的私有高可用存储配置示意图:



这个场景下,如果想创建私有高可用群集,会稍微比本地存储更好。一些存储供应商提供通过光纤连接的设备,并可以有最多两个主机连接到高可用方案的多个路径中。多个阵列存储模块可以顺便增加可用存储量。
这类存储也可以用于SQL Server FCI中。这种方式适合在特定环境下的小型或简单群集中少数几个节点共享存储之用。你可能已经注意到上图中LUNs的方式是一个方框,这是因为不是所有的Windows系统的逻辑硬盘底层都有独立的物理阵列。上图的情景也是最常见的配置中,磁盘被设置为一个较大的阵列。
想象一个大蛋糕。或者在这种情况下,从物理硬盘池中创建的阵列。切下一块蛋糕或者从阵列中划出一个LUN用于给Windows作为逻辑硬盘之用。


总结:


这一篇介绍了为群集和独立的SQL Server实例配置稳定坚固的典型存储要求。下一节会着重介绍支持WSFC和FCI及AlwaysOn可用组所需的基础设施。


SQL Server AlwaysON从入门到进阶(2)——存储的更多相关文章

  1. SQL Server AlwaysON从入门到进阶(3)——基础架构

    本文属于SQL Server AlwaysON从入门到进阶系列文章 前言: 本文将更加深入地讲解WSFC所需的核心组件.由于AlwaysOn和FCI都需要基于WSFC之上,因此我们首先要了解在Wind ...

  2. SQL Server AlwaysON从入门到进阶(1)——何为AlwaysON?

    本文属于SQL Server AlwaysON从入门到进阶系列文章 本文原文出自Stairway to AlwaysOn系列文章.根据工作需要在学习过程中顺带翻译以供参考.系列文章包含: SQL Se ...

  3. SQL Server AlwaysON从入门到进阶(6)——分析和部署AlwaysOn Availability Group

    前言:   本节是整个系列的重点文章,到现在,读者应该已经对整个高可用架构有一定的了解,知道独立的SQL Server实例和基于群集的SQL Server FCI的区别.上一节已经介绍了如何安装SQL ...

  4. 宣布正式发布 Windows Azure Notification Hub,新增 SQL Server AlwaysOn 可用性组侦听器支持

    今天,我们非常高兴地宣布,针对使用 Windows Azure 的移动和企业开发人员推出一些新功能.这些新功能可以减少构建移动应用程序的开发时间和成本,并能帮助企业开发人员实现高可用性和全球业务连续性 ...

  5. 最近帮客户实施的基于SQL Server AlwaysOn跨机房切换项目

    最近帮客户实施的基于SQL Server AlwaysOn跨机房切换项目 最近一个来自重庆的客户找到走起君,客户的业务是做移动互联网支付,是微信支付收单渠道合作伙伴,数据库里存储的是支付流水和交易流水 ...

  6. 从0开始搭建SQL Server AlwaysOn 第一篇(配置域控)

    从0开始搭建SQL Server AlwaysOn 第一篇(配置域控) 第一篇http://www.cnblogs.com/lyhabc/p/4678330.html第二篇http://www.cnb ...

  7. 从0开始搭建SQL Server AlwaysOn 第二篇(配置故障转移集群)

    从0开始搭建SQL Server AlwaysOn 第二篇(配置故障转移集群) 第一篇http://www.cnblogs.com/lyhabc/p/4678330.html第二篇http://www ...

  8. 从0开始搭建SQL Server AlwaysOn 第三篇(配置AlwaysOn)

    从0开始搭建SQL Server AlwaysOn 第三篇(配置AlwaysOn) 第一篇http://www.cnblogs.com/lyhabc/p/4678330.html第二篇http://w ...

  9. 从0开始搭建SQL Server AlwaysOn 第四篇(配置异地机房节点)

    从0开始搭建SQL Server AlwaysOn 第四篇(配置异地机房节点) 第一篇http://www.cnblogs.com/lyhabc/p/4678330.html第二篇http://www ...

随机推荐

  1. QT 实现在QLabel上画图

    QT之所以不能再任意控件上绘图是因为QT的事件过滤器把控件的绘图事件给过滤了. 在paintevent()函数中,通常需要设置QPainter对象,创建QPainter对象的同时需要指定绘图设备,即继 ...

  2. Why deep learning?

    1. 深度学习中网络越深越好么? 理论上说是这样的,因为网络越深,参数也越多,拟合能力也越强(但实际情况是,网络很深的时候,不容易训练,使得表现能力可能并不好). 2. 那么,不同什么深度的网络,在参 ...

  3. 【阿里聚安全·安全周刊】 全美警局已普遍拥有破解 iPhone 的能力 | 女黑客破解任天堂Switch,称硬件漏洞无法修复

    本周的七个关键词: 破解 iPhone丨 女黑客破解任天堂丨假的身份证 丨 扫黄打非丨华盛顿特区发现手机间谍设备 丨 Telegram被俄罗斯监管机构告上法庭丨价值5万美金的Firefox浏览器漏洞 ...

  4. https://segmentfault.com/a/1190000004518374#articleHeader3

    https://segmentfault.com/a/1190000004518374#articleHeader3 https://segmentfault.com/q/10100000049065 ...

  5. 三.SQL语句实例

    1.查询A表中存在而B表中不存在的数据 1.1 描述:表A中有一tel字段,表B中有一tel字段,两个字段存储的内容部分相同,现要查询A表tel字段中有而B表tel字段中没有的数据 1.2 有三个se ...

  6. vue-cli 去掉严格模式:

    vue-cli 去掉严格模式: 在根目录中找到 .eslintignore 文件,添加 严格模式需要监听的目录 src/*

  7. .NET CORE 2.0 踩坑记录之ConfigurationManager

    在之前.net framework 中使用的ConfigurationManager还是很方便的,不过在.NET CORE 2.0中SDK默认已经不存在ConfigurationManager. 那么 ...

  8. poj 3070 Fibonacci 矩阵快速幂

    Description In the Fibonacci integer sequence, F0 = 0, F1 = 1, and Fn = Fn − 1 + Fn − 2 for n ≥ 2. F ...

  9. Luogu1613 跑路

    题目描述 小A的工作不仅繁琐,更有苛刻的规定,要求小A每天早上在6:00之前到达公司,否则这个月工资清零.可是小A偏偏又有赖床的坏毛病.于是为了保住自己的工资,小A买了一个十分牛B的空间跑路器,每秒钟 ...

  10. Codeforces Round #398 (div.2)简要题解

    这场cf时间特别好,周六下午,于是就打了打(谁叫我永远1800上不去div1) 比以前div2的题目更均衡了,没有太简单和太难的...好像B题难度高了很多,然后卡了很多人. 然后我最后做了四题,E题感 ...