来自 BizTalk 的电子邮件通知失败消息和来自事件查看器的错误
Email notification from BizTalk for failed messages & error from event viewer
enter image description here请告诉我如何在 BizTalk 中的消息失败以及事件查看器中出现错误时获取电子邮件通知。
'correct' 方法是使用 Windows 和其他平台的监控工具。
首先,作为您的网络或服务器团队,如果他们有 SCOM 或 Splunk 之类的工具,无论如何他们都应该使用这些工具来监控服务器。然后,您可以配置 you/they 想要的任何规则,包括电子邮件。
在您的 BizTalk 应用程序中,请务必在您的异常处理代码中创建 Windows 事件(事件查看器)。
我认为这取决于您的解决方案。在我开发的解决方案中,我已经确定了消息路由的大部分故障点,原因是错误转换、缺少字段等。然后将这些路由到一个专门只发送 SMTP 电子邮件以设置地址的编排。这非常适合我公司的要求。 - 您可以快速找到大量 SMTP 编排示例 google.. 我开始 here
与此同时 - 对于未知数,我还设置了一个 powershell 脚本来通过电子邮件发送 Windows 日志事件查看器的最后一条消息。我使用 BizTalk 管理控制台创建了自定义查看器..
<QueryList>
<Query Id="0" Path="Application">
<Select Path="Application">*[System[Provider[@Name='BizTalk DW Reporting' or @Name='BizTalk Server' or @Name='BizTalk Server Deployment' or @Name='BizTalk Server EDI' or @Name='ENTSSO' or @Name='XLANG/s'] and (Level=1 or Level=2)]]</Select>
</Query>
</QueryList>
然后将其导出到 Windows 任务计划中,只要检测到自定义查看器中有新条目,就会触发 powershell 脚本。
我遵循了为 powershell 脚本提供的粗略原则 here。
希望这能为您指明正确的方向,满足您的需求。可能有更好的解决方案,但这相当有效。
这是我正在使用的 powershell 脚本
$event = get-eventlog -LogName Application -Source "XLANG/s","BizTalk Server","BizTalk DW Reporting","BizTalk Server Deployment","BizTalk Server EDI","ENTSSO" -EntryType "Error" -newest 1
#get-help get-eventlog will show there are a handful of other options available for selecting the log entry you want.
$eventtime = $event.TimeGenerated
#ignore any messagebox errors
if (($event.EntryType -eq "Error" -and $event.EventID -inotin 6998, 10514))
{
$Source = $event.Source
$PCName = $env:COMPUTERNAME
$EmailBody = "$Source Error captured at " + $event.TimeGenerated + " in windows error log on BizTalk-UAT server: `n`n" + $event.Message
$EmailFrom = "????-BizTalk-UAT@???.com"
$EmailTo = @('????-BizTalk-UAT@???.com')
$EmailSubject = "BizTalk-UAT Server - Windows Log - " + $event.EntryType
$SMTPServer = "mail.????.com"
Write-host "Sending Email" $EmailFrom "To" $EmailTo
Send-MailMessage -From $EmailFrom -To $EmailTo -Subject $EmailSubject -body $EmailBody -SmtpServer $SMTPServer
}
else
{
write-host "No error found"
write-host "Here is the log entry that was inspected:"
$event
}
enter image description here请告诉我如何在 BizTalk 中的消息失败以及事件查看器中出现错误时获取电子邮件通知。
'correct' 方法是使用 Windows 和其他平台的监控工具。
首先,作为您的网络或服务器团队,如果他们有 SCOM 或 Splunk 之类的工具,无论如何他们都应该使用这些工具来监控服务器。然后,您可以配置 you/they 想要的任何规则,包括电子邮件。
在您的 BizTalk 应用程序中,请务必在您的异常处理代码中创建 Windows 事件(事件查看器)。
我认为这取决于您的解决方案。在我开发的解决方案中,我已经确定了消息路由的大部分故障点,原因是错误转换、缺少字段等。然后将这些路由到一个专门只发送 SMTP 电子邮件以设置地址的编排。这非常适合我公司的要求。 - 您可以快速找到大量 SMTP 编排示例 google.. 我开始 here
与此同时 - 对于未知数,我还设置了一个 powershell 脚本来通过电子邮件发送 Windows 日志事件查看器的最后一条消息。我使用 BizTalk 管理控制台创建了自定义查看器..
<QueryList>
<Query Id="0" Path="Application">
<Select Path="Application">*[System[Provider[@Name='BizTalk DW Reporting' or @Name='BizTalk Server' or @Name='BizTalk Server Deployment' or @Name='BizTalk Server EDI' or @Name='ENTSSO' or @Name='XLANG/s'] and (Level=1 or Level=2)]]</Select>
</Query>
</QueryList>
然后将其导出到 Windows 任务计划中,只要检测到自定义查看器中有新条目,就会触发 powershell 脚本。
我遵循了为 powershell 脚本提供的粗略原则 here。
希望这能为您指明正确的方向,满足您的需求。可能有更好的解决方案,但这相当有效。
这是我正在使用的 powershell 脚本
$event = get-eventlog -LogName Application -Source "XLANG/s","BizTalk Server","BizTalk DW Reporting","BizTalk Server Deployment","BizTalk Server EDI","ENTSSO" -EntryType "Error" -newest 1
#get-help get-eventlog will show there are a handful of other options available for selecting the log entry you want.
$eventtime = $event.TimeGenerated
#ignore any messagebox errors
if (($event.EntryType -eq "Error" -and $event.EventID -inotin 6998, 10514))
{
$Source = $event.Source
$PCName = $env:COMPUTERNAME
$EmailBody = "$Source Error captured at " + $event.TimeGenerated + " in windows error log on BizTalk-UAT server: `n`n" + $event.Message
$EmailFrom = "????-BizTalk-UAT@???.com"
$EmailTo = @('????-BizTalk-UAT@???.com')
$EmailSubject = "BizTalk-UAT Server - Windows Log - " + $event.EntryType
$SMTPServer = "mail.????.com"
Write-host "Sending Email" $EmailFrom "To" $EmailTo
Send-MailMessage -From $EmailFrom -To $EmailTo -Subject $EmailSubject -body $EmailBody -SmtpServer $SMTPServer
}
else
{
write-host "No error found"
write-host "Here is the log entry that was inspected:"
$event
}