首页 热点资讯 义务教育 高等教育 出国留学 考研考公

三个常用PowerShell网络命令 等效IPConfig PING NSLookup

发布网友 发布时间:2022-04-23 12:46

我来回答

2个回答

懂视网 时间:2022-05-06 21:26

在第一篇中简单介绍了PowerShell,包含基本的一些命令,以及如何打开PowerShell,并且导航到SSAS对象。第二篇中学习了如何使用变量根据当前日期创建SSAS备份,以及如何运行MDX和XMLA脚本。 原文地址: http://www.mssqltips.com/sqlservertip/2980/using-pow

在第一篇中简单介绍了PowerShell,包含基本的一些命令,以及如何打开PowerShell,并且导航到SSAS对象。第二篇中学习了如何使用变量根据当前日期创建SSAS备份,以及如何运行MDX和XMLA脚本。

原文地址:

http://www.mssqltips.com/sqlservertip/2980/using-powershell-for-ssas-to-check-service-status-and-database-availability/

在这一篇中,主要介绍以下几个话题:

- 使用PowerShell命令验证SSAS服务的状态

- 如果SSAS服务当掉自动发送消息

- 验证SSAS数据库的硬盘使用情况

- 每小时运行脚本验证数据库的状态

环境:

Adventureworks微软示例项目。

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:scriptsAdventure.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/

热心网友 时间:2022-05-06 18:34

如果你是一个Windows老司机,那么一定知道
IPConfig、PING

NSLookup这3个非常常用的网络测试命令,虽然在Powershell中这3个命令还是可以使用,我们今天还是向大家介绍中等效IPConfig、PING和NSLookup命令的3个常用
Powershell网络命令。
IPConfig
如果你经常使用
IPConfig
命令来查看
Windows
中每个网卡的
TCP/IP
配置信息,在
PowerShell
中如下
2
条命令与其功能类似:
Get-NetIPConfiguration
#或
Get-NetIPAddress
Get-NetIPConfiguration
cmdlet
可以直接获取当前计算机中每块网卡的
TCP/IP
配置信息,Get-NetIPAddress
可以获取当前计算机的所有
IP
地址配置信息。
PING

PowerShell
中可以使用
Test-NetConnection
cmdlet
来获取与
PING
命令等效的网络连接诊断信息,它可以在
DNS
查询到
IP
地址之后进行
TCP
连接测试,并输出测试结果。
从上图中大家可以看到,Test-NetConnection
还可以使用
-TraceRoute
参数获取路由的路径和跳数,该功能相当于
tracert
命令。
NSLOOKUP
Powershell
中可以使用
Resolve-DnsName
cmdlet
来等效
NSLOOKUP
进行
DNS
名称查询,与
nslookup
交互式使用方法不同的是,Resolve-DnsName
可以直接跟像
-Server
这样的参数来指定要查询的
DNS
服务器,非常方便。

声明声明:本网页内容为用户发布,旨在传播知识,不代表本网认同其观点,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。E-MAIL:11247931@qq.com