如何使用Powershell脚本监控Exchange2010(一) 数据库Mount状态的监控

众所周知数据库是微软邮件系统Exchange 2010中最重要的部分,所有的用户邮件日历等信息都储存在数据库文件中。任何数据库的问题都会是大问题,日常的备份和保养非常重要。不过一旦数据库dismount,如果没有监控软件的报警,管理员将很难发现。直到有用户打电话来抱怨才会发现(谁也不会一直盯着EMC,5分钟刷新一次来人肉监控的吧?微笑

如果使用Powershell脚本来监控数据库的mount情况呢?请关注此文

 

相信很多同学都使用Powershell来管理Exchange 2010 Server,如果在你的EMS中输入

Get-MailboxDatabase -Identity 数据库名 -status |fl

你会得到很多的参数和数据,请留意以下这条

image

如果数据库没有Mounted,这个参数会变成False,也就是说,我们的思路是这样的:

1. 编写一个Powershell脚本,每隔N分钟去检查一下这个参数

2. 如果是True说明一切正常,可以无视

3. 如果检测到这个参数是False,我们可以让脚本发送EMAIL给管理员

 

那是如何实现的呢:

在介绍之前,我想让大家有个比较直观的概念什么是Powershell(以下简称PS)中的变量,我们来看看度娘的回答

变量是一段有名字的连续存储空间。在源代码中通过定义变量来申请并命名这样的存储空间,并通过变量的名字来使用这段存储空间。 变量是程序中数据的临时存放场所。在代码中可以只使用一个变量,也可以使用多个变量,变量中可以存放单词、数值、日期以及属性。

在PS中变量以$开头,简单的实验

1. 打开ps

2. 输入$a = 1

3. $a

1

你会得到1,因为你赋予了变量a 1的值,同理,如果你输入

$a = “exdb01” 注意需要加引号否则系统不认,加引号是将变量变成文字形式

并且在 Get-MailboxDatabase –Identity $a -status |fl

你会得到exdb01这个数据名的各项参数

这个就是我们想要的

回到主题

第一步. 定位

定位数据库名,如果你是初学者,你可以直接输入数据库的名称,但是你需要给输出结果一个变量,比方说:

$check01 = Get-MailboxDatabase –Identity exdb01 -status

变量的好处就在于它可以调用参数,尝试输入

$check01.mounted

你会得到True或者False的结果,这个就是我们想要的的数据

第二步. 判断

判断是ture或者false,很容易,我们可以使用if语句,这个对有编程经验的同学来说简直太容易了。

如何写呢,我们可以做个简单的测试

if ($check01.mounted –eq $true){write-host “OK”}

-eq代表等于

如果你在屏幕上看到OK,恭喜你你成功了

实际情况下我们可以这样做

$check01 = Get-MailboxDatabase –Identity exdb01 -status

if ($check01.mounted –eq $false)

{

$msg = “

alert! your $check01.identity database was dismounted!

send-mailmessage -subject "自己填" -Smtpserver "自己填" -From "自己填" -To "自己填" -body "$msg"

}

如果你会使用循环foreach的话,更好了,你完全可以使用 get-mailboxdatabase 命令来问Exchange服务器取出所有的数据库名称,然后再将这些名称自动填入你需要运行的命令中,然后再检查是否mount,如果没有的话可以发送邮件给你,你可以搭建一个简单的smtp服务器来做这个事情。当然你也可以用write-host命令将输入的结果显示在屏幕上。

完成之后收到的邮件效果如下:

image

脚本如下:

$dbs = get-mailboxdatabase

foreach ($db in $dbs)

{
$dbname = $db.name

$check01 = Get-MailboxDatabase –Identity $dbname -status

if ($check01.mounted –eq $false)

{

$msg = “

alert! your $check01 database was dismounted!

$nSmtpserver = ""
$nFrom = ""
$nTo = ""
$nSubject = ""
send-mailmessage -bodyashtml -subject $nSubject -Smtpserver $nSmtpserver -From $nFrom -To $nTo -body $nMsg

}

else

{

#do nothing

}

}

 

如此来循环。当然你也可以用HTML语句来美化你的邮件报警。

这个脚本就完成了,怎么样?用最简单的语句也可以完成Exchange服务器没有的功能吧??

 

===本期结束===

请有兴趣的看官关注我的博客吧,我会一个一个从简单到难写在博客中的

你可能感兴趣的:(数据库,监控,Exchange,powershell,Exchange2010)