SQL Server代理是所有實時資料庫的核心。代理有很多不明顯的用法,因此系統的知識,對於開發人員還是DBA都是有用的。這系列文章會通俗介紹它的很多用法。在以前的文章里我們看到,SQL Server代理由一系列的作業步驟組成,每個作業步驟是要進行的不同工作類型。SQL Server代理也提供創建警...
SQL Server代理是所有實時資料庫的核心。代理有很多不明顯的用法,因此系統的知識,對於開發人員還是DBA都是有用的。這系列文章會通俗介紹它的很多用法。
在以前的文章里我們看到,SQL Server代理由一系列的作業步驟組成,每個作業步驟是要進行的不同工作類型。SQL Server代理也提供創建警報的功能,它可以發消息給指定的操作員作為提醒。這些提醒很可能通過資料庫郵件發送,SQL Server和SQL Server代理內建的功能來發送和接收郵件。在這篇文章里,你會學到如何配置資料庫郵件來進行發送和接收操作,還有資料庫郵件的基本故障排除步驟。
資料庫郵件的簡單介紹
在SQL Server 2000或以前的版本里,郵件系統就可用,被稱為SQLMail。SQLMail(最終會被移除掉,但在SQL Server 2008 R2里還是存在的)使用MAPI(郵件應用程式介面(Messaging Application Programming Interface))的API來代表SQL Server實例來發送和接收郵件。在這個郵件系統里有很多問題和限制,包括:
- 不支持故障群集
- 依賴別的程式(例如微軟的Outlook)提供的MAPI
- 依賴SQL Server服務有MAPI配置
- 郵件發送後,如果發送失敗不能重發
- 沒有支持SQL Server可用MAPI版本
由於這些限制,新的郵件系統為SQL Server 2005設計了。那個新的郵件系統,資料庫郵件,去掉了這些限制,大大提高了SQL Server郵件的可靠性。在故障群集配置了,資料庫郵件完全支持。資料庫郵件使用SMTP與郵件伺服器交互,取消了額外郵件API的支持。資料庫郵件內部使用服務代理(service broker)對所有郵件進行隊列管理,使郵件系統更加健壯。
資料庫郵件可獨立運行,讓T-SQL的調用到msdb資料庫,然後直接與SMTP郵件伺服器交互,使用在msdb資料庫存儲的安全信息。
資料庫郵件配置
資料庫郵件預設是沒有配置的(和SQL Server代理類似)。在可以配置和使用它的功能之前,首先你必須啟用資料庫郵件。你有3個不同的方式啟用資料庫郵件:
資料庫郵件配置嚮導
- 圖形化嚮導,從SSMS啟動,會啟用資料庫郵件並配置服務的基本能力。這是我們這篇文章里要介紹的。
- sp_configure
- 和大多數伺服器配置選項一樣,你可以使用sp_configure系統存儲過程來啟用或停用資料庫郵件。你指定“Database Mail XPs”選項(在sp_configure里的高級選項)為1來啟用資料庫郵件,0來停止資料庫郵件。
- 基於策略管理
- 你可以指定”@DatabaseMailEnabled“並設置值為True,然後添加這方面的配置到策略,並應用策略到特定的SQL Server。如果你想管理多個伺服器的話,這是從擴展性來說最好的選項(基於策略的管理自SQL Server 2008和以後版本都可用)。
使用資料庫郵件配置嚮導來啟用資料庫郵件
在開始資料庫郵件前,使用SSMS連接到你的SQL Server本地實例,然後展開管理文件夾,右擊【資料庫郵件】。選擇【配置資料庫郵件】,資料庫郵件配置嚮導會啟動,顯示嚮導的介紹,點擊【下一步】,你會看到嚮導里的可用選項,如插圖1所示。
插圖1——資料庫郵件配置嚮導——選擇配置任務
因為這是你第一次運行資料庫郵件配置嚮導,你會需要保持這個選擇來配置資料庫郵件。點擊【下一步】,你會看到啟用資料庫郵件的對話框,如插圖2所示。
插圖2——是否啟用資料庫郵件?
還沒提到安全,你會需要是sysadmin伺服器組成員才可以完成這個任務。選擇【是】,合適的sp_configure命令會代你運行。你會看到【新建配置文件】對話框。輸入配置文件名和描述,然後點擊【增加】按鈕進入SMTP賬號列表,如插圖3所示。
插圖3——新建資料庫郵件賬號
賬號名稱是寫給你看的,因此要使用一些有意義的名稱。郵件地址會顯示來自SQL Server的名稱。取個允許你專門發送SQL Server郵箱的名字更好。當然,你也可以使用日常的郵箱。
伺服器名稱是SMTP郵件服務地址(博主註:首先要保證你的郵件已經啟用SMTP功能)。使用【基本身份認證】(用戶名要參考具體郵件伺服器的要求)。
完成這些配置後,點擊【確定】來結束郵件賬號配置。你可以按照這個方法創建多個郵件賬號,如果第一個賬號發送失敗,第二個賬號會自動啟用。對於一個郵件配置可以擁有多個郵件賬號。現在,我們切換回單個郵件賬號界面,點擊【確定】。你要設置你創建的賬號為【公共配置文件】(例如讓所有認證的資料庫郵件用戶使用這個郵件配置來發送郵件),你可以保持它為私有(你會關聯一個資料庫用戶來使用這個配置文件)。因為這是第一個配置文件,我們設置為公共配置(如插圖4所示)。
插圖4——設置資料庫配置為公共。
點擊【下一步】,你完成了初始資料庫配置的配置。可是,現在出現在你面前的是【配置系統參數】對話框,允許你修改資料庫郵件系統級的設置(如插圖5所示)。
插圖5:資料庫郵件系統參數
在這裡你可以指定下列選項:
- 賬戶重試次數:在給出的郵件配置里的賬號列表,切換到第二個賬號前,使用第一個郵件賬號嘗試失敗次數。
- 賬戶重試延遲時間:在每次嘗試連接並使用SMTP郵件賬號之間的等待時間(秒為單位)
- 最大文件大小(位元組):使用資料庫郵件允許的最大附件大小。你可以把來自SQL Server的查詢結果通過郵件附件進行發送,因此你可能會希望它儘可能大。但郵件伺服器上的附件大小設置會覆蓋這裡的配置。
- 禁止的附件文件擴展名:資料庫郵件不能發送的擴展名列表。這主要用來保證你的郵件系統不會通過可執行的或腳本來傳播病毒。當然,你可以按需要添加自己或刪除自己SQL Server需要的文件擴展名。
- 資料庫郵件可執行文件的最短生存期(秒):資料庫郵件進程啟動時有個額外開銷(因為它在外部運行,並不是資料庫引擎或SQL Server代理的一部分)。這個設置決定SQL Server代理使用資料庫郵件發送郵件後的持續運行時間。如果你經常使用資料庫郵件,可以保持這個進程運行更長,可以讓資料庫郵件的啟動更短,因為SQL Server郵件需要重新查詢SQL Server並緩存內部信息(例如賬號配置),發送郵件時,它們是必須的。
- 日誌記錄級別:有三個記錄級別:普通、擴展、詳細。如果你在故障排除或想查看更多的資料庫郵件信息,可以設置記錄級別為詳細。你可以在SSMS里檢查資料庫郵件記錄級別(或者在msdb資料庫里的sysmail_event_log視圖裡)。
現在的話,接受預設,點擊【下一步】完成【資料庫郵件配置嚮導】(如插圖6所示)
插圖6——完成資料庫郵件嚮導
如果一切順利的話,你會看到如插圖7的結果,顯示已經創建的配置和賬號,賬號與配置文件關聯,配置文件是公共的。如果這裡發生了錯誤,或者你需要修改郵件設置的配置,重新運行資料庫郵件配置嚮導,在第一個對話框上(如插圖1所示),選擇第二個選項【管理資料庫郵件賬號和配置文件】,你可以修改所有輸入的信息,創建新的郵件配置或郵件賬號。
插圖7——嚮導成功執行所有的命令
下一步
一旦嚮導完成,有2個步驟可以確認你的資料庫郵件已經成功配置,首先,你會想發送一個測試郵件。然後,你應該檢查下日誌來看看資料庫郵件記錄測試郵件發送的基本信息。
發送測試郵件
發送測試郵件,在SSMS里右擊【資料庫郵件】節點,在菜單選項里選擇【發送測試郵件】,你會看到如插圖8的對話框。
插圖8:發送測試郵件
如果郵件發送成功,點擊【發送測試電子郵件】按鈕後,出現的【資料庫郵件測試電子郵件】對話框上的【確定】按鈕。如果你不能收到郵件,點擊【疑難解答】按鈕,會出現資料庫郵件故障排除的幫助鏈接。對於SQL Sever 2008 R2有很多可用選項,如插圖9所示。選擇合適的癥狀,你可用按照嚮導提示來進行故障排除。
插圖9——資料庫郵件故障排除
如果一切順利,你會看到如插圖11所示的郵件信息。一旦配置成功,你可用使用郵件操作員,如第3篇文章所介紹的在SQL Server里發送郵件警報。
插圖10——來自SQL Server資料庫郵件的測試郵件
檢查資料庫郵件日誌
檢查資料庫郵件日誌,你要麼直接查看msdb..sysmail_event_log視圖,或者在SSMS里右擊資料庫郵件,選擇【查看資料庫郵件日誌】。你會看到標準日誌文件查看器,只過濾顯示了資料庫郵件日誌。如果你成功發送了郵件,你會看到資料庫郵件進程啟動。如果你有錯誤,你會看到對應的錯誤信息,點擊信息會日誌界面底部顯示關於錯誤的具體信息。
插圖11——日誌文件查看器查看資料庫郵件日誌
如果你還有困難,你可以在資料庫郵件里調整日誌級別為詳細。有2個操作方法,一個是SSMS,右擊資料庫郵件,再次啟動配置嚮導,選擇【查看或修改系統參數】,你會看到會插圖5一樣的界面,選擇【日誌記錄級別】為【詳細】,點擊【下一步】來完成嚮導,再次嘗試發送郵件。你會在資料庫郵件日誌視圖裡看到詳細日誌信息。另一個就是通過msdb資料庫里系統存儲過程sysmail_configure_sp。
1 Select name from sys.all_objects
下篇預告
如你所見,資料庫郵件非常簡單,一旦你有一個相容SMTP的郵件伺服器,你就可以和你的SQL Server進行交互,非常靈活。資料庫郵件有安全限制,允許你配置誰可以發送郵件(通過msdb里的DatabaseMailUserRole),也可以使用郵件配置來限制特定用戶。你可以使用SQL Server代理的資料庫郵件來發送警報來自動話SQL Server的管理。
現在你有作業、警報、操作員的基礎,郵件也可以發送了,下篇我們來看看下SQL Server代理的錯誤日誌,還有它如何幫助我們進行SQL Server代理的故障排除。