If-Koubou

Wysyłanie automatycznych powiadomień e-mail o zadaniach w programie SQL Server z SMTP

Wysyłanie automatycznych powiadomień e-mail o zadaniach w programie SQL Server z SMTP (Jak)

Gdy masz automatyczne zadania tworzenia kopii zapasowych uruchomione na serwerze bazy danych, czasami zapominasz, że działają. Następnie zapomniałeś sprawdzić, czy działają poprawnie i nie zdajesz sobie sprawy, dopóki baza danych nie ulegnie awarii i nie możesz go przywrócić, ponieważ nie masz aktualnej kopii zapasowej.

Właśnie tam przychodzą powiadomienia e-mail, więc możesz zobaczyć status pracy każdego ranka, kiedy sączysz kawę i udajesz, że pracujesz.

SQL Server zapewnia wbudowaną metodę wysyłania wiadomości e-mail, ale niestety wymaga zainstalowania programu Outlook i profilu na serwerze, co niekoniecznie jest idealnym sposobem wysłania wiadomości e-mail. Na szczęście istnieje inna metoda, która polega na zainstalowaniu na serwerze procedury składowanej, która umożliwi wysyłanie wiadomości e-mail przez SMTP.

Pobierz tutaj sp_SQLNotify Stored Procedure.

Będziesz chciał edytować jedną linię w procedurze przechowywanej, aby umieścić adres IP serwera SMTP:

EXEC @hr = sp_OASetProperty @iMsg, 'Configuration.fields ("http://schemas.microsoft.com/cdo/configuration/smtpserver") .Value', '10 .1.1.10 '

Zainstaluj procedurę przechowywaną w głównej bazie danych, aby można ją było łatwo używać tam, gdzie było to potrzebne.

Otwórz listę SQL Server Agent \ Jobs i wybierz właściwości zadania, dla którego próbujesz utworzyć powiadomienie:

Kliknij kartę Kroki i powinieneś zobaczyć ekran wyglądający tak:

Kliknij przycisk Nowy, aby utworzyć nowy krok zadania. Ten krok zostanie wykorzystany do wysłania powiadomienia e-mail o sukcesie.

Step Name: Email Notification Success

Wprowadź ten SQL do okna poleceń, jak pokazano poniżej. Będziesz chciał dostosować adresy e-mail i temat wiadomości do swojego środowiska:

exec master.dbo.sp_SQLNotify '[email protected]', '[email protected]', 'Backup Job Success', 'Praca kopii zapasowej została pomyślnie zakończona'

Kliknij przycisk OK, a następnie ponownie kliknij przycisk Nowy, aby utworzyć kolejny krok. To będzie powiadomienie o niepowodzeniu.

Step Name: Awaria powiadomienia e-mail

SQL:

exec master.dbo.sp_SQLNotify '[email protected]', '[email protected]', 'Awaria zadania kopii zapasowej,' Zadanie kopii zapasowej nie powiodło się '

Teraz chodzi o to, aby elementy były zgodne z określonym przepływem pracy. Najpierw kliknij Edytuj w kroku 1 i ustaw właściwości, jak pokazano poniżej:

Mówimy, że po sukcesie przejdź do etapu sukcesu, aw przypadku niepowodzenia przejdź do etapu niepowodzenia. Dość proste rzeczy.

Teraz edytuj drugi krok, jeden uznany "Powiadomienie o powodzeniu pocztą e-mail" i ustaw właściwości, jak widać tutaj:

Mówimy, że jeśli zadanie powiadamiania się powiedzie, po prostu zakończ pracę bez wykonywania kroku 3. Jeśli tego nie określimy, otrzymamy dwa e-maile, jeden z sukcesem, a drugi z błędem.

Teraz zmodyfikuj trzeci krok, jeden uznany komunikat "Powiadomienie o niepowodzeniu poczty e-mail" i ustaw właściwości, tak jak tutaj:

Teraz twoje kroki powinny wyglądać tak:

Powinieneś teraz otrzymywać powiadomienia e-mail w skrzynce odbiorczej o sukcesie lub porażce.

Uwaga: Znaleziono procedura składowana użyta w tym artykule, chociaż może nie być to oryginalne źródło.

Pobierz tutaj sp_SQLNotify Stored Procedure.