Проблемы
Предположим, что у вас есть среда репликации транзакций Microsoft SQL Server 2008 R2, SQL Server 2012 или SQL Server 2014. В среде есть несколько экземпляров распространителя SQL Server. В этой ситуации может возникнуть нарушение прав доступа, и агент распространителя репликации SQL Server завершает работу со сбоем. Кроме того, создается файл мини-дампа.
Решение
После применения исправления агент корректно завершает работу, а не аварийный сбой вместе с файлом дампа. Вы можете добавить дополнительный шаг задания в задание агента распространителя, чтобы автоматически перезапустить агент, когда агент остановлен, и имеет состояние "запланировано для перезапуска". Дополнительные сведения о том, как добавить дополнительный шаг задания в задание агента распространителя, можно найти в разделе Дополнительные сведения. Эта проблема впервые устранена в следующем накопительном обновлении SQL Server.
Накопительное обновление 1 для SQL Server 2014 /en-us/help/2931693
Накопительное обновление 9 для SQL Server 2012 с пакетом обновления 1 (SP1) /en-us/help/2931078
Накопительное обновление 11 для SQL Server 2012 /en-us/help/2908007
Накопительное обновление 9 для SQL Server 2008 R2 с пакетом обновления 2 (SP2) /en-us/help/2887606
Все новые накопительные обновления для SQL Server содержат все исправления и все исправления для системы безопасности, которые были включены в предыдущий накопительный пакет обновления. Ознакомьтесь с самыми последними накопительными обновлениями для SQL Server.
Пакет обновлений для SQL Server 2008 R2 с пакетом обновления 1 (SP1)Исправление для этой проблемы впервые выпущено в пакете обновления для SQL server 2008 R2 с пакетом обновления 1 (SP1).
Статус
Корпорация Майкрософт подтверждает наличие этой проблемы в своих продуктах, которые перечислены в разделе "Применяется к".
Дополнительная информация
После применения исправления добавьте в задание агента распространителя следующий сценарий:DECLARE @JobID BINARY(16)DECLARE @AgentID intDECLARE @command varchar(max)DECLARE JobCur CURSOR FOR SELECT Job.job_id, Agent.id FROM msdb.dbo.sysjobs AS Job INNER JOIN msdb.dbo.syscategories AS Cat ON Job.category_id = Cat.category_id INNER JOIN msdb.dbo.sysjobsteps AS Steps ON Job.job_id = Steps.job_id INNER JOIN distribution.dbo.MSdistribution_agents AS Agent ON Job.job_id = Agent.job_id WHERE Job.name like '%Put Text Mask To Identify Your Publisher DB Jobs Here%' AND Cat.name = 'REPL-Distribution' GROUP BY Job.job_id, Agent.id HAVING COUNT(step_id) = 3OPEN JobCurFETCH NEXT FROM JobCur INTO @JobID, @AgentIDWHILE @@FETCH_STATUS = 0 BEGIN IF (@JobID is not NULL) BEGIN set @command = N'if (select top 1 runstatus from MSdistribution_history where agent_id = ' + convert(varchar, @AgentID)+ N' order by timestamp desc) = 5 raiserror(''Agent was scheduled for retry. Performing restart now'',16,1)' EXEC msdb.dbo.sp_add_jobstep @job_id=@JobID, @database_name=N'distribution', @step_name=N'Check for retry', @step_id=4, @on_fail_action=4, @on_fail_step_id=1, @command=@command EXEC msdb.dbo.sp_update_jobstep @job_id=@JobID, @step_id=2, @on_success_action=4, @on_success_step_id=4 END FETCH NEXT FROM JobCur INTO @JobID, @AgentID;ENDCLOSE JobCur;DEALLOCATE JobCur;GO