有时候搭建的复制在作业比较多的时候,会因为某些情况导致代理停止或出错,如果分发代理时间停止稍微过长可能导致复制延期,从而需要从新初始化复制,带来问题。因此我写了一个脚本定期检查处于停止状态的分发代理,将其启动。

注:该脚本需要跑在分发服务器下的MSDB库中。

 

USE [msdb]

 

Create PROC [dbo].[CheckToRestartStopedAgentJob]

AS

    DECLARE @jobname VARCHAR(200)

 

    DECLARE jobname CURSOR

    FOR

        SELECT DISTINCT

                b.name AS MergeJobName

        FROM    distribution.dbo.MSdistribution_history a

                INNER JOIN distribution.dbo.MSdistribution_agents b ON a.agent_id = b.id

        WHERE   comments LIKE '传递了%'

 

    OPEN jobname

 

    FETCH NEXT  FROM jobname INTO @jobname

 

    WHILE @@FETCH_STATUS = 0

        BEGIN

 

 

 

                BEGIN

 

                    IF NOT EXISTS ( SELECT  *

                                    FROM    msdb..sysjobs

                                    WHERE   Name = @jobname )

                        BEGIN

                            PRINT 'Job does not exists'

     

                        END

                    ELSE

                        BEGIN

                            CREATE TABLE #xp_results

                                (

                                  job_id UNIQUEIDENTIFIER NOT NULL ,

                                  last_run_date INT NOT NULL ,

                                  last_run_time INT NOT NULL ,

                                  next_run_date INT NOT NULL ,

                                  next_run_time INT NOT NULL ,

                                  next_run_schedule_id INT NOT NULL ,

                                  requested_to_run INT NOT NULL , -- BOOL  

                                  request_source INT NOT NULL ,

                                  request_source_id SYSNAME

                                    COLLATE database_default

                                    NULL ,

                                  running INT NOT NULL , -- BOOL  

                                  current_step INT NOT NULL ,

                                  current_retry_attempt INT NOT NULL ,

                                  job_state INT NOT NULL

                                )  

 

                            INSERT  INTO #xp_results

                                    EXECUTE master.dbo.xp_sqlagent_enum_jobs 1,

                                        'sa'  

 

                            IF EXISTS ( SELECT  1

                                        FROM    #xp_results X

                                                INNER JOIN msdb..sysjobs J ON X.job_id = J.job_id

                                        WHERE   x.running = 1

                                                AND j.name = @jobname )

                                BEGIN

                                    PRINT 1

                                END

                            ELSE

                                BEGIN

                                    INSERT  INTO master.dbo.RestartMergeReplicationLog

                                            ( message ,

                                              errortime

                                            )

                                    VALUES  ( 'Job:' + @jobname

                                              + ' is not running,restarting......' ,

                                              GETDATE()

                                            )

                                    EXEC('EXEC dbo.sp_start_job  '''+@jobname+'''' )

                                END 

                            DROP TABLE #xp_results

                        END

   

 

 

 

 

 

         

            FETCH NEXT  FROM jobname INTO @jobname

        END

 

 

    CLOSE jobname

    DEALLOCATE jobname

 

 

 

 

 

 

T-SQL检查停止的复制作业代理,并启动的更多相关文章

  1. T-SQL检查停止的复制作业代理,并启动 (转载)

    有时候搭建的复制在作业比较多的时候,会因为某些情况导致代理停止或出错,如果分发代理时间停止稍微过长可能导致复制延期,从而需要从新初始化复制,带来问题.因此我写了一个脚本定期检查处于停止状态的分发代理, ...

  2. sql server 用脚本管理作业

    转自:https://blog.csdn.net/yunye114105/article/details/6594826 摘要: 在SQL SERVER中用脚本管理作业,在绝大部分场景下,脚本都比UI ...

  3. 通过SQL Server 2008数据库复制实现数据库同步备份

    SQL Server 2008数据库复制是通过发布/订阅的机制进行多台服务器之间的数据同步,我们把它用于数据库的同步备份.这里的同步备份指的是备份服务器与主服务器进行 实时数据同步,正常情况下只使用主 ...

  4. sql server 2008数据复制

    SQL Server 2008数据库复制是通过发布/订阅的机制进行多台服务器之间的数据同步,我们把它用于数据库的同步备份.这里的同步备份指的是备份服务器与主服务器进行实时数据同步,正常情况下只使用主数 ...

  5. SQL Server 2005同步复制

    原文:SQL Server 2005同步复制 以下实现复制步骤(以快照复制为例) 运行平台SQL SERVER 2005 一.准备工作: 1.建立一个 WINDOWS 用户,设置为管理员权限,并设置密 ...

  6. SQL Server2005配置同步复制

    因为实际需要,需要对两台SQL Server服务器配置同步复制.记录一下配置过程. 配置环境 两台服务器: 发布服务器,以下简称PS. 订阅服务器,以下简称SS. 两台服务器都是Windows Ser ...

  7. SQL Server 2000事务复制问题

    2000现在用的估计不多了,把之前收集的一些复制问题整理发布出来.可能都是些很白很二的问题,但人总是由最初的无知不断成长●-● SQL Server 2000事务复制问题服务器A(发布) 服务器B(分 ...

  8. 【转】通过SQL Server 2008数据库复制实现数据库同步备份

    SQL Server 2008数据库复制是通过发布/订阅的机制进行多台服务器之间的数据同步,我们把它用于数据库的同步备份.这里的同步备份指的是备份服务器与主服务器进行实时数据同步,正常情况下只使用主数 ...

  9. SQL Server跨库复制表数据错误的解决办法

    SQL Server跨库复制表数据的解决办法   跨库复制表数据,有很多种方法,最常见的是写程序来批量导入数据了,但是这种方法并不是最优方法,今天就用到了一个很犀利的方法,可以完美在 Sql Serv ...

随机推荐

  1. console的高级使用

    1.console.table()用来表格化展示数据. var people = { zqz: { name: 'zhaoqize', age: 'guess?' }, wdx: { name: 'w ...

  2. Android数据存储之Android 6.0运行时权限下文件存储的思考

    前言: 在我们做App开发的过程中基本上都会用到文件存储,所以文件存储对于我们来说是相当熟悉了,不过自从Android 6.0发布之后,基于运行时权限机制访问外置sdcard是需要动态申请权限,所以以 ...

  3. Intel Media SDK H264 encoder GOP setting

    1 I帧,P帧,B帧,IDR帧,NAL单元 I frame:帧内编码帧,又称intra picture,I 帧通常是每个 GOP(MPEG 所使用的一种视频压缩技术)的第一个帧,经过适度地压缩,做为随 ...

  4. 深入理解 Java G1 垃圾收集器--转

    原文地址:http://blog.jobbole.com/109170/?utm_source=hao.jobbole.com&utm_medium=relatedArticle 本文首先简单 ...

  5. ASP.NET MVC5----常见的数据注解和验证

    只要一直走,慢点又何妨. 在使用MVC模式进行开发时,数据注解是经常使用的(模型之上操作),下面是我看书整理的一些常见的用法. 什么是验证,数据注解 验证 从全局来看,发现逻辑仅是整个验证的很小的一部 ...

  6. .NET面试题集锦①(Part一)

    一.前言部分 文中的问题及答案多收集整理自网络,不保证100%准确,还望斟酌采纳. 1.面向对象的思想主要包括什么? 答:任何事物都可以理解为对象,其主要特征: 继承.封装.多态.特点:代码好维护,安 ...

  7. Java虚拟机 JVM

    finalize();(不建议使用,代价高,不确定性大) 如果你在一个类中覆写了finalize()方法, 那么你可以在第一次被GC的时候,挽救一个你想挽救的对象,让其不被回收,但只能挽救一次. GC ...

  8. 服务治理要先于SOA

      讲在前面的话: 若企业缺乏对服务变更的控制和规则,那么一个服务在经过几个项目之后,就很有可能被随意更改成多个版本,将来变成什么样更是无法预测.久而久之,降低了服务重用的可能性,提高了服务利用的成本 ...

  9. Git(1)

    安装Git 完毕 (在开始菜单打开的话,打开的不是你想要的路径,切换路径很麻烦) 1.D盘新建 GitTest 文件夹 2.打开GitTest , 在空白的地方右键, 3.单击 Git Bash He ...

  10. phpexcel读取输出操作

    //读取 <?php header("Content-Type:text/html;charset=utf-8"); include 'Classes/PHPExcel.ph ...