Chamar o powershell.exe é extremamente lento

5

Eu tenho um servidor Windows 2008 R2 com o Powershell V4.0

Eu recebi um script de teste muito simples.ps1 com este conteúdo:

Write-host "Hello world!"

Eu chamo esse script de um prompt do powershell como este:

measure-command { powershell.exe -file .\test.ps1 }

Eu tenho um valor extremamente alto, como você pode ver:

Days              : 0
Hours             : 0
Minutes           : 0
Seconds           : 7
Milliseconds      : 992
Ticks             : 79922815
TotalDays         : 9,25032581018519E-05
TotalHours        : 0,00222007819444444
TotalMinutes      : 0,133204691666667
TotalSeconds      : 7,9922815
TotalMilliseconds : 7992,2815

Ou

Days              : 0
Hours             : 0
Minutes           : 0
Seconds           : 4
Milliseconds      : 655
Ticks             : 46556579
TotalDays         : 5,38849293981481E-05
TotalHours        : 0,00129323830555556
TotalMinutes      : 0,0775942983333333
TotalSeconds      : 4,6556579
TotalMilliseconds : 4655,6579

E isso levou meu processador a 50%. Por que é muito longo? Eu tentei com -noprofile , mas é o mesmo.

Obrigado pela sua ajuda.

    
por Adeel ASIF 03.03.2016 / 14:12

1 resposta

6

As cargas Powershell e JIT compõem toneladas, toneladas e toneladas de material. Isso exige muitos ciclos de CPU e E / S de disco excessivos.

Tente usar o ngen.exe (Gerador de imagens nativo) pré-compilar os conjuntos que o Powershell carrega durante a inicialização. Só pode melhorar seu tempo de inicialização.

$FrameworkDir=[Runtime.InteropServices.RuntimeEnvironment]::GetRuntimeDirectory()
$NGENPath = Join-Path $FrameworkDir 'ngen.exe'

[AppDomain]::CurrentDomain.GetAssemblies() |
  Select-Object -ExpandProperty Location |
  ForEach-Object { & $NGENPath """$_""" } 

Leia sobre o ngen aqui .

    
por 04.03.2016 / 01:34