调用 powershell.exe 非常慢

Ade*_*SIF 5 windows powershell windows-server-2008-r2

我有一台装有 Powershell V4.0 的 Windows 2008 R2 服务器

我得到了一个非常简单的脚本 test.ps1,其中包含以下内容:

Write-host "Hello world!"
Run Code Online (Sandbox Code Playgroud)

我从一个 powershell 提示符调用这个脚本,如下所示:

measure-command { powershell.exe -file .\test.ps1 }
Run Code Online (Sandbox Code Playgroud)

如您所见,我获得了极高的价值:

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
Run Code Online (Sandbox Code Playgroud)

或者

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
Run Code Online (Sandbox Code Playgroud)

它占用了我 50% 的 CPU。为什么太长了?我试过,-noprofile但它是一样的。

谢谢你的帮助。

Rya*_*ies 7

Powershell 加载和 JIT 编译成吨、成吨、成吨的东西。这需要大量过多的 CPU 周期和磁盘 I/O。

尝试使用ngen.exe(本机图像生成器)预编译 Powershell 在启动期间加载的程序集。只是可能会改善您的启动时间。

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

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

在此处阅读有关 ngen 的信息