web-dev-qa-db-ja.com

SQL Serverのすべての既存のジョブにステップを追加する方法

IF (SELECT ars.role_desc
    FROM sys.dm_hadr_availability_replica_states ars
    INNER JOIN sys.availability_groups ag
    ON ars.group_id = ag.group_id
    AND ars.is_local = 1) <> 'PRIMARY'
BEGIN
   --We're on the secondary node, throw an error
   THROW 50001, 'Unable to execute job on secondary node',1
END

このステップを設定して、成功時に次のステップに進み、失敗した場合に成功を報告するジョブを終了します。

このステップを既存のすべてのSQLサーバージョブに追加する方法を説明できますか?

1
Uday

既存のエージェントジョブに新しい最初のステップを追加するストアドプロシージャを作成しました。

AGプライマリレプリカで実行されているかどうかを確認し、それ以外の場合は正常に終了します。

_use master
go

-- Adds a first step to specified job, which checks whether running on Primary replica

create procedure AddAGPrimaryCheckStepToAgentJob
    @jobname nvarchar(128)
as

set nocount on;

-- Do nothing if No AG groups defined
IF SERVERPROPERTY ('IsHadrEnabled') = 1
begin
    declare @jobid uniqueidentifier = (select sj.job_id from msdb.dbo.sysjobs sj where sj.name = @jobname)

    if not exists(select * from msdb.dbo.sysjobsteps where job_id = @jobid and step_name = 'Check If AG Primary' )
    begin
        -- Add new first step: on success go to next step, on failure quit reporting success
        exec msdb.dbo.sp_add_jobstep 
          @job_id = @jobid
        , @step_id = 1
        , @cmdexec_success_code = 0
        , @step_name = 'Check If AG Primary'
        , @on_success_action = 3  -- On success, go to Next Step
        , @on_success_step_id = 2
        , @on_fail_action = 1     -- On failure, Quit with Success  
        , @on_fail_step_id = 0
        , @retry_attempts = 0
        , @retry_interval = 0
        , @os_run_priority = 0
        , @subsystem = N'TSQL'
        , @command=N'IF (SELECT ars.role_desc
        FROM sys.dm_hadr_availability_replica_states ars
        JOIN sys.availability_groups ag ON ars.group_id = ag.group_id AND ars.is_local = 1) <> ''Primary''
    BEGIN
       -- Secondary node, throw an error
       raiserror (''Not the AG primary'', 2, 1)
    END'
        , @database_name=N'master'
        , @flags=0
    end
end
GO
_

ブログ投稿は こちら です。

注:SQL Server 2014以降では、組み込み関数 sys.fn_hadr_is_primary_replica('dbname') を使用できます。

_If sys.fn_hadr_is_primary_replica (@dbname) <> 1   
BEGIN 
    -- This is not the primary replica, exit without error. 
END 
-- This is the primary replica, continue to run the job... 
_
4
Mitch Wheat