案例分享:数据库镜像故障转移失败
案例分享:数据库镜像故障转移失败
对于关键性数据库,我们配置了带有见证服务器的同步数据库镜像,来允许自动故障转移。一切运行正常,直到有一次数据中心的突然断电。数据库镜像执行了故障转移,但是运维反馈说应用程序挂起了。当我们手动切换回来,应用程序又正常工作。为什么应用程序没有也故障转移呢?
这是使用数据库镜像的合理的常见问题,像这样的生产应用失败,是因为在镜像部署后没有做故障转移测试。在失败的故障转移之后我们感到棘手。
为了避免生产应用停机,我们在测试环境复制了线上的镜像环境。在确认应用和数据库镜像正常工作后,我们将主服务器关机,应用完全挂起。
我们检查了,镜像服务器已经成功初始化了一个故障转移,并在线作为主服务器。我们也检查了镜像数据库为在线状态,可以被新的主服务器本地访问,并且主服务器也可以像被应用程序使用一样被远程客户端访问。
然后,我们来检查应用程序。和开发聊了下,他确认应用程序是使用ADO.NET来连接SQL Server,并使用显式客户端重定向,在SqlConnection的ConnectionString属性指定镜像服务器名。(顺便说一句,使用显式客户端重定向总是比隐式客户端重启定向要好,隐式依赖于客户端连接建立时自动缓存的镜像服务器名)
那为什么应用程序没有故障转移呢?
我深入探究应用程序是如何处理连接失败,发现根本没有应对存在的连接失败的代码!基本上,当应用程序初始化,应用会打开一个到SQL Server的连接,并且绝不尝试重连。
结果发现:尽管DBA部署了数据库镜像,没有和开发讨论过高可用性,因此应用程序代码没有改变。在开发修复后,应用程序连接层可以应对连接失败和执行重连逻辑,在数据库故障转移之后可以完美工作。
这个故事告诉我们,需要重新构建应对发生的连接失败和重连,来让故障转移正确工作。在这个案例中,如果我们在部署在生产环境之前,在测试环境尝试了数据库镜像故障转移,那客户端就会发现这个问题了。
具体原理和应用程序的代码示例,可参考以下文章:
将客户端连接到数据库镜像会话(https://msdn.microsoft.com/zh-cn/library/ms175484.aspx)
Implementing Application Failover with Database Mirroring(https://technet.microsoft.com/en-us/library/cc917713.aspx#EDAA)
Sample Application to test database mirroring failover(https://blogs.msdn.microsoft.com/grahamk/2009/01/16/sample-application-to-test-database-mirroring-failover/)

低调大师中文资讯倾力打造互联网数据资讯、行业资源、电子商务、移动互联网、网络营销平台。
持续更新报道IT业界、互联网、市场资讯、驱动更新,是最及时权威的产业资讯及硬件资讯报道平台。
转载内容版权归作者及来源网站所有,本站原创内容转载请注明来源。
- 上一篇
lenovo Win10 安装 Androd Studio 新版本编程开发的软件
最近网上寻找到一款国外比较新颖的电脑最新编程开发版本Androia Studio,我也是尝试着一种编程开发的心态,也就下载并安装了,应用中感觉良好,也就这一种软件的编程开发来协调混用的。下面我们从网络进行下载和安装。示看下载时的安装程序。我们可以通过不同的电脑版本来安装不如:WinXP/Win2003/Vista/Win7/Win8/Win8.1/Win10 我的电脑是笔记本LenovoWin10。 。 首先是打开下载安装的地址:http://120.198.244.26:9999/221.181.72.84/big.softdl.360tpcdn.com/androidstudio/androidstudio_2.3.0.8.exe 1. 是把它装在E盘区: 2.喜欢wan编程开发的你们就下载试着应用wan wan 吧 . 瞎忙着,安装不需要用很多时间,就可以安装好。编程开发是免费 1848.94MB。 3.下载的时候必须按照安装系统的提示来进行安装不能改动安装的地址,要不然安装完毕之后,系统会显示出差错,这样的话,我们的安装程序就会浪费很多的时间和我们的工...
- 下一篇
升级域控制器-从Windows 2012升级到2016案例之1
Microsoft已经发布了Windows Server 2016的正式版,为了深入了解与学习这个产品,第一时间将我的实验环境中的服务器升级到了Windows Server 2016,整个升级过程比较顺利,只是在升级后一些小问题也一一解决,现在将整个升级过程展现出来,希望对读者有所帮助。 我当前的实验环境有3台服务器,系统都是Windows Server 2012 R2 Datacenter版本,其中1台是域控制器,另2台是成员服务器,其中一台是WSUS服务器,一台是Hyper-V Server主机,在这个Hyper-V主机上运行着一些生产及实验环境的虚拟机。整个实验环境如图1-1所示。说明,虽然这是一个实验环境,但我这个环境最后是从Windows Server 2003开始,经历了从Windows Server 2003到现在最新的Windows Server 2016期间每个版本的升级,还包括了服务器的更换,整个环境一直保留到现在实属不易,所以虽然是实验环境但处胜于一般的生产环境。当前环境中WSUS、DFS、CA、DHCP、WDS、Hyper-V应用近有。 图1-1 演示实验环境 ...
相关文章
文章评论
共有0条评论来说两句吧...