如何通过PowerShell命令检索与特定IIS AppPool关联的应用程序数量?
我们可以使用以下方式手动查看关联的应用程序:
Get-Item IIS:\AppPools\AppPoolName
但是,如果我们手动想要选择Applications
列,则无法进行此操作。此外,Applications
列中未列出| Get-Member *
列。
答案 0 :(得分:15)
诀窍是:PowerShell建立了所谓的“视图定义文件”,它告诉PowerShell如何格式化对象(例如,对象是否被格式化为列表或表格,显示哪些列等)。这些文件可以在C:\Windows\System32\WindowsPowerShell\v1.0
找到,并且都以.format.ps1xml
结尾。
回答原始问题:文件C:\Windows\System32\WindowsPowerShell\v1.0\Modules\WebAdministration\iisprovider.format.ps1xml
包含AppPool
类型的视图定义,该类型定义了如下所示的计算列:
<TableColumnItem>
<ScriptBlock>
$pn = $_.Name
$sites = get-webconfigurationproperty "/system.applicationHost/sites/site/application[@applicationPool=`'$pn`'and @path='/']/parent::*" machine/webroot/apphost -name name
$apps = get-webconfigurationproperty "/system.applicationHost/sites/site/application[@applicationPool=`'$pn`'and @path!='/']" machine/webroot/apphost -name path
$arr = @()
if ($sites -ne $null) {$arr += $sites}
if ($apps -ne $null) {$arr += $apps}
if ($arr.Length -gt 0) {
$out = ""
foreach ($s in $arr) {$out += $s.Value + "`n"}
$out.Substring(0, $out.Length - 1)
}
</ScriptBlock>
</TableColumnItem>
这解释了为什么列本身不是AppPool类型的成员。现在可以从上面的“scriptlet”中提取必要的代码,轻松回答第二个问题:
$applicationsInAppPoolCount = @(Get-WebConfigurationProperty `"/system.applicationHost/sites/site/application[@applicationPool=`'$appPool`'and @path!='/']"` "machine/webroot/apphost" -name path).Count
答案 1 :(得分:3)
我处理了同样的问题好几个小时,直到最终达成解决方案。 D.R.的答案非常有帮助,但它不适合我。经过一些调整后,我想出了下面的代码,它可以检索应用程序池中的应用程序数量。
我注意到代码nd @path!='/'
的这一部分丢掉了计数。
$appPool = "REPLACE ME with a value from your app pool"
@(Get-WebConfigurationProperty "/system.applicationHost/sites/site/application[@applicationPool=`'$appPool`']" "machine/webroot/apphost" -name path).Count
答案 2 :(得分:2)
我最终得到了以下代码(基本上与上面相同,但格式不同)
$appPools = Get-ChildItem –Path IIS:\AppPools
foreach ($apppool in $apppools) {
$appoolName = $apppool.Name
[string] $NumberOfApplications = (Get-WebConfigurationProperty "/system.applicationHost/sites/site/application[@applicationPool='$appoolName']" "machine/webroot/apphost" -name path).Count
Write-Output "AppPool name: $appoolName has $NumberOfApplications applications"
}
答案 3 :(得分:0)
这给出了数组中的内容。
导入模块WebAdministration;
Get-ChildItem IIS:\ AppPools >> AppPoolDetails.txt;
$appPoolDetails = Get-Content .\AppPoolDetails.txt;
$w = ($appPoolDetails |Select-String 'State').ToString().IndexOf("State");
$w = $w -1;
$res1 = $appPoolDetails | Foreach {
$i=0;
$c=0; `
while($i+$w -lt $_.length -and $c++ -lt 1) {
$_.Substring($i,$w);$i=$i+$w-1}}
Write-Host "First Column---";
$res1.Trim();
$j = $w + 1;
$w = ($appPoolDetails |Select-String 'Applications').ToString().IndexOf("Applications");
$w = $w -$j;
$res2 = $appPoolDetails | Foreach {
$i=$j;
$c=0; `
while($i+$w -lt $_.length -and $c++ -lt 1) {
$_.Substring($i,$w);$i=$i+$w-1}}
Write-Host "Second Column---";
$res2.Trim();
$lineLength=0
$appPoolDetails | Foreach {
if($lineLength -lt $_.TrimEnd().Length )
{
$lineLength = $_.TrimEnd().Length;
#Write-Host $lineLength;
}
}
$j = ($appPoolDetails | Select-String 'Applications').ToString().IndexOf("Applications");
$w = $lineLength;
$w = $w -$j;
#Write-Host $j $w;
$res3 = $appPoolDetails | Foreach {
$i=$j;
$c=0; `
while($i+$w -lt $_.length -and $c++ -lt 1) {
$_.Substring($i,$w);$i=$i+$w-1}}
Write-Host "Third Column---";
$res3;
答案 4 :(得分:0)
我最近遇到了这篇文章,以寻找获取活动应用程序池的方法。上面提供的信息很棒,但是我一直在努力寻找是否还有另一种方式来获取此信息。我能够找到一种通过Get-IISSite做到这一点的方法,我使用了以下方法:
Get-IISSite | Select-Object -ExpandProperty Applications | Select-Object Path,ApplicationPoolName
我在只有一个网站的服务器上对此进行了测试,但是如果服务器上有多个站点,您还可以为Select添加VirtualDirectories。
我还需要获取正在使用的应用程序池的唯一列表,因此我执行了以下操作:
$appPoolInfo = Get-IISSite | Select-Object -ExpandProperty Applications | Select-Object Path,ApplicationPoolName
$appPoolInfo | Select-Object -Unique ApplicationPoolName