কাজের সূচনা সময়ের সাথে এসকিউএল সার্ভারে চলমান কাজগুলি দেখার স্ক্রিপ্ট


16

জব স্টার্ট টাইমের সাথে এসকিউএল সার্ভারে চলমান কাজগুলি দেখতে স্ক্রিপ্ট কীভাবে লিখবেন?

SELECT sj.name, 
 sja.run_requested_date, 
 CONVERT(VARCHAR(12), sja.stop_execution_date-sja.start_execution_date, 114) Duration
FROM msdb.dbo.sysjobactivity sja
INNER JOIN msdb.dbo.sysjobs sj
ON sja.job_id = sj.job_id
WHERE sja.run_requested_date IS NOT NULL
ORDER BY sja.run_requested_date desc;

নিশ্চিত না যে আমি প্রশ্নটি বুঝতে পেরেছি। আপনি কি কেবল বর্তমানে চলমান কাজগুলি দেখতে চান?
অ্যারন বারট্র্যান্ড

উত্তর:


49

এখানে বর্তমানে চলমান কাজের তালিকার জন্য আমি কিছুক্ষণ আগে একটি ক্যোয়ারী পোস্ট করেছি

SELECT
    ja.job_id,
    j.name AS job_name,
    ja.start_execution_date,      
    ISNULL(last_executed_step_id,0)+1 AS current_executed_step_id,
    Js.step_name
FROM msdb.dbo.sysjobactivity ja 
LEFT JOIN msdb.dbo.sysjobhistory jh 
    ON ja.job_history_id = jh.instance_id
JOIN msdb.dbo.sysjobs j 
ON ja.job_id = j.job_id
JOIN msdb.dbo.sysjobsteps js
    ON ja.job_id = js.job_id
    AND ISNULL(ja.last_executed_step_id,0)+1 = js.step_id
WHERE ja.session_id = (SELECT TOP 1 session_id FROM msdb.dbo.syssessions ORDER BY agent_start_date DESC)
AND start_execution_date is not null
AND stop_execution_date is null;

এটিতে কাজের নাম, কাজের আইডি, শুরুর সময় এবং এটি কোন ধাপে চলছে has আপনি যদি উপরের লিঙ্কটি অনুসরণ করেন তবে আমি কীভাবে এটি নিয়ে এসেছি এবং কী কী উপলভ্য তা সম্পর্কে আপনি আরও কিছু বিশদ পেতে পারেন।


6
দুর্ভাগ্যক্রমে, এই স্ক্রিপ্টটি ধরে নিয়েছে যে শেষের ধাপের পরে বর্তমানে চলমান ধাপটি এক। এটি সবসময় হয় না।
টড ম্যাকডার্মিড

3

আমার এক সার্ভারে এমএসডিবি সারণি (উপরে তালিকাভুক্ত ওরফে কোড) জিজ্ঞাসা করে আমি যে কোনও একটি কাজ দৌড়ে এসেছি বলে ইস্যুতে ছড়িয়ে পড়েছি, তবে তা হয়নি। একটি সিস্টেম সঞ্চিত প্রক্রিয়া রয়েছে যা কার্যকর করে স্ট্যাটাসটি ফিরিয়ে দেয় তবে ত্রুটি ব্যতীত কেউ একটি sertোকানো এক্সিকিউট স্টেটমেন্ট করতে পারে না। এর অভ্যন্তরে অন্য একটি সিস্টেম সঞ্চিত পদ্ধতি যা একটি সন্নিবেশ নির্বাহী বিবৃতি দিয়ে ব্যবহার করা যেতে পারে।

INSERT INTO #Job
EXEC master.dbo.xp_sqlagent_enum_jobs 1,dbo

এটিতে লোড করার জন্য টেবিল:

CREATE TABLE #Job 
           (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) 

1

এটি আপনাকে কাজের নাম এবং রানের তারিখ এবং সময় দেবে, আপনি কেবল নাম এবং সময়টি দেখতে চাইলে আপনি তারিখটি সরাতে পারেন।

SELECT
j.name AS 'JobName',
run_date,
run_time,
msdb.dbo.agent_datetime(run_date, run_time) AS 'RunDateTime'
FROM msdb.dbo.sysjobs j 
JOIN msdb.dbo.sysjobhistory h ON j.job_id = h.job_id 
WHERE j.enabled = 1  --Only Enabled Jobs
ORDER BY JobName, RunDateTime desc

এমএসডিবি.ডো.এজেন্ট_ডেটটাইমের জন্য +1 (রান_ডেট, রান_টাইম)
অ্যালোকাইট

1

এই স্ক্রিপ্টটি বর্তমানে চলমান কাজগুলি এবং সেই সাথে বর্তমানে কার্যকর করা পদক্ষেপটি প্রদর্শন করবে:

-- From http://www.databasejournal.com/features/mssql/article.php/10894_3491201_2/Detecting-The-State-of-a-SQL-Server-Agent-Job.htm
    CREATE TABLE #ENUM_JOB 
    ( 
        Job_ID UNIQUEIDENTIFIER, 
        Last_Run_Date INT, 
        Last_Run_Time INT, 
        Next_Run_Date INT, 
        Next_Run_Time INT, 
        Next_Run_Schedule_ID INT, 
        Requested_To_Run INT, 
        Request_Source INT, 
        Request_Source_ID VARCHAR(100), 
        Running INT, 
        Current_Step INT, 
        Current_Retry_Attempt INT, 
        State INT 
    )
    INSERT INTO #ENUM_JOB 
         EXEC master.dbo.xp_sqlagent_enum_jobs 1,garbage
    SELECT E.*, SJ.name AS job_name, SJS.step_name
        FROM #ENUM_JOB AS E
        JOIN msdb.dbo.sysjobs AS SJ
            ON SJ.job_id = E.Job_ID
        JOIN msdb.dbo.sysjobsteps AS SJS
            ON SJS.job_id = SJ.job_id
            AND SJS.step_id = E.Current_Step
    DROP TABLE #ENUM_JOB

0

নিম্নলিখিত লিপিটি ফিরে আসে:

  • কাজের নাম
  • জব আইডি
  • কাজ সময় অনুরোধ
  • চাকরি কার্যকর করার সময়
SELECT sj.name
   , sja.*
FROM msdb.dbo.sysjobactivity AS sja
INNER JOIN msdb.dbo.sysjobs AS sj ON sja.job_id = sj.job_id
WHERE sja.start_execution_date IS NOT NULL
   AND sja.stop_execution_date IS NULL

3
আমার জন্য এই ক্যোয়ারী অক্ষম চাকরিগুলি ফিরিয়েছে যা আসলে চলছে না
নিক.এমসিডার্মাইড

1
কেবল কেনেথের উত্তর আরও ভাল কারণ এটি কেবলমাত্র চলমান চাকরিগুলি ফেরত দেয়।
নিরাজ

0

এটি সম্ভবত বাড়ির চারপাশে কিছুটা তবে কৌশলটি করে

;WITH cJobDetail AS (
    SELECT 
        ja.job_id
        ,j.name
        ,ja.start_execution_date
        ,ja.last_executed_step_id
        --,j.start_step_id
        ,CASE 
            WHEN j.start_step_id = COALESCE(ja.last_executed_step_id,j.start_step_id) THEN j.start_step_id
            ELSE NULL
            END AS ExecutingStepId
        ,ja.job_history_id
        ,DATEDIFF(HOUR, ja.start_execution_date, COALESCE(ja.stop_execution_date,SYSDATETIME())) AS JobHourRunning
        ,DATEDIFF(SECOND, ja.start_execution_date, COALESCE(ja.stop_execution_date,SYSDATETIME())) / 60 % 60 AS JobMinuteRunning
        ,DATEDIFF(SECOND, ja.start_execution_date, COALESCE(ja.stop_execution_date,SYSDATETIME())) % 60 AS JobSecondRunning 
    FROM dbo.sysjobactivity ja
    INNER JOIN dbo.sysjobs j
        ON ja.job_id = j.job_id
    WHERE ja.start_execution_date IS NOT NULL
    AND ja.stop_execution_date IS NULL
)
,MaxJobHistoryStepStatus AS (
    SELECT jh.job_id, jh.step_id, MAX(jh.instance_id) AS MaxInstanceId
    FROM cJobDetail jd
    INNER JOIN dbo.sysjobhistory jh
        ON jd.job_id = jh.job_id
        AND jd.last_executed_step_id = jh.step_id
    GROUP BY jh.job_id, jh.step_id
    )

SELECT 
    jd.job_id
    ,jd.name
    ,jd.start_execution_date 
    ,COALESCE(
                CASE jh.run_status 
                        WHEN 1 THEN 
                                    CASE js.on_success_action
                                                            WHEN 3 THEN jd.last_executed_step_id + 1
                                                            WHEN 4 THEN js.on_success_step_id
                                    END
                        WHEN 0 THEN 
                                    CASE js.on_fail_action
                                                        WHEN 3 THEN jd.last_executed_step_id + 1
                                                        WHEN 4 THEN js.on_fail_step_id
                                    END
                END,jd.ExecutingStepId) AS StepId
    ,jd.JobHourRunning
    ,jd.JobMinuteRunning
    ,jd.JobSecondRunning                                
FROM cJobDetail jd
LEFT JOIN MaxJobHistoryStepStatus mhs
    ON jd.job_id = mhs.job_id
LEFT JOIN dbo.sysjobhistory jh
    ON mhs.MaxInstanceId = jh.instance_id
LEFT JOIN dbo.sysjobsteps js
    ON mhs.job_id = js.job_id
    AND mhs.step_id = js.step_id
আমাদের সাইট ব্যবহার করে, আপনি স্বীকার করেছেন যে আপনি আমাদের কুকি নীতি এবং গোপনীয়তা নীতিটি পড়েছেন এবং বুঝতে পেরেছেন ।
Licensed under cc by-sa 3.0 with attribution required.