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サーバージョブに追加する方法を説明できますか?
既存のエージェントジョブに新しい最初のステップを追加するストアドプロシージャを作成しました。
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...
_