此腳本是羣裏面的哥們共享的,本人特整理出來分享給有需要的同學。
注意:
1.使用前修改下里面的一些參數(原作者都貼心的標註了)
2.有必要的話修改下腳本的執行策略
效果截圖:
計劃任務截圖:
腳本內容:
add-pssnapin microsoft.exchange* #加載EMS不然exchange命令無法識別
$seei = $Sear.ErrorEventId
$OutDB += "<tr style=""font-size:12px; font-family:'微軟雅黑';$trbgcolor"" align=""center"">
<td height=""30"">$mbs</td>
<td>$sdn</td>
<td bgcolor=""$bordercolor""> $SStatus </td>
<td bgcolor=""$bgindex""> $SConIndexState </td>
<td> $scql </td>
<td> $srql </td>
<td> $sac </td>
<td bgcolor=""$bordercolor""> $sem </td>
<td> $seei </td>
</tr>"
}
$Output = "<font size=""1"" face=""Arial,sans-serif"">
<h3 align=""center"">Exchange 數據庫運行狀態報表</h3>
<h5 align=""center"">生成時間 $((Get-Date).ToString())</h5>
</font>
<table width=""100%"" bordercolor=""#FFFFFF"" border=""0"" cellspacing=""2"" cellpadding=""0"">
<tr style=""background-color:#090; color:#FFF; font-size:14px; font-family:'微軟雅黑';"" align=""center"">
<td height=""30"">服務器名稱</td>
<td>數據庫名稱</td>
<td>狀態</td>
<td>內容索引狀態</td>
<td>複製隊列長度</td>
<td>重播隊列長度</td>
<td>是否爲主動庫</td>
<td>錯誤信息</td>
<td>錯誤事件ID</td>
</tr>
$OutDB
</table>
<br><br><h5 align=""center"">錯誤代碼及錯誤信息</h5><br>
<table width=""100%"" bordercolor=""#FFFFFF"" border=""0"" cellspacing=""2"" cellpadding=""0"">
<tr style=""background-color:#f90; color:#FFF; font-size:14px; font-family:'微軟雅黑';"" align=""center"">
<td>錯誤代碼</td>
<td>錯誤內容</td>
</tr>
$errmes
</table>
"
function sendmail($body)
{
$today = Get-Date
$SmtpClient = new-object system.net.mail.smtpClient
$mailmessage = New-Object system.net.mail.mailmessage
$SmtpClient.Host = $Smtp
$mailmessage.from = $EmailSender
$mailmessage.To.add($AdminEamil)
$mailmessage.Priority=[system.net.mail.MailPriority]::High
$mailmessage.Bcc.add("[email protected]") #需要修改處
$mailmessage.Subject = “[Report] Exchange 數據庫運行狀態報表”
$mailmessage.IsBodyHtml = $true
$mailmessage.Body += "`n" + $body
$smtpclient.Send($mailmessage)
}
sendmail $Output