SQL Server代理(4/12):配置資料庫郵件

来源:http://www.cnblogs.com/woodytu/archive/2016/01/27/5154526.html
-Advertisement-
Play Games

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


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 線程通信、ActivityThread及Thread類是理解Android線程管理的關鍵。 線程,作為CPU調度資源的基本單位,在Android等針對嵌入式設備的操作系統中,有著非常重要和基礎的作用。本小節主要從以下三個方面進行分析: 《Android線程管理(一)——線程通信》 《Android線...
  • 代碼:ViewController.h#import //簡訊分享#import #import @interface ViewController : [email protected]#import "ViewController.h"@interface ...
  • 在移動互聯網時代,幾乎所有應用都需要用到網路下載,比如圖片的載入,音樂的下載,安裝包的下載,等等,下麵我們來看看如何進行下載一、文件的下載我們用get來請求數據,並對請求的二進位數據進行解析存入文件,首先我們先引入一個第三方進度條 ,並且進行初始化- (void)viewDidLoad { [...
  • iOS中plist的創建,數據寫入與讀取功能創建一個test.plist文件-(void)triggerStorage{NSArray *paths=NSSearchPathForDirectoriesInDomains(NSDocumentDirectory,NSUserDomainMask,YE...
  • 1:AFNetworking狀態欄網路請求效果直接在AppDelegate裡面didFinishLaunchingWithOptions進行設置[[AFNetworkActivityIndicatorManager sharedManager] setEnabled:YES];這樣在有用AF請求的網...
  • Mac Android ADT Bundle+真機調試 ——配置
  • 什麼是單例模式 1.單例模式是一個類在系統中只有一個實例對象。通過全局的一個入口點對這個實例對象進行訪問。在 iOS 開發中,單例模式是非常有用的一種設計模式。如 下圖,是一個簡單單例模式的 UML 類圖。 2.iOS SDK 中也有許多類使用了單例模式,例如,UIApplication:當程式啟動...
  • 利用分類,NSString,增加一個方法。#import #import @interface NSString (Height)+ (CGSize)getRect:(NSString *)textStr andWidth:(CGSize)size andFont:(UIFont *)font;@e...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...