众所周知数据库是微软邮件系统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服务器没有的功能吧??
===本期结束===
请有兴趣的看官关注我的博客吧,我会一个一个从简单到难写在博客中的
自由广告区 |
分类导航 |
邮件新闻资讯: IT业界 | 邮件服务器 | 邮件趣闻 | 移动电邮 电子邮箱 | 反垃圾邮件|邮件客户端|网络安全 行业数据 | 邮件人物 | 网站公告 | 行业法规 网络技术: 邮件原理 | 网络协议 | 网络管理 | 传输介质 线路接入 | 路由接口 | 邮件存储 | 华为3Com CISCO技术 | 网络与服务器硬件 操作系统: Windows 9X | Linux&Uinx | Windows NT Windows Vista | FreeBSD | 其它操作系统 邮件服务器: 程序与开发 | Exchange | Qmail | Postfix Sendmail | MDaemon | Domino | Foxmail KerioMail | JavaMail | Winwebmail |James Merak&VisNetic | CMailServer | WinMail 金笛邮件系统 | 其它 | 反垃圾邮件: 综述| 客户端反垃圾邮件|服务器端反垃圾邮件 邮件客户端软件: Outlook | Foxmail | DreamMail| KooMail The bat | 雷鸟 | Eudora |Becky! |Pegasus IncrediMail |其它 电子邮箱: 个人邮箱 | 企业邮箱 |Gmail 移动电子邮件:服务器 | 客户端 | 技术前沿 邮件网络安全: 软件漏洞 | 安全知识 | 病毒公告 |防火墙 攻防技术 | 病毒查杀| ISA | 数字签名 邮件营销: Email营销 | 网络营销 | 营销技巧 |营销案例 邮件人才:招聘 | 职场 | 培训 | 指南 | 职场 解决方案: 邮件系统|反垃圾邮件 |安全 |移动电邮 |招标 产品评测: 邮件系统 |反垃圾邮件 |邮箱 |安全 |客户端 |