首页 > 解决方案 > PowerShell SQL Server 处理器性能计数器

问题描述

我想监视具有 8 个 SQL 实例的服务器上的处理器负载。我发现了正确的计数器:

get-counter -listset processor | select -expandproperty counter

我得到类似: \Processor(*)% Processor Time 和 \Process(sqlsrv#1...sqlsrv#XX) 我很感兴趣。我现在可以声明我的计数器:

$counter="\Process(sqlsrv#1)\% Processor Time"; Get-counter -counter $counter -sampleInterval 3

但是我怎么知道哪一个 SQL 实例隐藏在“sqlsrv#1”..“sqlsrv#8”后面?

标签: sql-serverpowershell

解决方案


实际上,我认为我们没有直接的方法可以做到这一点......但是

假设 - 如果您的服务器中有 3 个实例(进程将是sqlservrsqlservr#1sqlservr#2)。正确的 ?

您可以使用下面的计数器名称ID 进程在进程对象中找到每个进程的 PID

\Process(sqlservr)\ID Process
\Process(sqlservr#1)\ID Process
\Process(sqlservr#2)\ID Process

电源外壳

Get-counter -counter "\Process(sqlservr)\ID Process"
Get-counter -counter "\Process(sqlservr#1)\ID Process"
Get-counter -counter "\Process(sqlservr#2)\ID Process"

获得 PID 后,您可以在任务管理器中比较 PID 并找到“用户名”选项卡将具有实际的实例名称

注意:后缀为名为InstanceIndex的进程的数字


推荐阅读