SQL Server代理(4/12):配置數據庫郵件


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代理的故障排除。

原文鏈接:http://www.sqlservercentral.com/articles/Stairway+Series/72455/


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM