Добавление ссылок на HTML-вывод в Powershell - PullRequest
0 голосов
/ 22 сентября 2011

Я написал сценарий PowerShell, который перехватывает все запущенные рабочие процессы IIS на удаленном сервере и возвращает обратно диагностическую информацию (имя приложения, процессор, виртуальная память и т. Д.).Затем он преобразуется в HTML и отображается для пользователя.

$server = Read-Host Enter server name...

if (!(test-connection -computername $server -quiet))
{ 
Write-Host $server is not pingable, does not exist, or timed out. Please try a different server.
}

else 
{
$command = 
{add-pssnapin WebAdministration

function get-iiswp([string]$name="*")
{

   $list = get-process w3wp -ea SilentlyContinue
   if ($error)
   {

Write-Host There are no IIS worker processes currently running. Error Message: $error

   }
        else
        {
            foreach($p in $list)
                { 
                $filter = "Handle='" + $p.Id + "'"
                $wmip = get-WmiObject Win32_Process -filter $filter 

                if($wmip.CommandLine -match "-ap `"(.+)`"")
                    {
                        $appName = $matches[1]
                        $p | add-member NoteProperty AppPoolName $appName
                    }
                }
    $list | where { $_.AppPoolName -like $name }
    }
}

get-iiswp | select-object -property *
}


invoke-command -computername $server -scriptblock $command | ConvertTo-HTML ID, AppPoolName, @{Label="CPU(s)";Expression={if ($_.CPU -ne $()) {$_.CPU.ToString("N")}}}, @{Label="Virtual Memory";Expression={[int]($_.VM/1MB)}}, @{Label="Physical Memory";Expression={[int]($_.WS/1024)}} | Out-file D:/test.html

}

Я ищу способ форматирования HTML-вывода для преобразования вывода таблицы AppPoolName в ссылку, в которой он будет использовать AppPoolNameи PID внутри самой ссылки (например, http://powershell.com/requests.ps1x?PID=$PID&AppPoolName=$AppPoolName

Если у кого-то есть какие-либо мысли или идеи, которые могут решить и направить меня в правильном направлении, это будет высоко оценено.

Спасибо!

----------- Обновление -------------------

Вот пример выходных данных:

<tr><tr><tr>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN"  "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<title>HTML TABLE</title>
</head><body>
<h2>IIS Worker Process Diagnostic</h2>
<table>
<colgroup>
<col/>
<col/>
<col/>
<col/>
<col/>
</colgroup>
<tr><th>ID</th><th>AppPoolName</th><th>CPU(s)</th><th>Virtual Memory</th><th>Physical Memory</th></tr>
<tr><td>3820</td><td>AppPool1</td><td>4.92</td><td>355</td><td>74200</td></tr>
<tr><td>4108</td><td>AppPool2</td><td>0.23</td><td>106</td><td>21380</td></tr>
<tr><td>4940</td><td>AppPool3</td><td>0.20</td><td>590</td><td>39444</td></tr>
<tr><td>7244</td><td>AppPool4</td><td>0.33</td><td>596</td><td>42556</td></tr>
</table>
</body></html>

1 Ответ

1 голос
/ 23 сентября 2011

Я думаю, вы могли бы заменить AppPoolName (в ConvertTo-HTML) на это ...

@{Label="AppPoolName";Expression={ '<a href="http://powershell.com/requests.ps1x?PID=$($_.PID)&AppPoolName=$($_.AppPoolName)">$($_.AppPoolName)</a>' }}

Это просто не в моей голове и не проверено ...: -)

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...