在 SharePoint Server 中移动或重命名服务应用程序数据库

 

**上一次修改主题:**2018-03-09

了解如何在 SharePoint Server 2016 和 SharePoint 2013 中移动或重命名服务应用程序数据库。

将服务应用程序数据库移到其他场数据库服务器的主要原因是保持场负载平衡。或者,您可能需要将其移到较新的硬件中。

通常,只有当使用 SharePoint 产品配置向导 和 SharePoint Server 产品配置向导在服务器场中创建服务应用程序数据库后,重命名服务应用程序数据库才会完成将 GUID 从数据库中删除的操作。可能还需要使数据库名称符合组织的命名标准。

移动和重命名服务应用程序数据库都遵循相同的基本流程,但在移动服务应用程序数据库时有几个额外的步骤。

  1. 使用 Microsoft SQL Server Management Studio 或 Microsoft PowerShell 移动或重命名 SharePoint Server 服务应用程序数据库。

  2. 使用 SharePoint 管理中心网站 或 PowerShell 将 SharePoint 服务应用程序指向已移动或重命名的数据库。

    根据您移动或重命名的服务应用程序数据库的数量,将服务应用程序指向数据库可能会非常复杂。不同的服务应用程序需要不同的方法才能指向已移动或重命名的数据库。

这些服务应用程序数据库使用以下步骤:

  • App Management Service

  • Managed Metadata Service

  • PerformancePoint Service

  • Secure Store Service

  • SharePoint Translation Service

  • State Service

  • 订阅设置服务

  • Word Automation Services

  1. 停止或禁用服务应用程序。

  2. 分离数据库。

  3. 移动或重命名数据库。

  4. 附加数据库。

  5. 将服务应用程序指向已移动或重命名的数据库。

  6. 重启服务应用程序。

Business Data Connectivity Service 和 User Profile Service 应用程序数据库需要以下步骤来移动或重命名数据库:

  1. 停止或禁用服务应用程序。

  2. 分离数据库。

  3. 移动或重命名数据库。

  4. 附加数据库。

  5. 将服务应用程序指向已移动或重命名的数据库。

  6. 删除服务应用程序。

  7. 重新创建服务应用程序。

  8. 重启服务应用程序。

Search Service 应用程序数据库需要执行以下步骤:

  1. 暂停服务应用程序。

  2. 将 Search service 应用程序设置为“只读”。

  3. 备份服务应用程序。

  4. 在托管 SQL Server 的新服务器中将最大并行度设置为 1。

  5. 将 Search service 应用程序还原到新的数据库服务器。

  6. 将 Search Service 应用程序设置为“读/写”。

  7. 启动服务应用程序。

  8. 将 Search service 应用程序指向已移动或重命名的数据库。

本文内容:

  • 使用 SQL Server 移动或重命名大多数服务应用程序数据库的一般步骤

  • 移动或重命名 Business Data Connectivity Service 和 User Profile Service 应用程序数据库的步骤

  • 移动和重命名 Search Service 应用程序数据库的步骤

使用 SQL Server 移动或重命名服务应用程序数据库的一般步骤

若要移动服务应用程序数据库,必须使用 SQL Server。若要重命名服务应用程序数据库,必须使用 SQL Server 和资源管理器。

警告

请勿尝试在一个过程中移动和重命名数据库。您应只移动数据库或重命名数据库,请勿同时执行这两项操作。

当您移动或重命名服务应用程序数据库时,第一步是停止您要更改的数据库的服务应用程序。您可以使用 管理中心 或 PowerShell 停止或启动服务。

步骤 1:使用 管理中心 停止服务应用程序

  1. 使用 SharePoint 组“Farm Administrators”的成员的帐户。

  2. 在 管理中心 中,单击“服务器设置”。

  3. 在“系统设置”页上的“服务器”部分,单击“管理服务器上的服务”。

  4. 找到您要停止的服务,单击服务的“操作”列中的“停止”或“禁用”,然后单击“确定”。

使用 PowerShell 停止服务

  1. 使用具有以下成员身份的帐户:

    • SQL Server 实例上的 securityadmin 固定服务器角色。

    • 要更新的所有数据库上的 db_owner 固定数据库角色。

    • 运行 PowerShell cmdlet 的服务器上的 Administrators 组。

      备注

      有关 Windows PowerShell 权限的其他信息,请参阅权限

  2. 启动 SharePoint 命令行管理程序。

  3. 您需要知道下一步的服务 GUID。使用 Get-SPServiceInstance cmdlet 检索场中的所有服务及其 GUID 的列表。

  4. 在 PowerShell 命令提示符处,键入以下命令:

    Stop-SPServiceInstance -Identity <ServiceGUID>
    

    其中,<ServiceGUID> 是服务的 GUID。

    有关详细信息,请参阅 Stop-SPServiceInstance

使用 SQL Server Management Studio 和资源管理器移动数据库

移动数据库要求先从 SQL Server 分离数据库,使用资源管理器将文件移动到新位置,然后将数据库附加到 SQL Server 的新实例。

步骤 2:从 SQL Server 分离数据库

  1. 使用具有要移动的所有数据库的 db_owner 固定数据库角色的帐户。

  2. 在 SQL Server Management Studio 中,连接到服务应用数据库附加到的 SQL Server 实例上,然后展开“数据库”节点。

  3. 右键单击数据库,指向“任务”,然后单击“分离”。针对要移动的每个数据库,重复此步骤。

步骤 3:使用文件资源管理器将数据库文件移到新位置

  1. 使用对源位置具有读取权限,对目标位置具有写入权限的帐户。

  2. 在资源管理器中查找服务应用程序数据库的 .mdf, .ndf 和.ldf 文件并选择想要移动的文件。通常会在 C:\Program Files\Microsoft SQL Server\MSSQL12.MSSQLServer\MSSQL\Data 位置找到数据库文件

  3. 将数据库文件复制或移动到新位置。

步骤 4:将数据库附加到 SQL Server 的新实例

  1. 使用具有要移动的所有数据库的 db_owner 固定数据库角色的帐户。

  2. 在 SQL Server Management Studio 中,打开目标 SQL Server 实例。

  3. 右键单击“数据库”节点,指向“任务”,再单击“附加”。

  4. 在“附加数据库”对话框中,浏览至您将 .mdf, .ndf 和 .ldf 文件移动到的位置,选择要附加的数据库的 .mdf 文件,然后单击“确定”。针对要移动的每个数据库,重复此步骤。

使用 SQL Server Management Studio 重命名数据库

重命名服务应用数据库是一个包含两个步骤的过程,首先,停止服务,这与移动数据库相同。然后,使用 SQL Server Management Studio 重命名数据库。

步骤 3:使用 SQL Server 重命名数据库

  1. 在 SQL Server Management Studio 中,连接到 SQL Server 源实例,然后展开“数据库”节点。

  2. 右键单击要重命名的数据库,单击“重命名”,然后键入新名称。针对要重命名的每个数据库,重复此步骤。

将 SharePoint Server 服务应用程序指向已移动或重命名的数据库

下一步是指向已移动或重命名的数据库。您可以使用 管理中心 或 PowerShell 来执行此操作。使用 管理中心 将服务应用程序指向已移动或重命名的数据库,这对大部分 SharePoint Server 服务应用程序而言是相同的。使用 PowerShell 将服务应用程序指向已移动或重命名的数据库,这根据每个服务应用程序有所不同。本节内容提供对每个服务应用程序和数据库的指导。

第 5 步:使用管理中心将服务应用指向已移动或重命名的数据库

  1. 使用 SharePoint 组“Farm Administrators”的成员的帐户。

  2. 在管理中心中的“应用程序管理”下,单击“管理服务应用程序”。

  3. 在“管理服务应用程序”页上,单击服务应用程序名称旁边的行中的空白区域。功能区将变为活动状态,单击“属性”,将显示“编辑服务应用程序”对话框。

  4. 更改数据库服务器或数据库名称,然后单击“确定”。

使用 PowerShell 将 Managed Metadata Service 应用程序指向已移动或重命名的数据库

  1. 使用具有以下成员身份的帐户:

    • SQL Server 实例上的 securityadmin 固定服务器角色。

    • 要更新的所有数据库上的 db_owner 固定数据库角色。

    • 运行 PowerShell cmdlet 的服务器上的 Administrators 组。

      备注

      有关 Windows PowerShell 权限的其他信息,请参阅权限

  2. 启动 SharePoint 命令行管理程序。

  3. 在 PowerShell 命令提示符处,键入以下命令:

    $app = Get-SPServiceApplication -Name "<ServiceApplicationName>"
    Set-SPMetadataServiceApplication -Identity "<Name/GUID of service application>" $app -DatabaseName "<DatabaseName>" -DatabaseCredentials PSCredential object>
    

    其中:

    • <ServiceApplicationName> 是 Managed Metadata Service 应用程序的名称。

    • <DatabaseName> 是重命名的数据库的名称。

使用 PowerShell 将 PerformancePoint Service 应用程序指向重命名或已移动的数据库

  1. 使用具有以下成员身份的帐户:

    • SQL Server 实例上的 securityadmin 固定服务器角色。

    • 要更新的所有数据库上的 db_owner 固定数据库角色。

    • 运行 PowerShell cmdlet 的服务器上的 Administrators 组。

      备注

      有关 Windows PowerShell 权限的其他信息,请参阅权限

  2. 启动 SharePoint 命令行管理程序。

  3. 在 PowerShell 命令提示符处,键入以下命令:

    Set-SPPerformancePointServiceApplication -Identity "<ServiceApplicationName>" -SettingsDatabase "<DatabaseServerName\DatabaseName>"
    

    其中:

    • <ServiceApplicationName> 是 PerformancePoint Service 应用程序的名称。

    • <DatabaseServerName\DatabaseName> 是重命名或移动的数据库的位置和名称。如果您只是重命名数据库,则不包括位置。

State Service 数据库用于存储临时状态信息数据。您可通过执行以下过程之一,使用 PowerShell 将 State Service 服务应用程序指向已移动的数据库:

  • 在新位置添加一个新的数据库,或使用新名称创建一个数据库。然后将新数据库添加到服务应用程序,并删除旧的数据库。有关详细信息,请参阅使用 Windows PowerShell,将新数据库添加到 State Service 服务应用程序并删除旧数据库。

  • 使用 SQL Server 卸除、移动旧数据库,然后重新安装 State Service 数据库。有关详细信息,请参阅使用 Windows PowerShell 将 State Service 应用程序指向已移动的数据库。

    下面的过程均包含项目符号列表中显示的步骤。因此,它们不要求已经执行这些步骤:

    • 停止服务应用程序

    • 使用 SQL Server Management Studio 和 Windows 移动数据库

使用 PowerShell 将新数据库添加到 State Service 服务应用程序并删除旧数据库

  1. 使用具有以下成员身份的帐户:

    • SQL Server 实例上的 securityadmin 固定服务器角色。

    • 要更新的所有数据库上的 db_owner 固定数据库角色。

    • 运行 PowerShell cmdlet 的服务器上的 Administrators 组。

      备注

      有关 Windows PowerShell 权限的其他信息,请参阅权限

  2. 启动 SharePoint 命令行管理程序。

  3. 在 PowerShell 命令提示符处,键入以下命令以创建新的数据库:

    New-SPStateServiceDatabase -Name "<NewDatabaseName>" 
    

    然后,键入以下命令以删除旧的数据库:

    Remove-SPStateServiceDatabase -Name "<OldDatabaseName>"
    

    其中:

    • <NewDatabaseName> 是要创建的新数据库的名称。

    • <OldDatabaseName> 是要与 State Service 取消关联并从 SQL Server 分离的旧数据库的名称。

使用 PowerShell 将 State Service 服务应用程序指向已移动的数据库

  1. 启动 SharePoint 命令行管理程序。

  2. 在 PowerShell 命令提示符处,键入以下命令以卸除数据库:

    Dismount-SPStateServiceDatabase -Identity <DatabaseID>
    

    其中,<DatabaseID> 是要从服务应用程序中移除的 State Service 数据库。键入的值必须是 12345678-90ab-cdef-1234-567890bcdefgh 形式的有效 GUID、State 数据库的有效名称或有效 SPStateServiceDatabase 对象的实例。

    有关详细信息,请参阅 Dismount-SPStateServiceDatabase

  3. 移动数据库。有关详细信息,请参阅使用 SQL Server Management Studio 和文件资源管理器移动数据库。

  4. 在 PowerShell 命令提示符处,键入以下命令,装载已重命名或移动的数据库:

    Mount-SPStateServiceDatabase -Name "<DatabaseName>" -DatabaseServer "<ServerName>"
    

    其中:

    • <DatabaseName> 是要与 State Service 关联的数据库的名称。

    • <ServerName> 是承载 State Service 数据库的 SQL Server 的名称。

使用 PowerShell 将 Usage and Health Data Collection 服务应用程序指向已移动的数据库

  1. 使用具有以下成员身份的帐户:

    • SQL Server 实例上的 securityadmin 固定服务器角色。

    • 要更新的所有数据库上的 db_owner 固定数据库角色。

    • 运行 PowerShell cmdlet 的服务器上的 Administrators 组。

      备注

      有关 Windows PowerShell 权限的其他信息,请参阅权限

  2. 启动 SharePoint 命令行管理程序。

  3. 在 PowerShell 命令提示符处,键入以下命令:

    Set-SPUsageApplication -Identity "<ServiceApplicationName>" -DatabaseName "<DbName>" -DatabaseServer "<SQLServerName>"
    

    其中:

    • <ServiceApplicationName> 是 Usage and Health Data Collection Service 应用程序的名称。

    • <DatabaseName> 是数据库的名称。

    • <SQLServerName> 是数据库服务器的名称。

使用 PowerShell 将 Word Automation Service 应用程序指向重命名或已移动的数据库

  1. 使用具有以下成员身份的帐户:

    • SQL Server 实例上的 securityadmin 固定服务器角色。

    • 要更新的所有数据库上的 db_owner 固定数据库角色。

    • 运行 PowerShell cmdlet 的服务器上的 Administrators 组。

      备注

      有关 Windows PowerShell 权限的其他信息,请参阅权限

  2. 启动 SharePoint 命令行管理程序。

  3. 在 PowerShell 命令提示符处,键入以下命令:

    $app = Get-SPServiceApplication -Name "<ServiceApplicationName>"
    Set-SPWordConversionServiceApplication -Identity $app -DatabaseName "<DatabaseName>" -DatabaseServer "<DatabaseServer>"
    

    其中:

    • <ServiceApplicationName> 是 Word Automation Service 应用程序的名称。

    • <DatabaseName> 是重命名或移动的数据库的名称。

    • <DatabaseServer> 是重命名或移动的数据库的位置。如果要指向同一位置的重命名的数据库,则不包括此参数。

使用 PowerShell 将 Subscription Settings Services 服务应用程序指向已移动的数据库

  1. 使用具有以下成员身份的帐户:

    • SQL Server 实例上的 securityadmin 固定服务器角色。

    • 要更新的所有数据库上的 db_owner 固定数据库角色。

    • 运行 PowerShell cmdlet 的服务器上的 Administrators 组。

      备注

      有关 Windows PowerShell 权限的其他信息,请参阅权限

  2. 启动 SharePoint 命令行管理程序。

  3. 在 PowerShell 命令提示符处,键入以下命令:

    Set-SPSubscriptionSettingsServiceApplication -Identity "<ServiceApplicationName>" -DatabaseName "<DatabaseName>" -DatabaseServer "<DatabaseServer>"
    

    其中:

    • <ServiceApplicationName> 是 Subscription Settings Service 应用程序的名称。

    • <DatabaseName> 是重命名的数据库的名称。

    • <DatabaseServer> 是重命名的数据库的服务器。

使用 PowerShell 指向已移动或重命名的数据库根据每个服务应用程序有所不同。每个服务应用程序使用的命令和 cmdlet 稍有不同,如下表所示。

步骤 6:使用 管理中心 启动服务应用程序

  1. 使用 SharePoint 组“Farm Administrators”的成员的帐户。

  2. 在 管理中心 中,单击“服务器设置”。

  3. 在“系统设置”页上的“服务器”部分,单击“管理服务器上的服务”。

  4. 找到您要停止的服务,单击服务的“操作”列中的“启动”,然后单击“确定”。

移动或重命名 Business Data Connectivity Service 和 User Profile Service 应用程序数据库的步骤

移动或重命名 Business Data Connectivity service 和 User Profile service 应用程序数据库时需要额外的步骤。这两个服务应用程序数据库所需的额外步骤是,在移动或重命名数据库后,我们建议您删除该服务应用程序,然后重新创建。

以下过程演示如何移动或删除 Business Data Connectivity Service 应用程序。

停止 Business Data Connectivity service 应用程序

  1. 使用 SharePoint 组“Farm Administrators”的成员的帐户。

  2. 在 管理中心 中,单击“服务器设置”。

  3. 在“系统设置”页上的“服务器”部分,单击“管理服务器上的服务”。

  4. 找到您要停止的服务,单击服务的“操作”列中的“停止”或“禁用”,然后单击“确定”。

使用 PowerShell 停止服务

  1. 启动 SharePoint 命令行管理程序。

  2. 在 PowerShell 命令提示符处,键入以下命令:

    Stop-SPServiceInstance -Identity <ServiceGUID>
    

    其中,<ServiceGUID> 是该服务的 GUID。如果不知道服务 GUID,可以使用 Get-SPServiceInstance cmdlet 来检索服务器场中所有服务的列表以及相应的 GUID。

    有关详细信息,请参阅 Stop-SPServiceInstanceGet-SPServiceInstance

步骤 2:从 SQL Server 分离数据库

  1. 使用具有要移动的所有数据库的 db_owner 固定数据库角色的帐户。

  2. 在 SQL Server Management Studio 中,连接到 SQL Server 源实例,然后展开“数据库”节点。

  3. 右键单击数据库,指向“任务”,然后单击“分离”。针对要移动的每个数据库,重复此步骤。

步骤 3:使用文件资源管理器或 Windows 资源管理器将数据库文件移到新位置

  1. 使用对源位置具有读取权限,对目标位置具有写入权限的帐户。

  2. 在资源管理器中查找服务应用程序数据库的 .mdf, .ndf 和.ldf 文件并选择想要移动的文件。通常会在 C:\Program Files\Microsoft SQL Server\MSSQL12.MSSQLServer\MSSQL\Data 位置找到数据库文件

  3. 将数据库文件复制或移动到新位置。

步骤 4:将数据库附加到 SQL Server 的新实例

  1. 使用具有要移动的所有数据库的 db_owner 固定数据库角色的帐户。

  2. 在 SQL Server Management Studio 中,打开目标 SQL Server 实例。

  3. 右键单击“数据库”节点,指向“任务”,再单击“附加”。

  4. 在“附加数据库”对话框中,浏览至您将 .mdf, .ndf 和 .ldf 文件移动到的位置,选择要附加的数据库的 .mdf 文件,然后单击“确定”。针对要移动的每个数据库,重复此步骤。

将 Business Data Connectivity service 应用程序指向已移动的数据库

适用于大多数服务应用程序的将服务应用程序指向移动的数据库的一般方法为:先删除服务应用程序,然后再重新创建服务应用程序。重新创建服务应用程序时,请使用新的名称或新的位置。

记录服务应用程序设置

使用管理中心删除服务应用程序

  • 使用 SharePoint 组“Farm Administrators”的成员的帐户。

  • 在管理中心中,单击“应用程序管理”,然后单击“管理服务应用程序”。

  • 在“服务应用程序”页上,将光标置于 Business Data Connectivity Service的旁边,然后单击空行。

    功能区将变为活动状态。

  • 在功能区上,单击“删除”。

  • 若要删除服务应用程序数据库,请在“删除服务应用程序”对话框中,选中“删除与服务应用程序关联的数据”旁边的复选框。如果要保留此数据库,请清除该复选框。

  • 单击“确定”删除服务应用程序,或单击“取消”停止操作。

创建服务应用程序

启动服务应用程序

  1. 若要启动服务应用程序,请参阅在 SharePoint Server 中启动或停止服务

移动和重命名 Search Service 应用程序数据库的步骤

若要移动 Search Service 应用程序数据库,您必须使用 SQL Server、SQL Server Management Studio 和 Windows 资源管理器。若要指向移动的数据库,您必须使用 PowerShell。请按列出的顺序完成以下步骤。

重要

用于执行操作的帐户必须具有以下成员身份和权限:

  • SharePoint 组“Farm Administrators”的成员。

  • 本地服务器上 Administrators 组的成员。

  • 对源位置的读取权限和对目标位置的写入权限。

  • 要移动的所有数据库的 db_owner 固定数据库角色。

  • 要移动的所有数据库的 db_creatorsecurityadmin 角色。

Search Service 帐户必须具有以下角色:
  • 管理数据库、链接数据库和爬网数据库上的 db_owner 固定数据库角色。

  • 分析报告数据库上的 SPSearchDBAdmin 数据库角色。

在有些环境中,您必须与数据库管理员配合执行重命名和移动过程。请务必遵循适用的策略和准则来管理数据库。

使用 PowerShell 暂停 Search Service 应用程序

  1. 启动 SharePoint 命令行管理程序。

  2. 在 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 Server db_backupoperator 固定数据库角色的成员的帐户。

  2. 启动 SQL Server Management Studio 并连接到存储 Search Service 应用程序数据库的数据库服务器。

  3. 在对象资源管理器中,展开“数据库”。

  4. 右键单击要备份的数据库,指向“任务”,然后单击“备份”。

  5. 在“备份数据库”对话框的“源”区域中,从“备份类型”列表中选择要执行的备份类型。

    有关要使用的备份类型的详细信息,请参阅恢复模式 (SQL Server)

  6. 在“备份组件”区域中,单击“数据库”。

  7. 在“名称”框中,为备份集使用默认名称或指定一个名称。

  8. 指定备份集的到期日期。

    此日期确定备份集何时可被同名的后续备份覆盖。默认情况下,备份集设置为永不过期(0 天)。

  9. 在“目标”区域中指定要将备份存储在何处。

  10. 单击“确定”以备份数据库。

  11. 对以下数据库重复步骤 1-10:

    • Search Administration

    • 分析报告

    • 爬网

    • 链接

在托管 SQL Server 的新服务器中将最大并行度值设置为 1

  1. 启动 SQL Server Management Studio 并连接到承载您将 Search Service 应用程序数据库移动到的 SQL Server 的新服务器。

  2. 在“对象资源管理器”中,右键单击数据库服务器,然后单击“属性”。

  3. 单击“高级”。

  4. 在“最大并行度”框中,选择“1”以限制并行计划执行中要使用的处理器的数量。

    有关详细信息,请参阅配置 max degree of parallelism 服务器配置选项

将 Search Service 应用程序数据库还原到新的数据库服务器

  1. 使用是存储每个数据库的数据库服务器上 SQL Server sysadmin 固定服务器角色的成员的帐户。

  2. 启动 SQL Server Management Studio 并连接到数据库服务器。

  3. 在“对象资源管理器”中,展开“数据库”。

  4. 右键单击要还原的数据库,指向“任务”,再指向“还原”,然后单击“数据库”。

  5. 在“还原数据库”对话框中的“常规”页上,从“目标数据库”列表中选择要还原到的数据库。

  6. 从“自数据库”列表中选择还原源。

  7. 在“选择要还原的备份集”区域,选中数据库旁边的复选框。

  8. 在“选项”选项卡上,从“恢复状态”部分选择恢复状态。

    有关要使用的恢复类型的详细信息,请参阅 SQL Server 联机丛书中的恢复模式 (SQL Server)

  9. 单击“确定”还原数据库。

  10. 对与该服务应用程序关联的每个数据库重复步骤 1-9。

将 Search Service 应用程序数据库设置为读/写

  1. 按照更改 Search Service 应用程序数据库的只读模式中的步骤操作。

使用 PowerShell 将 Search Service 应用程序指向已移动的数据库

  1. 启动 SharePoint 命令行管理程序。

  2. 将 Search Service 应用程序指向新位置。在 PowerShell 命令提示符处,键入以下命令:

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

    其中:

    • <NewDbName> 是数据库的名称。

    • <NewServerName> 是新的数据库位置。

  3. 将 CrawlStore 数据库指向新位置。在 PowerShell 命令提示符处,键入以下命令:

    $CrawlDatabase0 = ([array]($ssa | Get-SPEnterpriseSearchCrawlDatabase))[0] 
    $CrawlDatabase0 | Set-SPEnterpriseSearchCrawlDatabase [-DatabaseName "<NewDbName>"] -DatabaseServer "<NewServerName>"
    
  4. 将 LinkStore 数据库指向新位置。在 PowerShell 命令提示符处,键入以下命令:

    $LinksDatabase0 = ([array]($ssa | Get-SPEnterpriseSearchLinksDatabase))[0] 
    $LinksDatabase0 | Set-SPEnterpriseSearchLinksDatabase [-DatabaseName "<NewDbName>"] -DatabaseServer "<NewServerName>"
    
  5. 将所有 Search Service 实例设置为联机。对服务器场中的每个 Search Service 运行以下命令,直到 Search Service 实例报告为联机。在 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> 是承载搜索组件的服务器的名称。

  6. 恢复 Search service 应用程序。在 PowerShell 命令提示符处,键入以下命令:

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

    其中,<SearchServiceApplicationName> 是与数据库移动相关联的 Search service 应用程序的名称。

  7. 重新启动承载搜索组件的每台服务器。

See also

在 SharePoint Server 中移动所有数据库