众所周知数据库是微软邮件系统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) { $check01 = Get-MailboxDatabase –Identity $dbname -status if ($check01.mounted –eq $false) { $msg = “ alert! your $check01 database was dismounted! ” $nSmtpserver = "" } else { #do nothing } }
如此来循环。当然你也可以用HTML语句来美化你的邮件报警。 这个脚本就完成了,怎么样?用最简单的语句也可以完成Exchange服务器没有的功能吧??
===本期结束=== 请有兴趣的看官关注我的博客吧,我会一个一个从简单到难写在博客中的 |
|
来自: xiaozhuang > 《待分类》