Overview
Το DBMail είναι κάτι που χρόνια έχουμε στον SQL Server και βασικό σκοπό έχει να στέλνει notifications είτε από alerts είτε από jobs. Φυσικά μπορείς να κάνεις και άλλα πράγματα αλλά δεν είναι σε καμία περίπτωση αντικαταστάτης ενός mail server ή κάποιου SMTP provider που αρκετοί νομίζουν.
Μπορεί όπως έχω περιγράψει σε παλαιότερο άρθρο μου η ενεργοποίηση του να είναι εύκολη μέσω του wizard που υπάρχει αλλά δεν μπορώ να πω ότι η διαχείριση του έχει κάτι αντίστοιχο σε γραφικό περιβάλλον. Αντίθετα γίνεται εύκολη με μια σειρά από stored procedures , views και system tables.
Από όσο βλέπω λίγοι είναι αυτοί που γνωρίζουν την ύπαρξη αυτών και επειδή στα σεμινάρια διαχείρισης του SQL Server που κάνω, πάντα τα δείχνω και τα εξηγώ ώστε οι μαθητές μου να γνωρίζουν θέλω τουλάχιστον όσοι με διαβάζουν να γνωρίζουν την ύπαρξη τους.
Για το λόγο αυτό στην παρακάτω λίστα αναφέρω όλα όσα έχουμε διαθέσιμα στα χέρια μας για την διαχείριση του DBMail και όλα είναι στην msdb database.
Πριν όμως παραθέσω την λίστα αυτή θα πρέπει να κάνω μια επισήμανση και αυτή αφορά ότι κάθε φορά που ένα email φεύγει από τον SQL Server σε N παραλήπτες αυτό αποθηκεύεται για κάθε ένα στα system tables sysmail_mailitems, sysmail_sentitems, sysmail_event_log, sysmail_log. Αυτό σημαίνει ότι μεγαλώνει το μέγεθος της msdb και πρέπει να το διαχειριστούμε με τις αντίστοιχες stored procedures που υπάρχουν sysmail_delete_log_sp, sysmail_delete_mailitems_sp.
DBMail Administration commands
Stored Procedures |
System Tables |
System Views |
|
Δεν είναι documented αλλά είναι κατανοητά
- sysmail_mailitems
- sysmail_attachments
- sysmail_send_retries
- sysmail_log
- sysmail_query_transfer
- sysmail_attachments_transfer
- sysmail_configuration
- sysmail_server
- sysmail_servertype
- sysmail_profileaccount
- sysmail_account
- sysmail_principalprofile
- sysmail_profile
|
|
//antonch