如何在沒有域的環境中搭建AlwaysOn(二)

来源:http://www.cnblogs.com/i6first/archive/2016/11/09/6047538.html
-Advertisement-
Play Games

對DBA而言,不需要域就可以搭建SQL Server AlwaysOn是Windows Server 2016中最令人興奮的功能了,它不僅可以降低搭建的成本,而且還減少了部署和運維的工作量。 上篇博客已給大家分享過:要在沒有域的環境中搭建AlwaysOn需要兩個步驟, 1).搭建基於windows ...


     對DBA而言,不需要域就可以搭建SQL Server AlwaysOn是Windows Server 2016中最令人興奮的功能了,它不僅可以降低搭建的成本,而且還減少了部署和運維的工作量。

     上篇博客已給大家分享過:要在沒有域的環境中搭建AlwaysOn需要兩個步驟,

      1).搭建基於windows server 2016 工作組環境的故障轉移集群;

      2).搭建AlwaysOn;

      步驟1已在上篇博客中介紹了,因此本文將分享AlwaysOn的搭建方法:

image

 

 

1.安裝SQL Server 2016

    在所有節點上安裝SQL Server 2016。

2.啟用AlwaysOn功能

    在所有節點上啟用AlwaysOn功能,方法:

    打開SQL Server配置管理器,在對應的SQL Server實例屬性中,勾選【啟用AlwaysOn可用性組】,如下圖:

clipboard

 

3.在每個節點上創建alwaysOn的通訊端點(鏡像端點)

     在windows server 2016之前,配置端點的加密的方式有兩種:域用戶授權和證書加密,升級到windows server 2016後,如果不使用域搭建AlwaysOn,那麼就只能選擇證書加密的方式了。

     3.1創建一個共用目錄,允許AlwaysOn的所有節點均可以讀寫該目錄;

           共用目錄用來存放端點通訊的證書,在後續的步驟中將會用到。示例為:\\WIN-JBRHIAJPMG2\file

     3.2創建端點

          為了方便,我把創建證書和安裝證書的過程用兩個存儲來實現。(這個兩個存儲過程來自網上,不是我寫的)

          3.2.1將如下兩個存儲過程在每個節點的SQL Server實例中執行一遍:

CREATE PROCEDURE CreateEndpointCert
 @ShareName SYSNAME ,
 @StrongPassword SYSNAME
AS BEGIN
 
--This must be executed in the context of Master
 IF (DB_NAME() <> 'master')
 BEGIN
  PRINT N'This SP must be executed in master.  USE master and then retry.'
  RETURN (-1)
 END

    DECLARE @DynamicSQL varchar(1000);
    DECLARE @CompName varchar(250);
 DECLARE @HasMasterKey INT;
    SELECT @CompName = CONVERT(SysName, SERVERPROPERTY('MachineName'));

-- Only create a master key if it doesn't already exist

 SELECT @HasMasterKey = is_master_key_encrypted_by_server from sys.databases where name = 'master'
 IF (@HasMasterKey = 0)
 BEGIN
 --Create a MASTER KEY to encrypt the certificate.
  SET @DynamicSQL = CONCAT('CREATE MASTER KEY ENCRYPTION BY PASSWORD = ' ,  QUOTENAME(@StrongPassword, ''''));
  EXEC (@DynamicSQL)
 END

--Create the certificate to authenticate the endpoint
    SET @DynamicSQL = CONCAT('CREATE CERTIFICATE ', QUOTENAME(@CompName + '-Cert'), ' WITH SUBJECT = ', QUOTENAME(@CompName, '''')) ;
    EXEC (@DynamicSQL);

    --Create the database mirroring endpoint authenticated by the certificate.
    SET @DynamicSQL =
        CONCAT('CREATE ENDPOINT Endpoint_Mirroring
            STATE = STARTED
            AS TCP (LISTENER_PORT = 5022, LISTENER_IP = ALL)
            FOR DATABASE_MIRRORING (AUTHENTICATION = CERTIFICATE ',QUOTENAME(@CompName + '-Cert'), ' , ENCRYPTION = REQUIRED ALGORITHM AES, ROLE = ALL)');
    EXEC (@DynamicSQL);

   --Back up the certificate to a common network share for import into other nodes in the cluster
    SET @DynamicSQL = CONCAT('BACKUP CERTIFICATE ',QUOTENAME(@CompName + '-Cert'),' To FILE = ', QUOTENAME( @ShareName + '\SQL-' + @CompName + '.cer', ''''));
    EXEC (@DynamicSQL);
END
GO

說明:

         CreateEndpointCert 接受2個參數,分別為共用路徑和證書密碼,其作用:創建證書,創建基於證書加密通訊的端點,備份證書到共用路徑;

CREATE PROCEDURE InstallEndpointCert
    @CompName SYSNAME,
 @ShareName SYSNAME,
 @StrongPassword SYSNAME
AS BEGIN
    DECLARE @DynamicSQL varchar(1000);
    DECLARE @MyCompName varchar(250);
    SELECT @MyCompName = CONVERT(SysName, SERVERPROPERTY('MachineName'));
   --Don't need to create LOGINs for the local system
    IF (@MyCompName <> @CompName)
    BEGIN
        SET @DynamicSQL = CONCAT('CREATE LOGIN ', QUOTENAME (@CompName + '-Login'), ' WITH PASSWORD= ', QUOTENAME( @StrongPassword, ''''));
        EXEC (@DynamicSQL);

        SET @DynamicSQL = CONCAT('CREATE USER ', QUOTENAME( @CompName + '-User'), ' FOR LOGIN ', QUOTENAME(@CompName + '-Login'));
        EXEC (@DynamicSQL);

        SET @DynamicSQL = CONCAT('CREATE CERTIFICATE ', QUOTENAME(@CompName +'-Cert'), ' AUTHORIZATION ', QUOTENAME(@CompName +'-User'), ' FROM FILE = ', QUOTENAME(@ShareName + '\SQL-' + @CompName + '.cer' , ''''));
        EXEC (@DynamicSQL);

        SET @DynamicSQL = CONCAT('GRANT CONNECT ON ENDPOINT::Endpoint_Mirroring TO ', QUOTENAME(@CompName +'-Login'));
        EXEC (@DynamicSQL);
 END
END
GO

說明:

       InstallEndpointCert  接受3個參數,分別為主機名、共用路徑(必須跟CreateEndpointCert的共用路徑相同)和密碼。其作用:在SQL Server中為每個節點(除自身外)創建一個對應的登錄用戶和資料庫用戶(為了便於管理),然後利用共用路徑中證書來授予該資料庫用戶可以訪問對應節點的端點;

 

3.2.2 創建端點

        首先依次在每個節點上執行CreateEndpointCert,創建證書,

        然後在每個節點上執行InstallEndpointCert,InstallEndpointCert的第一個參數就是主機名,也就是說,除了自身外,需要將其他所有節點的主機名作為參數都執行一次InstallEndpointCert。

 

說明:

  CreateEndpointCert 接受2個參數,分別為共用路徑和證書密碼,其作用:創建證書,創建基於證書加密通訊的端點,備份證書到共用路徑;

  InstallEndpointCert  接受3個參數,分別為主機名、共用路徑(必須跟CreateEndpointCert的共用路徑相同)和密碼(資料庫用戶的密碼)。

 

4.新建可用組

     打開SSMS,登錄到SQL Server,展開【AlwaysOn搞可用性】,根據嚮導創建AlwaysOn。

    4.1指定可用組名稱

clipboard

 

4.2選擇資料庫

      說明:在走AlwaysOn之前,資料庫必須在完整模式下,且已經做過完整備份。

clipboard

 

4.3指定副本,單擊【添加副本】把所有的成員節點添加進來;

       4.3.1 添加副本

clipboard

自動故障轉移:運行在哪些節點間建立高可用(SQL Server 2016已經支持在3個節點了) 。

同步提交:AlwaysOn同步的模式,對應的還有非同步模式,當選擇了自動故障轉移時,必須勾選同步提交;如想詳細瞭解同步和非同步模式的區別,可參考這個鏈接:http://www.cnblogs.com/i6first/p/4139670.html

可讀輔助副本:當該節點為輔助副本時,能否接受只讀請求以及以哪種方式接受只讀請求(只讀意向)。

 4.3.2配置端點

步驟3中創建的端點在這裡可以查看到:

image

 4.3.3配置偵聽器

clipboard

4.4 選擇數據同步的方式

       我選擇的是完整,指定了一個共用目錄,在後面安裝環節中,主副本會把資料庫備份到這個位置,然後輔助副本從此位置拿到備份文件後還原,已實現數據同步。

clipboard

4.5後面的【驗證】、【摘要】直接選擇Next(下一步)即可。

      正常情況完成步驟4.5以後AlwaysOn就搭建完了,但我在兩次實際驗證過程中發現還需要繼續後面的步驟,可能是我的環境的問題,請讀者根據需要參考。

4.6將可用副本聯機

     在下圖所示的位置,右擊離線的節點(紅色向下的標記),選擇聯接到可用性組;

clipboard


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 你沒有錯,現在的瀏覽器都不怎麼支持實體引用了,這是個無奈的現實。我記得上回試過,好像如果DTD不是單獨的文件而是內置到XML裡面的話,實體還可以顯示的。你可以試一下 ...
  • ...
  • 百度API:xlongwei 這個人提供的介面很多啊,也很實用:Word轉Html、Word轉Pdf、屬性配置、手機號段、微信公眾號消息加密、微信公眾號消息解密、二維碼、關鍵詞、分詞、拼音、生僻字、微博短鏈接。但是很多都不感興趣的,除了一個,那就是中文分詞啊。以前某天突然對瀏覽器以及編輯器中的滑鼠雙 ...
  • 新版六合彩投註網站系統源碼 (測試完整可商業運行) 帶新開獎結果》》》》》 網站系統可以支持代理開設,股東發展,普通會用等常用的功能。 玩法齊全》連碼自由對碰》各類玩法內附說明。資料庫文件 hs001 修改資料庫連接 文件夾 configs 文件config後臺管理 admin admin前臺會員目 ...
  • 本節介紹EnumMap的用法和實現原理,為什麼要針對枚舉類型單獨實現一個Map?它的用法和其他Map有什麼不同?內部是如何實現的?... ...
  • 效果: ...
  • 使用beans.xml文件進行bean的創建和註入通常是可行的,但在便利性上Spring提供了更簡單的方法——自動裝配 當然,我們也可以在創建bean時對它命名,在CDPlayer類中可以體會到。代碼如下: 值得註意的是,真正的實現過程與代碼主體非常複雜,@Component,@ComponScan ...
  • 一、面向對象 Java中的面向對象與C 的面向對象,本質都是一樣。所以對於學過C 的同學理解Java中面向對象的概念就比較輕鬆。 對象 定義: 萬物皆對象,客觀存在的事物都稱為 對象 。 1、面向對象 類 定義: 類是模具,確定對象將會擁有的特性(屬性)和行為(方法) 特點: A.類是對象的類型 B ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...