SQL SERVER-Alwayson原理
流程
1.异步提交模式
主副本无须确认该副本已经完成日志固化,就可提交事务。
主副本不受辅助副本的影响
辅助副本上的DB处于SYNCHRONIZING
2.同步提交模式
主副本要确认副本已经完成日志固化,才可提交事务。
步骤 | 行为 |
1.提交事务 | 在主副本上运行COMMIT TRAN命令来提交事务 |
2.写入到本地日志记录 |
在主副本上,COMMIT TRAN 命令会被写成一条日志记录(此时记录还在主数据库的日志缓存中)。 然后主副本上的log writer工作线程会把直到COMMIT 命令为止的所有日志记录组成一个日志块从缓存写入到磁盘上的LDF文件中。 当日志被写入到磁盘之后,主数据库就开始等待来自辅助副本的消息来确认日志在辅助副本上被成功写入磁盘。在这之前,该事务提交操作会保持等待。 |
3.扫描日志 |
当日志开始被从缓存写入到磁盘上时,他也会发信号给Log Scanner工作线程,告诉Log Scanner"日志已经准备好了,可以被发送到辅助副本"。 Log Scanner从缓存中取出日志块,把它发送给alwayson的日志块解码器,一旦日志块被解码完毕,整个日志块也会被作为消息发送给辅助副本。 |
4.处理日志块消息 | 日志块消息在辅助副本上得到处理。固化线程负责将日志固化到磁盘上。然后日志被保存到辅助数据库的日志缓存中,重做线程从缓存中获得日志块并开始执行重做操作。 |
5.反馈进度 |
每当辅助副本收到3条来自主副本的消息时,就把固化和重做的进度作为一个消息返回给主副本。 如果超过1秒还没有收到3条消息,进度消息也会被返回。进度信息中包含了当前那些LSN被固化,哪些LSN被重做了。 由于重做线程晚于固化,所以被固化的LSN会多于被重做的LSN。 |
6.完成提交 | 主数据库收到了辅助副本发来的消息,完成事务提交并向客户端发送一条确认的消息。 |
名词解释
连接状态
DISCONNECTED
主副本与辅助副本之间 ping 消息如超时则连接进入DISCONNECTED,
1.如果主副本发现辅助副本断开了和它的连接,在主副本上会将那些辅助副本上的辅助数据库标记为未同步,主副本等待辅助副本重新连接。
2.当辅助副本检测到它和主副本的连接断开后,辅助副本会尝试重新连接主副本。
CONNECTION
辅助副本和主副本间连接正常
可用性副本状态
可用性副本角色:primary ,secondary,resolving
resolving:既不是主副本也不是辅助副本。
NOT SYNCHRONIZING
副本中有一个或多个数据库未同步或未连接到AG
Synchronizing
正在同步副本中的一个或多个数据库
Synchronized
辅助副本中的所有数据库都与主副本的数据库同步
可用性数据库状态
NOT SYNCHRONIZING
无论什么模式如果一个事务在辅助数据库上重做失败,就会导致辅助数据库进入SYNCHRONIZING状态,此时主副本事务直接提交,无须等待。
1.如果主数据库处于该状态,说明该数据库未做好准备将其事务日志与相应的辅助数据库进行同步。
2.如果是辅助数据库处于该状态,原因如下:
1.由于连接问题或者重做失败,不在进行日志同步。
2.和主数据库的日志同步被挂起
3.由于角色切换,正处于装换的中间状态
Synchronizing
1.如果主数据库处于该状态,说明该数据库已做好接受来自辅助数据库的同步请求的准备
2.如果是辅助数据库处于该状态,说明该辅助数据库和主数据之间有正在进行同步的数据
Synchronized
1.如果主数据处于该状态,说明他至少同步了一个辅助数据库
2.如果辅助数据库处于该状态,说明该数据库与相应的主数据库保持同步
SQL SERVER-Alwayson原理的更多相关文章
- SQL Server AlwaysOn原理简介
SQL Server2012所支持的AlwaysOn技术集中了故障转移群集.数据库镜像和日志传送三者的优点,但又不相同.故障转移群集的单位是SQL实例,数据库镜像和日志传送的单位是单个用户数据库,而A ...
- SQL Server AlwaysOn架构及原理
SQL Server AlwaysOn架构及原理 SQL Server2012所支持的AlwaysOn技术集中了故障转移群集.数据库镜像和日志传送三者的优点,但又不相同.故障转移群集的单位是SQL实例 ...
- 最近帮客户实施的基于SQL Server AlwaysOn跨机房切换项目
最近帮客户实施的基于SQL Server AlwaysOn跨机房切换项目 最近一个来自重庆的客户找到走起君,客户的业务是做移动互联网支付,是微信支付收单渠道合作伙伴,数据库里存储的是支付流水和交易流水 ...
- SQL Server AlwaysON 同步模式的疑似陷阱
原文:SQL Server AlwaysON 同步模式的疑似陷阱 SQL Server 2012 推出的最重要的功能之一Alwayson,是一个集之前Cluster和Mirror于一体的新功能,即解决 ...
- 从0开始搭建SQL Server AlwaysOn 第一篇(配置域控)
从0开始搭建SQL Server AlwaysOn 第一篇(配置域控) 第一篇http://www.cnblogs.com/lyhabc/p/4678330.html第二篇http://www.cnb ...
- 从0开始搭建SQL Server AlwaysOn 第二篇(配置故障转移集群)
从0开始搭建SQL Server AlwaysOn 第二篇(配置故障转移集群) 第一篇http://www.cnblogs.com/lyhabc/p/4678330.html第二篇http://www ...
- 从0开始搭建SQL Server AlwaysOn 第三篇(配置AlwaysOn)
从0开始搭建SQL Server AlwaysOn 第三篇(配置AlwaysOn) 第一篇http://www.cnblogs.com/lyhabc/p/4678330.html第二篇http://w ...
- 从0开始搭建SQL Server AlwaysOn 第四篇(配置异地机房节点)
从0开始搭建SQL Server AlwaysOn 第四篇(配置异地机房节点) 第一篇http://www.cnblogs.com/lyhabc/p/4678330.html第二篇http://www ...
- (转) 从0开始搭建SQL Server AlwaysOn 第三篇(配置AlwaysOn)
原文地址: http://www.cnblogs.com/lyhabc/p/4682986.html 这一篇是从0开始搭建SQL Server AlwaysOn 的第三篇,这一篇才真正开始搭建Alwa ...
- (转)从0开始搭建SQL Server AlwaysOn 第二篇(配置故障转移集群)
原文地址: http://www.cnblogs.com/lyhabc/p/4682028.html 这一篇是从0开始搭建SQL Server AlwaysOn 的第二篇,主要讲述如何搭建故障转移集 ...
随机推荐
- 【IoT】物联网NB-IoT之电信物联网开放平台对接流程浅析
版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明.本文链接:https://blog.csdn.net/liwei16611/article/de ...
- EasyDSS高性能RTMP、HLS(m3u8)、HTTP-FLV、RTSP流媒体服务器同步输出http-flv协议流是怎么实现的?
http-flv是什么 http-flv是以http为传输协议,flv媒体格式为内容的方式实时下载flv音视频帧.为什么选择flv格式而非mp4?原因是mp4必须要有moov box或者moof bo ...
- [LeetCode] 249. Group Shifted Strings 分组偏移字符串
Given a string, we can "shift" each of its letter to its successive letter, for example: & ...
- node版本切换工具n的使用介绍
全局安装 npm install -g n mac的安装目录/usr/local/n/versions/node/13.2.0 因此首先在/usr/local/创建目录n,修改权限为普通访问权限,这样 ...
- vs2010+ARX2012向导添加mfc支持类出现Error in default.htm PopulateDialogIDs():
初步判断为ARX2012默认的编译器平台集是v90,如果你只安装了vs2010,没有安装vs2008sp1或者vs2008sp1的编译器,以及对应的Windows MFC SDK,就可能会出现这样的问 ...
- (转)JVM原理讲解和调优
背景:jvm实际调优在面试时候经常被问到,所以有必要认真总结一番. 转自:JVM原理讲解和调优 四.JVM内存调优 首先需要注意的是在对JVM内存调优的时候不能只看操作系统级别Java进程所占用的内存 ...
- 给通过canvas生成的二维码添加logo
以jquery.qrcode为例来说, 生成二维码代码: 依赖jquery.js, jquery.qrcode.js //计算宽,高,中心坐标,logo大小 var width = 256,heigh ...
- 第07组 Beta冲刺(4/4)
队名:秃头小队 组长博客 作业博客 组长徐俊杰 过去两天完成的任务:学习了很多东西 Github签入记录 接下来的计划:继续学习 还剩下哪些任务:后端部分 燃尽图 遇到的困难:自己太菜了 收获和疑问: ...
- Jenkins运行python脚本出现 configparser.NoSectionError: No section: 'XXXXXX'
原来的代码如下: def get_test_config(tag, key, config="config.ini"): cf = configparser.ConfigParse ...
- 用easyui从servlet传递json数据到前端页面的两种方法
用easyui从servlet传递json数据到前端页面的两种方法 两种方法获取的数据在servlet层传递的方法相同,下面为Servlet中代码,以查询表中所有信息为例. //重写doGet方法 p ...