在第一篇中简单介绍了PowerShell,包含基本的一些命令,以及如何打开PowerShell,而且导航到SSAS对象。第二篇中学习了如何使用变量根据当前日期建立SSAS备份,以及如何运行MDX和XMLA脚本。html
原文地址: sql
在这一篇中,主要介绍如下几个话题:数据库
- 使用PowerShell命令验证SSAS服务的状态工具
- 若是SSAS服务当掉自动发送消息sqlserver
- 验证SSAS数据库的硬盘使用状况学习
- 每小时运行脚本验证数据库的状态spa
环境: 3d
SQL Server 2008以后的版本。
开始:
1. 首先使用PowerShell获取Windows Services状态。
get-service
这个命令返回当前的Windows Services以及其状态:
2. 此篇中咱们关注的是SSAS服务,因此命令将会以下所示:
get-service | select status, name | Where-Object {$_.Name -like "*MSSQLServerOLAP*"}
这条命令显示名称中包含"MSSQLServerOLAP"的服务名称以及服务状态,能够看到服务当前的状态是开启仍是中止。
3. 接下来将实现若是服务中止,自动发送信息。
$servicestatus=get-service | select status,name | Where-Object {$_.Name -like "*MSSQLServerOLAP*"}
$Message="The SSAS Service is down"
if($servicestatus.status -eq "Stopped"){
echo $Message
}
这条命令若是监测到SSAS服务中止,将显示消息"The SSAS Service is down"。
4. 如下命令显示磁盘的剩余空间。
$driveinformation=gwmi win32_volume -Filter 'drivetype = 3' | select driveletter, label, @{LABEL='GBfreespace';EXPRESSION={$_.freespace/1GB} }
这条命令以GB为单位显示每一个磁盘的剩余空间,当咱们须要知道SSAS是否有足够的剩余空间的时候,这条命令颇有用。
5. 为了验证SSAS下Cube的状态能够每五分钟发送一条MDX语句。在此篇咱们将建立一条简单的MDX脚本而后以每小时的方式运行以此验证Cube是处于在线状态。
6. 打开SSMS。
7. 链接到SSAS服务而且浏览Adentureworks多维数据集。
8. 拖拽Internet Gross Profit到透视表区域,而后切换到MDX视图。
9. 自动生成的查询以下所示:
SELECT NON EMPTY { [Measures].[Internet Gross Profit] } ON COLUMNS FROM [Adventure Works] CELL PROPERTIES VALUE, BACK_COLOR, FORE_COLOR, FORMATTED_VALUE, FORMAT_STRING, FONT_NAME, FONT_SIZE, FONT_FLAGS
10. 保存脚本为Adventure.mdx文件。
11. 接下来使用PowerShell脚原本调用这条查询。若是没有结果或者一条没有处理的错误消息返回,自动返回链接错误的信息。
$result=Invoke-ASCmd -Database "Adventureworks" -InputFile:"c:\scripts\Adventure.mdx"
$Message="Adventureworks had a connection error"
if ((!$result) -or ($resultado -like "*either does not exist or has not been processed*")){$message}
12. 为了让PowerShell脚本周期的运行,在SSMS下建立一个做业:
13. 给做业取一个名字,而后建立一个新步骤。
14. 指定一个步骤名称,在Type下选择PowerShell而后在命令区粘贴第11步的脚本,而后点击OK。
而后选择Schedules页面,点击New按钮。
输入schedule信息,在这里咱们设置为每小时运行来验证数据库的状态。
至此,一个每小时验证SSAS数据库状态的做业建立完成。但愿你们喜欢这篇。
相关内容:
PowerShell建立自动化任务是一个不错的工具,更多信息请参考如下连接:
http://technet.microsoft.com/en-us/library/hh849804.aspx
http://technet.microsoft.com/en-us/library/ee177028.aspx
http://blogs.technet.com/b/flaphead/archive/2006/09/12/455555.aspx
在MSSQLTips.com上阅读更多关于PowerShell的内容。
http://www.mssqltips.com/sql-server-tip-category/81/powershell/