SQLServerAlwaysOn架构及原理_第1页
SQLServerAlwaysOn架构及原理_第2页
SQLServerAlwaysOn架构及原理_第3页
SQLServerAlwaysOn架构及原理_第4页
免费预览已结束,剩余1页可下载查看

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1、SQLServerAlwaysOn架构及原理SQLServer2012所支寸J的AlwaysOn技术集中了故障转移群集、数据库镜像和日志传送三者的优点,但又不相同。故障转移群集的单位是SQL实例,数据库镜像和日志传送的单位是单个用户数据库,而AlwaysOn支持的单位是可用性组,每个组中可以包括一个或者是多个用户数据库。也就是说,一旦发生切换,则可用性组中的所有数据组会作为一个整体进行切换。AlwaysOn底层依然采用Windows故障转移群集的机制进行监测和转移,因此也需要先建立WindowsCluster,只不过可用性组中的数据库不一定非要再存放在共享存储上了。可以是存储在本地磁盘上。Al

2、waysOn的关键特性:1 .同故障转移群集一样,也需要一个虚拟网络名称用于客户端的统一连接。2 .一个主服务器可以最多对应四个辅助服务器,总数达到五个,而且辅助服务器支持只读功能。3 .辅助服务器可以独立执行备份和DBCC隹护命令。通过配置,可以实现客户端的只读请求可以被自动定向到辅助服务器。4 .主服务器和辅助服务器之间的数据会被加密和压缩,以提高安全性和网络传输效率。5.支持自动、手动和强制三种故障转移方式。6 .有仪表盘用于监控AlwaysOn的运行状态。7 .可以实现多站点的部署,即主站点和辅助站点可以跨物理网络。AlwaysOn的基本架构在WindowsMSCSfc障转移群集白基础

3、上部署AlwaysOn高可用组,用户可以在群集节点上安装SQLServer单机实例,也可以安装SQLServer群集实例,AlwaysOn仅要求所有SQLServer实例都运行在同一个MSCSK但SQLServer实例本身是不需要群集模式的,这与SQLServer2008群集的实例完全不同。在此推荐使用单机模式的SQLServer,好处是:可用性副本是个单机实例,那么数据库副本就存放在该运行该实例节点的本地磁盘上;如果可用性副本是个群集实例,那么数据库副本就存放在共享磁盘上。可用性组从Windows群集角度来看,就是一个群集资源,其中的所有数据库作为一个整体在节点间进行故障转移,当然这不包括系

4、统数据库,系统数据库是不能加入高可用性组中的。因为需要借助Windos群集实现监控和转移,所以AlwaysOn会受到一些限制:一个可用性组中的所有可用性副本必须运行在单一的Windows群集上,跨不同Windows群集的SQLServer实例不能配置成一个AlwaysOn可用性组。一个可用性组的所有可用性副本必须运行在Windows群集的不同节点上。运行在同一个节点上的两个不同实例不能用作同一个可用性组的副本。如果某个可用性副本实例是一个SQLgf集实例,那同一个SQ州集的其他非活跃节点上安装的任何其他SQL实例都不能作为它的辅助副本。一个数据库只能属于一个可用性组。AlwaysOn最多可以支

5、持五个副本,但只有一个可用性副本上运行的数据库是处于可读写状态。这个可读写的数据库被称为主数据库(PrimaryDatabase),同时这个可用性副本被称为主副本(primaryreplica)。其余的副本都被称为辅助副本(secondaryreplica),辅助副本上的数据库可能是不可访问的,或者是只能接受只读操作(取决于可用性组的配置),这些数据库被称为辅助数据库。一但发生故障转移,任何一个辅助副本都可以成为新的主副本实例。主副本会不断地将主数据库上的数据变化发送到辅助副本,来实现副本间的数据库同步。下图就显示了一个可用性组中各副本之间的关系。下图展示了AlwaysOn可用性组与Windo

6、ws故障转移群集之间的关系,在这个图中,Windows的故障转移群集使用到了两个子网,在左边的子网里,有两个节点;右边的子网里有三个节点,其中最右边两个节点上创建了一个SQLServer的群集实例,存放于共享存储;其他三个节点安装的是单机实例,存放于本地存储;一共四个实例组成了一个AlwaysOn可用性组,其中一个主副本,其他的都是辅助副本。(WSF£”虹帙浦H侦听器AlwaysOn创建后,客户端就需要进行连接,为了让应用程序能够透明地连接到主副本而不受故障故障转移的影响,我们需要创建一个侦听器,侦听器就是一个虚拟的网络名称,可以通过这个虚拟网络名称访问可用性组,而不用关心连接的是哪

7、一个节点,它会自动将请求转发到主节点,当主节点发生故障后,辅助节点会变为主节点,侦听器也会自动去侦听主节点。一个侦听器包括虚拟IP地址、虚拟网络名称、端口号三个元素,一旦创建成功,虚拟网络名称会注册到DNS,同时为可用性组资源添加IP地址资源和网络名称资源。用户就可以使用此名称来连接到可用性组中。与故障转移群集不同,除了使用虚拟网络名称之外,主副本的真实实例名还可以被用来连接。SQLServer2012早期版本的SQLServer只有在实例启动的时候地会尝试绑定IP和端口,但是SQLServer2012却允许在副本实例处于运行状况的时候随时绑定新的IP地址、网络名称和端口号。因此可以为随时为为

8、可用性组添加侦听器,而且这个操作会立即生效。当添加了侦听器之后,在SQLServer的错误日志中可以看到类似:在虚拟网络名称上停止和启动侦听器的消息。要注意的是,SQLBrowser服务是不支持Listener的。这是因为应用程序在使用Listener的虚拟网络名连接SQLServer时,是以一个默认实例的形式进行访问的(只有主机名,没有实例名),因此客户端根本就不会去尝试使用SQLBrowser服务。各副本问的数据同步AlwaysOn必须要维护各副本问的数据一致性,当主副本上的数据发生变化,会同步到辅助副本上。这里AlwaysOn通过三个步骤来完成:步骤1:主副本记录发生变化的数据;步骤2:

9、将记录传输到各个辅助副本;步骤3:把数据变化操作在辅助副本上执行一遍。具体实现如下:在主副本和辅助副本上,SQLServer都会启动相应的线程来完成相应的任务。对于一般的SQLServer服务器,即没有配置高可用性,会运行LogWriter的线程,当发生数据修改事务时,此线程负责将本次操对应的日志信息记录到日志缓冲区中,然后再写入到物理日志文件。但如果配置了AlwaysOny主副本的数据库,SQLServer会为它建立一个叫LogScanner的线程,不间断的工作,负责将日志从日志缓冲区或日志文件里读出,打包成日志块,发送到辅助副本。因此可以保证发生的数据变化,不断送给各辅助副本。辅助副本上存在固化和重做两个线程完成数据更新操作,固化线程会将主副本LogScanner所发过来的日志块写入辅助副本磁盘上的日志文件里,因此称为固化,然后重做线程负责从磁盘上读取日志块,将日志记录对应的操作重演一遍,此时主副本和辅助副本上的数据就一致了。重做线程每隔固定的时间点,会跟主副本通

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论