众所周知数据库是微软邮件系统Exchange 2010中最重要的部分,所有的用户邮件日历等信息都储存在数据库文件中。任何数据库的问题都会是大问题,日常的备份和保养非常重要。不过一旦数据库dismount,如果没有监控软件的报警,管理员将很难发现。直到有用户打电话来抱怨才会发现(谁也不会一直盯着EMC,5分钟刷新一次来人肉监控的吧?)
如果使用Powershell脚本来监控数据库的mount情况呢?请关注此文
相信很多同学都使用Powershell来管理Exchange 2010 Server,如果在你的EMS中输入
Get-MailboxDatabase -Identity 数据库名 -status |fl
你会得到很多的参数和数据,请留意以下这条
如果数据库没有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命令将输入的结果显示在屏幕上。
完成之后收到的邮件效果如下:
脚本如下:
$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服务器没有的功能吧??
===本期结束===
请有兴趣的看官关注我的博客吧,我会一个一个从简单到难写在博客中的