2012-05-10 85 views
0

如何在數據流任務失敗期間終止SSIS中的excel.exe進程?從其他包中運行的Excel.exe可能有多個實例在運行,這些包完全有效,所以我不想通過所有實例循環查殺它們。SSIS - 在數據流任務失敗時激活Excel.exe

我的問題是,在數據流任務期間,由於名稱不正確或缺少列的工作表,過程有時會失敗。這使excel.exe的一個實例運行,現在這是一個孤立的任務,它耗盡了資源,因此需要將其終止。

與此同時還有其他SSIS包正在運行,它們正在訪問他們自己的excel.exe進程並且​​沒有任何問題。

那麼如何殺掉孤兒excel.exe進程而不影響其他excel.exe進程呢?

感謝

+0

你確切的問題是什麼?殺或不殺或誰殺?請更改您的問題,並更清楚您要做什麼以及您遇到什麼問題。 – JotaBe

+0

這聽起來像你有SSIS開始一個Excel進程,失敗,並且該進程保持運行? [這是](http://www.craigmurphy.com/blog/?p=82)某人的代碼,瞭解他們如何跟蹤他們的Excel實例。 –

+0

@Russell您的鏈接是在腳本任務期間,我可以使用它獲取進程ID,而不是通過連接管理器打開與excel的連接的數據流任務。不涉及任何代碼。 – user1238918

回答

0

你可以用下面的腳本

Public Sub Main() 
    Dim controller As New ServiceController 
    controller.MachineName = "." 
    controller.ServiceName = "ReportServer" 

    Dim status As String = controller.Status.ToString 

    If status.ToLower = "running" Then 
     controller.Stop() 
    End If 

    Dts.TaskResult = Dts.Results.Success 
End Sub 

上有ServiceController類Finalize方法停止Windows服務。也許它可以殺死一個進程。

+0

我不想殺掉錯誤的excel.exe。可能有5個excel.exe進程正在運行,只有一個是孤立的。這可能會殺死錯誤的人。 – user1238918

0

在這種情況下,您需要從sysprocesses獲取主機的processID並運行taskkill來擺脫進程。像這樣的事情在TSQL:

DECLARE @cmd VARCHAR(50) 
SELECT @cmd = 'taskkill /pid ' + 
    CAST(hostprocess AS VARCHAR(10)) 
FROM sys.sysprocesses 
WHERE program_name = 'Microsoft® Excel' 
AND status = 'sleeping' 

xp_CmdShell (@cmd); 

這將是更好,如果你可以立即獲得Excel進程的SPID立即當它產生了,那麼你可以存儲它並把它插入到上面的命令。請閱讀taskkill函數,因爲它有其他幾個可能有用的選項。