windows server 2008 R2升级到windows 2012迁移Alwayson AG的方法
<p>Windows cluster要求同一个cluster中的所有windows版本都是相同的,这样就出现一个问题,当我们要将对windows进行升级时,(例如从windows 2008 R2升级到windows 2012)不得不搭建一套新的windows cluster。你可以选择使用新的硬件搭建,或者将现有windows cluster中的节点一台一台的evict掉,重装/升级系统后加入到新的windows cluster中。具体的cluster升级方案我就不在这里讨论。马上进入主题:</p><p>sql server AlwaysOn Availability Group (后文简称为AG) 的一个要求是:所有的replica都要求隶属于同一个windows cluster。</p>
<p><img src="https://img.jbzj.com/file_images/article/201408/201408270859281.png" alt="" /></p>
<p>所以当我们对windows cluster进行升级时,无法在新的windows cluster和现有的windows cluster之间建立AG。那么在迁移过程中会有一段时间内AG无法对外提供服务。</p>
<p>从数据库的角度上说,我们需要做下面的事情</p>
<p>接下来停止应用并删除cluster1中的Listener,确保没有外界来接使用SQL SERVER.</p>
<p>Backup database</p>
<p>Backup tail log</p>
<p>将备份文件copy到新的服务器</p>
<p>Restore 到各个服务器</p>
<p>然后重新建立AG</p>
<p>创建Listener</p>
<p>重启应用</p>
<p>我们需要将数据库备份并还原到新的primary replica和secondary replica。 相应的downtime时间就是1+2+3+4+5+6+7+8想要的时间。 或许你想到了在新旧cluster之间创建一个mirroring,但遗憾的是,创建了AG的数据库是不再允许创建mirroring的.</p>
<p>那应当如何进行迁移呢?从SQL Server 2012 SP1 开始,允许在两套不同的windows cluster之间创建AG。下面用一个例子说明一下</p>
<p>有一个三个节点的windows cluster, windows版本为Windows 2008 R2<br /><br><div class="msgheader"><div class="right"><span style="CURSOR: pointer" class="copybut"><u>复制代码</u></span></div>代码如下:</div><div class="msgborder" id="phpcode3"><br />Domain:liweiyin3.lab</p>
<p>Cluster name: cluster1</p>
<p>Server002</p>
<p>Server003</p>
<p>Server004</p>
<p>Listener name: Listener1<br /></div><br />三个节点上装有SQL Server 2012 SP1的standalone实例。均为默认实例。</p>
<p>之间建立了AG.拓扑图如下:<br /></p>
<p><img src="https://img.jbzj.com/file_images/article/201408/201408270859282.png" alt="" /></p>
<p><img src="https://img.jbzj.com/file_images/article/201408/201408270859283.png" alt="" /></p>
<p>现在创建一套两个节点的windows 2012的windows cluster</p>
<p>Domain:liweiyin3.lab</p>
<p>Cluster name: cluster2</p>
<p>Server005</p>
<p>Server006</p>
<p><img src="https://img.jbzj.com/file_images/article/201408/201408270859284.png" alt="" /></p>
<p><br />对cluster1上的AG数据库进行备份,包含full database backup和log backup两个cluster中间创建AG:</p>
<p>将第一步得到的文件在cluster2的节点上进行还原,指定为with norecovery.</p>
<p>接下来在cluster2的三个数据库上执行下面的语句<br /><br><div class="msgheader"><div class="right"><span style="CURSOR: pointer" class="copybut"><u>复制代码</u></span></div>代码如下:</div><div class="msgborder" id="phpcode4"><br />ALTER SERVER CONFIGURATION SET HADR CLUSTER CONTEXT='cluster1.liweiyin3.lab'<br /></div><br />这条语句执行完毕后,这台数据库的cluster context就会切换为cluster1了。这个结果可以从下面的DMV中检查到<br /><br><div class="msgheader"><div class="right"><span style="CURSOR: pointer" class="copybut"><u>复制代码</u></span></div>代码如下:</div><div class="msgborder" id="phpcode5"><br />select cluster_name from sys.dm_hadr_cluster<br /></div></p>
<p><img src="https://img.jbzj.com/file_images/article/201408/201408270859285.png" alt="" /></p>
<p>接下就可以在cluster1和cluster2之间建立AG。我们可以使用UI或者T-SQL语句。</p>
<p>需要注意的是,请将cluster2中的至少一个SQL Server的同步模式设置为Synchronous commit,以保证迁移是没有数据损失的。</p>
<p>这样,我们就建立了一套既包含win 2008R2,也包含win 2012的AG环境了。并且也可以正常地向外界提供服务,整个流程不需要downtime.</p>
<p>这样,我们就建立了一套既包含win 2008R2,也包含win 2012的AG环境了。并且也可以正常地向外界提供服务,整个流程不需要downtime.</p>
<p><img src="https://img.jbzj.com/file_images/article/201408/201408270859286.png" alt="" /></p>
<p>这样,我们就建立了一套既包含win 2008R2,也包含win 2012的AG环境了。并且也可以正常地向外界提供服务,整个流程不需要downtime.</p>
<p><img src="https://img.jbzj.com/file_images/article/201408/201408270859297.png" alt="" /></p>
<p>但需要注意的是,这种情况下是不允许在两个cluster之间进行failover的。相应的提示信息如下</p>
<p><img src="https://img.jbzj.com/file_images/article/201408/201408270859298.png" alt="" /></p>
<p>An attempt to fail over or create an availability group failed. This operation is not supported when AlwaysOn Availability Groups is running under a <strong>remote</strong> Windows Server Failover Clustering (WSFC) cluster context. Under a remote cluster context, failing over or creating availability groups are not supported.</p>
<p><img src="https://img.jbzj.com/file_images/article/201408/201408270859299.png" alt="" /></p>
<p>接下来停止应用并删除cluster1中的Listener,确保没有外界来接使用SQL SERVER</p>
<p>在Cluster1将AG进行offline操作</p>
<p>ALTER AVAILABILITY GROUP dbName offline</p>
<p>将cluster2中所有sql server的CLUSTER CONTEXT切换回来</p>
<p>ALTER SERVER CONFIGURATION SET HADR CLUSTER CONTEXT=local</p>
<p>在cluster2中重新创建AG</p>
<p>在cluster2中创建新的listener</p>
<p>重启应用</p>
<p>这样所涉及的downtime就是5+6+7+8+9+10</p>
<p>和之前的解决方案相比,省去了backup,文件copy和restore的时间。其余的操作都是句操作,很大程度地减少了downtime。</p>
<p>更多信息 </p>
<p>===</p>
<p>迁移之前,Cluster2中的sql server不允许创建任何AG。</p>
<p>迁移之前需要授予cluster2中的sql server启动账号访问cluster1注册表的权限</p>
<p>Change the HADR Cluster Context of Server Instance (SQL Server)</p>
頁:
[1]