本文為機器翻譯文章。如需檢視英文版,請選取 [原文] 核取方塊。您也可以將滑鼠指標移到文字上,即可在快顯視窗顯示英文原文。
譯文
原文

在 SharePoint 2013 中移動 Search Service 應用程式資料庫

SharePoint 2013
 

適用版本:SharePoint Foundation 2013, SharePoint Server 2013

上次修改主題的時間:2016-12-16

摘要:了解如何移動 SharePoint 2013 中的 Search Service 應用程式資料庫。

您可以將服務應用程式資料庫移至另一個伺服器陣列資料庫伺服器或資料庫的執行個體,以平衡系統的負載。此程序包含兩個主要工作:移動資料庫檔案,然後將服務應用程式指向移動的資料庫。

注意事項 附註:
如果需要重新命名相同資料庫伺服器上的 Search Service 應用程式資料庫,您可以使用相同的程序。

本文內容:

注意事項 附註:
管理員通常會使用 SharePoint 2013 管理命令介面來管理部署。如需管理員適用之協助工具的詳細資訊,請參閱<SharePoint 2013 的協助工具>。
因為 SharePoint 2013 在 Internet Information Services (IIS) 中以網站形式運作,所以管理員與使用者均依賴瀏覽器提供的協助工具功能。SharePoint 2013 支援所支援瀏覽器的協助工具功能。如需詳細資訊,請參閱下列資源:
重要事項 重要事項:
執行作業的帳戶必須具備下列成員資格和權限:
  • 伺服器陣列管理員 SharePoint 群組的成員。

  • 本機伺服器上系統管理員群組的成員。

  • 來源位置的讀取權限,以及目標位置的寫入權限。

  • 您要移動之所有資料庫的 db_owner 固定資料庫角色。

  • 您要移動之所有資料庫的 db_creatorsecurityadmin 角色。

Search Service 帳戶必須具有下列角色:
  • 管理、連結及編目資料庫的 db_owner 固定資料庫角色。

  • 分析報告資料庫的 SPSearchDBAdmin 資料庫角色。

在某些環境中,您必須與資料庫管理員協調重新命名和移動程序。請務必遵循適用於管理資料庫的原則和準則。

若要移動 Search Service 應用程式資料庫,您必須使用 SQL Server、SQL Server Management Studio 及 Windows 檔案總管。若要指向移動的資料庫,您必須使用 Windows PowerShell。請依照所列示的順序完成下列步驟。

  1. 暫停 Search Service 應用程式。

    重要事項 重要事項:
    Search Service 應用程式必須暫停,直到資料庫還原在新位置,以及服務指向移動的資料庫為止。
  2. 將所有搜尋資料庫設為唯讀。

    這是必要動作,以防止備份及還原程序期間的新資料庫交易。

  3. 備份 Search Service 應用程式資料庫,但請勿繼續 Search Service 應用程式。

  4. 在新的 SQL Server 將平行處理原則的最大程度啟用為 1。

  5. 將 Search Service 應用程式資料庫還原至新位置。

  6. 將 Search Service 應用程式指向移動的資料庫。

  7. 繼續 Search Service 應用程式。

使用 Windows PowerShell 來暫停 Search Service 應用程式
  1. 確認您具備下列成員資格:

    • SQL Server 執行個體上的 securityadmin 固定伺服器角色。

    • 待更新之所有資料庫上的 db_owner 固定資料庫角色。

    • 正在執行 Windows PowerShell Cmdlet 之所在伺服器上的系統管理員群組。

    管理員可以使用 Add-SPShellAdmin Cmdlet 來授與使用 SharePoint 2013 Cmdlet 的權限。

    注意事項 附註:
    如果您沒有權限 ,請連絡安裝程式系統管理員或 SQL Server 管理員以要求權限。如需 Windows PowerShell 權限的其他詳細資訊,請參閱<Add-SPShellAdmin>。
  2. 啟動 SharePoint 2013 管理命令介面。

    • 若為 Windows Server 2008 R2:

      • 在 [開始] 功能表上,依序按一下 [所有程式]、[Microsoft SharePoint 2013 產品]、[SharePoint 2013 管理命令介面]。

    • 若為 Windows Server 2012:

      • 在 [開始] 畫面上,按一下 [SharePoint 2013 管理命令介面]。

        如果 [開始] 畫面上未顯示 [SharePoint 2013 管理命令介面]:

      • 在 [電腦] 上按一下滑鼠右鍵,按一下 [所有應用程式],然後按一下 [SharePoint 2013 管理命令介面]。

    如需如何與Windows Server 2012互動的詳細資訊,請參閱 <常見管理工作及 Windows Server 2012 中的導覽

  3. 在 Windows PowerShell 命令提示字元中,輸入下列命令:

    $ssa = Get-SPEnterpriseSearchServiceApplication <SearchServiceApplicationName>
    Suspend-SPEnterpriseSearchServiceApplication -Identity $ssa
    

    其中:

    • <SearchServiceApplicationName> 是資料庫移動相關的 Search Service 應用程式名稱。

變更 Search Service 應用程式資料庫的唯讀模式
  1. 確認執行此程序的使用者帳戶為內容資料庫之 db_owner 固定資料庫角色的成員。

  2. 開啟 SQL Server Management Studio 並連線至資料庫伺服器。

  3. 在 [物件總管] 中,展開 [資料庫]。

  4. 將下列資料庫設為唯讀模式:

    • 搜尋管理

    • 分析報告

    • 編目

    • 連結

    1. 以滑鼠右鍵按一下您要設為讀寫或唯讀模式的資料庫,然後按一下 [屬性]。

    2. 在 [資料庫屬性] 對話方塊中,於「選項」 屬性頁面的 [狀態] 區段中,選取 [資料庫唯讀] 旁之清單中的 [True] 或 [False],然後按一下 [確定]。

    3. 按一下 [是]。

備份 Search Service 應用程式資料庫
  1. 確認執行此程序的使用者帳戶是儲存各資料庫之資料庫伺服器上的 SQL Serverdb_backupoperator 固定資料庫角色成員。

  2. 啟動 SQL Server Management Studio,並連接至儲存 Search Service 應用程式資料庫的資料庫伺服器。

  3. 在 [物件總管] 中,展開 [資料庫]。

  4. 在要備份的資料庫上按一下滑鼠右鍵,並指向 [工作],然後按一下 [備份]。

  5. 在 [備份資料庫] 對話方塊的 [來源] 區域中,從 [備份類型] 清單選取要執行的備份種類。

    如需所要使用的備份類型的詳細資訊,請參閱SQL Server線上叢書中的復原模式 (SQL Server)

  6. 在 [備份元件] 區域中,按一下 [資料庫]。

  7. 在 [名稱] 方塊中,使用預設名稱,或指定備份組的名稱。

  8. 指定備份組的到期日。

    此日期會決定相同名稱的後續備份可於何時覆寫此備份組。根據預設,備份組會設為永不過期 (0 天)。

  9. 在 [目的地] 區域中,指定您要儲存備份的位置。

  10. 按一下 [確定] 備份資料庫。

  11. 針對下列資料庫重複步驟 1-10:

    • 搜尋管理

    • 分析報告

    • 編目

    • 連結

在主控 SQL Server 的新伺服器中將平行處理原則的最大程度設為 1
  1. 啟動 SQL Server Management Studio,並連接至主控 SQL Server (將要移動 Search Service 應用程式資料庫) 的新伺服器。

  2. 在 [物件總管] 中,以滑鼠右鍵按一下資料庫伺服器,然後按一下 [屬性]。

  3. 按一下 [進階]。

  4. 在 [平行處理原則的最大程度] 方塊中,選取 [1],以限制在平行計劃執行中使用的處理器數目。

    如需詳細資訊,請參閱 < Configure parallelism Server Configuration Option 的最大程度

將 Search Service 應用程式資料庫還原至新資料庫伺服器
  1. 確認您要用於還原資料庫的使用者帳戶是否為儲存每個資料庫之資料庫伺服器上 SQL Serversysadmin 固定伺服器角色的成員。

  2. 啟動 SQL Server Management Studio,並連線至資料庫伺服器。

  3. 在 [物件總管] 中,展開 [資料庫]。

  4. 以滑鼠右鍵按一下要還原的資料庫,並依序指向 [工作] 及 [還原],然後按一下 [資料庫]。

  5. 在 [還原資料庫] 對話方塊中的「一般」頁面上,從 [目的地資料庫] 清單中選取還原的目的地資料庫。

  6. 從 [從資料庫] 清單中選取還原的來源位置。

  7. 在 [選取要還原的備份集] 區域中,選取資料庫旁的核取方塊。

  8. 在 [選項] 索引標籤上,從 [復原狀態] 區段中選取復原狀態。

    如需使用哪種復原類型的詳細資訊,請參閱SQL Server線上叢書 》 中的復原模式 (SQL Server)

  9. 按一下 [確定] 還原資料庫。

  10. 針對與服務應用程式相關聯的每個資料庫重複步驟 1-9。

將 Search Service 應用程式資料庫設為讀寫模式
  1. 遵循<變更 Search Service 應用程式資料庫的唯讀模式>中的步驟進行。

您必須使用 Windows PowerShell 3.0 來指向移動的 Search Service 應用程式資料庫:搜尋管理、編目、連結以及分析報告。

使用 Windows PowerShell 將 Search Service 應用程式指向移動的資料庫
  1. 確認您具備下列成員資格:

    • SQL Server 執行個體上的 securityadmin 固定伺服器角色。

    • 待更新之所有資料庫上的 db_owner 固定資料庫角色。

    • 正在執行 Windows PowerShell Cmdlet 之所在伺服器上的系統管理員群組。

    管理員可以使用 Add-SPShellAdmin Cmdlet 來授與使用 SharePoint 2013 Cmdlet 的權限。

    注意事項 附註:
    如果您沒有權限 ,請連絡安裝程式系統管理員或 SQL Server 管理員以要求權限。如需 Windows PowerShell 權限的其他詳細資訊,請參閱<Add-SPShellAdmin>。
  2. 啟動 SharePoint 2013 管理命令介面。

    • 若為 Windows Server 2008 R2:

      1. 在 [開始] 功能表上,按一下 [所有程式]。

      2. 按一下 [Microsoft SharePoint 2013 產品]。

      3. 按一下 [SharePoint 2013 管理命令介面]。

    • 若為 Windows Server 2012:

      • 在 [開始] 畫面上,按一下 [SharePoint 2013 管理命令介面]。

        如果 [開始] 畫面上未顯示 [SharePoint 2013 管理命令介面]:

      1. 以滑鼠右鍵按一下 [電腦]。

      2. 按一下 [所有應用程式]。

      3. 按一下 [SharePoint 2013 管理命令介面] 。

    如需如何與Windows Server 2012互動的詳細資訊,請參閱 <常見管理工作及 Windows Server 2012 中的導覽

  3. 將搜尋管理資料庫指向新位置。在 Windows PowerShell 命令提示字元中,輸入下列命令:

    $ssa = Get-SPEnterpriseSearchServiceApplication <SearchServiceApplicationName>
    $ssa | Set-SPEnterpriseSearchServiceApplication [-DatabaseName "<NewDbName>"] -DatabaseServer "<NewServerName>"
    

    其中:

    • <新資料庫名稱> 是資料庫的名稱。

    • <新伺服器名稱> 是新的資料庫位置。

  4. 將分析報告資料庫指向新位置。在 Windows PowerShell 命令提示字元中,輸入下列命令:

    Add-SPServerScaleOutDatabase -ServiceApplication $ssa -DatabaseServer <NewServerName> [-DatabaseName <NewDbName>]
    $temp = Get-SPServerScaleOutDatabase -ServiceApplication $ssa
    Remove-SPServerScaleOutDatabase -Database $temp[0] -ServiceApplication $ssa
    
  5. 將編目資料庫指向新位置。在 Windows PowerShell 命令提示字元中,輸入下列命令:

    $CrawlDatabase0 = ([array]($ssa | Get-SPEnterpriseSearchCrawlDatabase))[0] 
    $CrawlDatabase0 | Set-SPEnterpriseSearchCrawlDatabase [-DatabaseName "<NewDbName>"] -DatabaseServer "<NewServerName>"
    
  6. 將連結資料庫指向新位置。在 Windows PowerShell 命令提示字元中,輸入下列命令:

    $LinksDatabase0 = ([array]($ssa | Get-SPEnterpriseSearchLinksDatabase))[0] 
    $LinksDatabase0 | Set-SPEnterpriseSearchLinksDatabase [-DatabaseName "<NewDbName>"] -DatabaseServer "<NewServerName>"
    
  7. 將所有 Search Service 執行個體設為線上。針對伺服器陣列中的每個 Search Service 執行下列命令,直到 Search Service 執行個體報告為線上。在 Windows PowerShell 命令提示字元中,輸入下列命令:

    get-SPEnterpriseSearchServiceInstance -Identity <Search Server> Do {write-host -NoNewline .;Sleep 10; $searchInstance = Get-SPEnterpriseSearchServiceInstance -Identity <Search Server>} while ($searchInstance.Status -ne "Online")
    

    其中:

    • <Search Server> 是主控搜尋元件的伺服器名稱。

  8. 繼續 Search Service 應用程式。在 Windows PowerShell 命令提示字元中,輸入下列命令:

    $ssa = Get-SPEnterpriseSearchServiceApplication <SearchServiceApplicationName>
    Resume-SPEnterpriseSearchServiceApplication -Identity $ssa
    

    其中:

    • <SearchServiceApplicationName> 是資料庫移動相關的 Search Service 應用程式名稱。

  9. 重新啟動主控搜尋元件的每一部伺服器。

https://technet.microsoft.com/zh-tw/library/jj219654.aspx
顯示: