天天看點

SQL Server代理(2/12):作業步驟和子系統

SQL Server代理是所有實時資料庫的核心。代理有很多不明顯的用法,是以系統的知識,對于開發人員還是DBA都是有用的。這系列文章會通俗介紹它的很多用法。

SQL Server代理作業有一系列的一個或多個作業步驟組成。一個作業步驟會配置設定給特定的作業子系統,用來辨別将要進行的作業步驟工作種類。每個作業步驟在各自安全上下文運作,盡管每個作業有可以決定誰可以修改作業的擁有者。這篇文章會聚焦組成SQL Server代理作業的作業步驟和子系統。

作業的快速回顧

認為SQL Server代理作業的最好方式是關聯一系列需要進行指定任務的元件的容器。作業的主要元件是作業步驟,計劃,警報和通知。

當作業被建立時,擁有者會配置設定給作業。如第一篇提到的,預設的擁有者會是建立作業的使用者(不管使用T-SQL,通過sp_add_job系統存儲過程或使用SSMS)。SQL Server代理的大部分功能假設你是sysadmin伺服器角色成員。如果是的話,一旦作業建立後,那麼你或任何其他sysadmin伺服器角色成員可以修改作業。如果你想非sysadmin伺服器角色成員可以修改作業,那麼你應該修改作業擁有者為登入的使用者。注意sysadmin成員可以修改任何作業,不管作業擁有者是誰。

作業步驟

如第一篇提到的,SQL Server代理裡的作業至少要有一個作業步驟組成。當大多數人想SQL Server代理進行一些工作時,他們真正的意思是作業步驟。作業步驟是你定義的想要進行的行動類型,包括一下能運作的作業子系統:

  • ActiveX
  • 作業系統(CMD的運作)
  • PowerShell
  • 各種複制任務
  • SQL Server分析服務(SSAS)指令(例如XML/A)
  • SQL Server分析服務(SSAS)查詢(MDX)
  • SQL Server內建服務(SSIS)包(SQL Server 2000li de DTS包)
  • T-SQL腳本

我們來建立一個作業,至少需要一個作業步驟,備份Mater資料庫。建立一個新的作業,如插圖1所示,我命名它為"備份Master資料庫"。

SQL Server代理(2/12):作業步驟和子系統

插圖1——建立新的作業

現在點選【步驟】标簽來檢視作業步驟,點選【建立】彈出【建立作業步驟】對話框(插圖2)。

在我們進行備份前,我在這個作業步驟裡進行master資料庫的完整性檢查。我可以在一個步驟裡完成所有操作,但這裡我想向你展示下步驟間的作業流。我取我的作業名稱為“檢查Mater資料庫的完整性”,類型設定為T-SQL。資料庫上下文是mater,我在文本框裡輸入了一個簡單的指令:

1 DBCC CHECKDB      
SQL Server代理(2/12):作業步驟和子系統

插圖2——建立新的作業步驟

對這個對話框做一些簡單解釋。下拉框類型是用來選擇SQL Server代理子系統。可選的子系統在下面會解釋。對于T-SQL作業步驟沒有安全代理賬号,是以作業步驟會在作業擁有者的上下文裡運作。安全代理賬号可以讓作業步驟以不同使用者安全上下文運作,通常給作業使用而不是sysadmin組成員。

你選擇的作業子系統會改變對話框的剩餘内容。對于T-SQL的作業步驟,一個簡單的文本框會給你輸入你的T-SQL,如我這裡所做的。每個作業步驟會有不同相關的子系統。

接下來,點選作業步驟裡的【進階】。你會看到如插圖3所示的界面。【成功要執行的步驟】定義一旦作業步驟成功執行将發什麼的事。預設選項是【轉到下一步】,意味着如果作業裡有多個作業步驟,這步完成後,執行下一步。如果點選下拉框,你會看到其他選項——包括現存的作業(成功或失敗的提醒),或跳轉下另一步。注意這個最後選項,跳到另一個步驟,不會顯示,知道作業裡你有第二個步驟。

SQL Server代理(2/12):作業步驟和子系統

插圖3——建立作業步驟進階選項

如果作業因某些原因失敗,你可以選擇作業步驟的【重試次數】。你也可以指定每個嘗試成功完成作業步驟間的延遲(分鐘為機關)。下面是失敗的操作(例如作業不能完成或在錯誤代碼裡結束)。這個選項和成功的操作一樣,有不同的預設值(如你所預料)。

因為這是個T-SQL的作業步驟類型,你可以有來自T-SQL指令記錄的指令輸出(就和sql指令裡 -o參數)。你也可以将結果寫入表(MSDB裡的sysjobsteps表)。

點選【确定】,點選【建立】增加第2個作業到作業。假設步驟1沒有生成錯誤,這個下一步作業步驟備份master資料庫。這裡我系統裡的指令:

1 BACKUP DATABASE [master] TO  DISK =
2 N'C:\Program Files\Microsoft SQL Server\MSSQL10_50.MSSQLSERVER\MSSQL\Backup\master.bak'
3 WITH INIT      
SQL Server代理(2/12):作業步驟和子系統

插圖4——備份master資料庫的第2個步驟

因為這個事作業的結束,點選【進階】,選擇【成功要執行的操作】為:退出報告成功的作業。好了——你可以點選【确定】了,完成後的作業步驟如插圖5所示。

SQL Server代理(2/12):作業步驟和子系統

 插圖5——完成的作業。

選擇點選【确定】完成作業定義,并運作作業。當你點選運作作業時,注意因為有多個步驟,你會被問從哪個步驟開始你的祖業。從第一個步驟來運作作業(如插圖6所示),圍觀下作業流,第1步成功執行後然後移到的第2步——最後一步作業。

SQL Server代理(2/12):作業步驟和子系統

插圖6——作業開始步驟選擇(選擇第1步)

一談成功完成,作業标記為成功并退出(如插圖7所示)

SQL Server代理(2/12):作業步驟和子系統

插圖7——作業成功執行

作業子系統

你會用到7個主要作業子系統。這個數字不包含複制子系統,因為它們情況特殊,典型的這些作業步驟和作業由複制元件建立而不是DBA。對于下片文章,我們會延遲3個分析服務子系統的讨論,因為它們有幾個獨特的考慮。

T-SQL子系統非常直接,是你最常建立的作業步驟。它允許你對于本地SQL Server執行個體運作T-SQL,當然SQL Server代理也是本地和它關聯的。注意不像分析服務子系統,你隻能連接配接到本地SQL Server執行個體。對于T-SQL,沒有代理能力,是以對于T-SQL的作業步驟隻在作業擁有者的安全上下文裡運作。

ActiveX腳本

ActiveX子系統允許你運作VBScript,Jscript,或其他自定義的腳本(理論上)。腳本預設在SQL Server代理服務賬号的安全上下文裡運作。如果你擅長VBSccript,這是個友善的子系統,但這個子系統已經從SQL Server 2008剝離,你應該使用PowerShell來替代。

作業系統(cmd指令執行)

CmdExec子系統允許你運作作業系統指令(如同你打開指令提示行)。指令會在SQL Server代理服務賬号的安全上下文裡運作。這裡要記住的關鍵是沒有使用者可以點選或接受任何提示符,是以請確定你的腳本運作沒有使用者幹預。

PowerShell子系統允許你Windows PowerShell 1.0或2.0相容的腳本。如其他腳本子系統,甲苯預設在SQL Server代理服務賬号的安全上下文裡運作。PowerShell非常強大,你應該認真學習并掌握它。PowerShell允許連接配接到遠端系統,是以這是繞開T-SQL子系統的限制,可以連接配接到遠端SQL Server執行個體。

下篇預告

如你所見,SQL Server代理作業步驟是作業内容的核心問題。有很多不同的子系統,每個提供你不同的能力。在這個系列的下一步,我會在作業步驟上檢查加強安全的代理能力,還有SQL代理子系統剩下部分——分析服務。

原文連結:http://www.sqlservercentral.com/articles/SQL+Agent/Job+Steps+and+Subsystems/72268/

注:此文章為

WoodyTu

學習MS SQL技術,收集整理相關文檔撰寫,歡迎轉載,請在文章頁面明顯位置給出此文連結!

若您覺得這篇文章還不錯請點選下右下角的推薦,有了您的支援才能激發作者更大的寫作熱情,非常感謝!

繼續閱讀