设置目标服务器

适用于SQL Server

重要

Azure SQL 托管实例目前支持大多数(但不是所有)SQL Server 代理功能。 有关详细信息,请参阅 Azure SQL 托管实例与 SQL Server 的 T-SQL 区别

本主题介绍如何通过使用 SQL Server Management Studio、Transact-SQL 或 SQL Server 管理对象 (SMO) 在 SQL Server 中生成目标服务器。

开始之前

安全性

如果分布式作业的步骤与某个代理相关联,则该作业将在目标服务器上该代理帐户的上下文下运行。 请确保满足以下条件,否则与代理关联的作业步骤将不会从主服务器下载到目标服务器上:

  • 主服务器注册表子项 \HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Microsoft SQL Server\<*instance_name*>\SQL Server Agent\AllowDownloadedJobsToMatchProxyName (REG_DWORD) 设置为 1 (true)。 默认情况下,此子项设置为 0 (False)。

  • 目标服务器上已存在与运行作业步骤的主服务器代理帐户同名的代理帐户。

从主服务器将使用代理帐户的作业步骤下载到目标服务器时,如果作业步骤失败,可以检查 msdb 数据库中 sysdownloadlist 表的 error_message 列是否存在以下错误消息:

  • “该作业步骤需要代理帐户,但是目标服务器上禁用了代理匹配功能。”

    若要解决此错误,请将 AllowDownloadedJobsToMatchProxyName 注册表子项设置为 1。

  • “找不到代理。”

    若要解决此错误,请确保目标服务器上已存在与运行作业步骤的主服务器代理帐户同名的代理帐户。

权限

默认情况下授予 sysadmin 固定服务器角色的成员执行此过程的权限。

使用 SQL Server Management Studio

生成目标服务器

  1. 在“对象资源管理器”中,连接到一个 Microsoft SQL Server 数据库引擎实例,然后展开该实例。

  2. 右键单击“SQL Server 代理”,指向“多服务器管理”,然后单击“使其成为目标服务器”“目标服务器向导” 会指导您完成生成目标服务器的过程。

  3. “选择主服务器” 页中,选择此目标服务器将从中接收作业的主服务器。

    选取服务器
    连接到主服务器。

    此服务器的说明
    键入此目标服务器的说明。 目标服务器将此说明上载到主服务器。

  4. “主服务器登录凭据” 页中,在目标服务器上创建新的登录(如果需要)。

    在必要时创建新登录名,并为其分配针对 MSX 的权限
    如果指定的登录名不存在,则在目标服务器上创建新登录名。

“使用 Transact-SQL”

生成目标服务器

  1. 连接到 数据库引擎。

  2. 在标准菜单栏上,单击 “新建查询”

  3. 将以下示例复制并粘贴到查询窗口中,然后单击“执行” 。 本示例将当前服务器登记到 AdventureWorks1 主服务器中。 当前服务器的位置是 Building 21、Room 309、Rack 5。

    USE msdb ;  
    GO  
    
    EXEC dbo.sp_msx_enlist N'AdventureWorks1',   
        N'Building 21, Room 309, Rack 5' ;   
    GO
    

    有关详细信息,请参阅 sp_msx_enlist (Transact-SQL)

另请参阅

企业范围的自动化管理