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.