SQL Serverメンテナンス計画のタスクと完了
-
28-09-2019 - |
質問
私はこのように見えるメンテナンス計画を持っています...
Client 1 Import Data (Success) -> Process Data (Success) -> Post Process (Completion) -> Next Client
Client 2 Import Data (Success) -> Process Data (Success) -> Post Process (Completion) -> Next Client
Client N ...
データとプロセスデータのインポートはジョブを呼び出し、ポストプロセスは実行されたSQLタスクです。データのインポートまたはプロセスデータが失敗した場合、次のクライアントインポートデータに移動します...
インポートデータとプロセスデータの両方は、組み込みのSQLロギングプロバイダーを使用しているSSISパッケージを含むジョブです。
構成に対する私の期待は、次のとおりです。
- クライアント1インポートデータの実行:失敗 - >クライアント2インポートデータ|成功プロセスデータ
- プロセスデータの実行:失敗 - >クライアント2インポートデータ|成功ポストプロセス
- ポストプロセスの実行:完了 - >成功または失敗 - >次のクライアントインポートデータ
これは私のログに表示されているものではありません...いくつかのクライアントインポートデータSSISログエントリ、次にいくつかのポストプロセスログエントリ、次にクライアントインポートデータに戻ります。 arg !!
私は何が間違っているのですか?クライアント1のインポートデータの「成功」の部分がそれが始まるまで始まるとは思いませんでした...まあ...別名が終了しました!ログはそうでなければ示されているようですが...
これらのタスクは、連続して並行している必要があります。これは可能ですか?
ありがとう!
解決 2
私にとって、回避策は、組み込みの「SQL Serverエージェントのジョブタスク」を組み込んでいないことになり、代わりに「T-SQLステートメントタスクを実行」を使用し、完了までブロックされるストアドプロシージャを呼び出すことになりました...
甘い成功:-)
CREATE PROCEDURE [dbo].[SQLJob_RunBlocking]
(
@JobName SYSNAME
)
AS
BEGIN
-- running a job returns before the job is complete
-- this procedure will run the job and loop until its status is complete
SET NOCOUNT ON;
DECLARE @JobStatus INT;
-- start job
EXECUTE msdb.dbo.sp_start_job @job_name = @JobName;
-- loop until status is complete
WHILE ISNULL(@JobStatus, 0) != 4 BEGIN
WAITFOR DELAY '00:00:01';
EXECUTE dbo.SQLJob_GetStatus @job_name = @JobName, @select_data = 0, @execution_status = @JobStatus OUTPUT;
END
END
と...
CREATE PROCEDURE [dbo].[SQLJob_GetStatus]
(
@job_name SYSNAME
,@select_data INT = 0
,@execution_status INT = NULL OUTPUT
)
AS
BEGIN
SET NOCOUNT ON;
-- http://www.siccolo.com/Articles/SQLScripts/how-to-create-sql-to-sql-job-execution-status.html
/*
Is the execution status for the jobs.
Value Description
0 Returns only those jobs that are not idle or suspended.
1 Executing.
2 Waiting for thread.
3 Between retries.
4 Idle.
5 Suspended.
7 Performing completion actions
*/
DECLARE @job_id UNIQUEIDENTIFIER
,@is_sysadmin INT
,@job_owner SYSNAME;
SELECT @job_id = job_id FROM msdb.dbo.sysjobs_view where name = @job_name;
SELECT @is_sysadmin = ISNULL(IS_SRVROLEMEMBER(N'sysadmin'), 0);
SELECT @job_owner = SUSER_SNAME();
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
);
IF ((@@microsoftversion / 0x01000000) >= 8) -- SQL Server 8.0 or greater
INSERT INTO #xp_results
EXECUTE master.dbo.xp_sqlagent_enum_jobs @is_sysadmin, @job_owner, @job_id;
ELSE
INSERT INTO #xp_results
EXECUTE master.dbo.xp_sqlagent_enum_jobs @is_sysadmin, @job_owner;
--declare @execution_status int
SET @execution_status = (SELECT job_state FROM #xp_results);
DROP TABLE #xp_results;
IF @select_data = 1
SELECT @job_name AS 'job_name', @execution_status AS 'execution_status';
END
他のヒント
グループで実行する必要があるタスクの周りにシーケンスコンテナを配置してみてください。
所属していません StackOverflow