yp1234 发表于 2018-9-3 09:11:40

如何使用Powershell脚本监控Exchange2010(四) MessageTracking邮件跟踪小工具自己做

  不好意思,对不起各位,好久没来写博客了,最近忙着照顾我儿子(一条边境牧羊犬)。公司又比较忙,所以没把博客多放在心上。抱歉抱歉。。。不过我相信在51cto的博客里,我写的东西应该算是绝无仅有而且有一定的技术含量的,在日常的工作中也是相当的实用。好吧,开始今天的博客。
  最近很头疼,新加坡的阿三一直打电话来问为什么他的客户会议邀请没收到啊,为什么邮件DELAY啊,为什么邮件没收到啊,麻烦的很。没办法,只能一遍一遍的人肉查message tracking log。一般情况下,我比较喜欢使用powershell命令,直观,简单。不过有时候也难免因为笔误而造成查询失败,或者信息太多。比如:
  我需要精确的查询 2012-03-10 到 2012-03-12 abc@abc.com 收到的标题为”weekly meeting”的邮件,标准的Powershell格式应该是
  Get-MessageTrackingLog -Start 2012-03-10 -End 2012-03-12 -Recipients "abc@abc.com" -MessageSubject "weekly meeting"
  而如果当前Site中有多个hub server的话,无法得知你想要的log在哪个服务器上。这是因为同一个Site中的Hub Server会自动负载均衡,
  打个比方:
  你今天发送了10封邮件,你们的hub 服务器有4台。可能会出现这样的情况,你有在hub01上找到2封邮件,hub02上有4封,hub03上有3封,hub04上有1封。
  OMG,天知道我要搜索的邮件在哪台服务器上。。。一台一台的找又不是我的风格。。。怎么办呢。。。自己做个基于Powershell的小工具算了。。
  Conecpt:
  1. 这个小工具必须是交互式的,可以让使用者轻松的把自己的想要搜索的条件放到窗口里
  2. 为了精确搜索,必须支持多个条件搜索
  3. 为了简便,需要把在同一个Site中hub服务器上的tracking log集中在一起以方便查看(没办法,我懒。。)
  注意:要做到搜寻同一个Site中的Hub服务器,我们的服务器名需要做到规范,比如 exshahub01, or exshahub02, exusahub01 等
第一部分: 窗体的设计
  我的设计理念是把用户输入的参数作为一个变量为我调用。Powershell可谓非常强大,做到这点完全没有问题。
  Powershell可以调用系统的窗口比如日历
  代码如下:
  ######################################################################
   ::LoadWithPartialName("System.Windows.Forms")
   ::LoadWithPartialName("System.Drawing")
  $objForm = New-Object Windows.Forms.Form
  $objForm.Text = "Select a Date"
  $objForm.Size = New-Object Drawing.Size @(190,190)
  $objForm.StartPosition = "CenterScreen"
  $objForm.KeyPreview = $True
  $objForm.Add_KeyDown({
  if ($_.KeyCode -eq "Enter")
  {
  $dtmDate=$objCalendar.SelectionStart
  $objForm.Close()
  }
  })
  $objForm.Add_KeyDown({
  if ($_.KeyCode -eq "Escape")
  {
  $objForm.Close()
  }
  })
  $objCalendar = New-Object System.Windows.Forms.MonthCalendar
  $objCalendar.ShowTodayCircle = $False
  $objCalendar.MaxSelectionCount = 1
  $objForm.Controls.Add($objCalendar)
  $objForm.Topmost = $True
  $objForm.Add_Shown({$objForm.Activate()})
   $objForm.ShowDialog()
  if ($dtmDate)
  {
  Write-Host "Date selected: $dtmDate"
  }
  ######################################################################
  有兴趣的同学可以拷贝这段代码到ps1文件里然后运行看看,会出现日历的窗口,是不是很神奇?

  当然,我们也可以调用其他的窗口,比如TXT窗口

  代码如下:
  ########################################################################
   ::LoadWithPartialName("System.Drawing")
   ::LoadWithPartialName("System.Windows.Forms")
  $objForm = New-Object System.Windows.Forms.Form
  $objForm.Text = "abc"
  $objForm.Size = New-Object System.Drawing.Size(300,140)
  $objForm.StartPosition = "CenterScreen"
  $objForm.KeyPreview = $True
  $objForm.Add_KeyDown({if ($_.KeyCode -eq "Enter")
  {$x=$objTextBox.Text;$objForm.Close()}})
  $objForm.Add_KeyDown({if ($_.KeyCode -eq "Escape")
  {$objForm.Close()}})
  $OKButton = New-Object System.Windows.Forms.Button
  $OKButton.Location = New-Object System.Drawing.Size(75,80)
  $OKButton.Size = New-Object System.Drawing.Size(75,23)
  $OKButton.Text = "OK"
  $OKButton.Add_Click({$x=$objTextBox.Text; $objForm.Close()})
  $objForm.Controls.Add($OKButton)
  $CancelButton = New-Object System.Windows.Forms.Button
  $CancelButton.Location = New-Object System.Drawing.Size(150,80)
  $CancelButton.Size = New-Object System.Drawing.Size(75,23)
  $CancelButton.Text = "Cancel"
  $CancelButton.Add_Click({$objForm.Close()})
  $objForm.Controls.Add($CancelButton)
  $objLabel = New-Object System.Windows.Forms.Label
  $objLabel.Location = New-Object System.Drawing.Size(10,20)
  $objLabel.Size = New-Object System.Drawing.Size(280,20)
  $objLabel.Text = "bcd
  $objForm.Controls.Add($objLabel)
  $objTextBox = New-Object System.Windows.Forms.TextBox
  $objTextBox.Location = New-Object System.Drawing.Size(10,40)
  $objTextBox.Size = New-Object System.Drawing.Size(260,20)
  $objForm.Controls.Add($objTextBox)
  $objForm.Topmost = $True
  $objForm.Add_Shown({$objForm.Activate()})
   $objForm.ShowDialog()
  ##########################################################################

页: [1]
查看完整版本: 如何使用Powershell脚本监控Exchange2010(四) MessageTracking邮件跟踪小工具自己做