gpt4 book ai didi

c# - 所有 .NET 程序集在 Windows Server 上运行都非常慢

转载 作者:行者123 更新时间:2023-11-30 17:43:05 28 4
gpt4 key购买 nike

我有非常简单的 C# 代码编译成 .NET exe assmebly:

using System;
class Program
{
public static void Main()
{
Console.WriteLine("test");
}
}

编译后的程序集在我的桌面 Windows 8.1 机器上每次运行大约 0.02 秒,但在生产 Windows Server 2012 R2 上它运行 1.05 秒。

这是我正在测试的PowerShell:

$sw = [Diagnostics.Stopwatch]::StartNew()
for ($i=1; $i -le 10; $i++)
{
.\cs.exe
}
$sw.Stop()
$sw.Elapsed

在我的本地机器上的输出:

TotalMinutes      : 0.00391715666666667
TotalSeconds : 0.2350294
TotalMilliseconds : 235.0294

我本地机器上的 .NET 版本:

PSChildName                                                 Version
----------- -------
v2.0.50727 2.0.50727.4927
v3.0 3.0.30729.4926
Windows Communication Foundation 3.0.4506.4926
Windows Presentation Foundation 3.0.6920.4902
v3.5 3.5.30729.4926
Client 4.5.51641
Full 4.5.51641
Client 4.0.0.0

服务器上的输出:

TotalMinutes      : 0.172228565
TotalSeconds : 10.3337139
TotalMilliseconds : 10333.7139

服务器上的 .NET 版本:

PSChildName                                                 Version
----------- -------
Client 4.5.51650
Full 4.5.51650
Client 4.0.0.0

服务器上的环境变量:

Name                           Value
---- -----
ALLUSERSPROFILE C:\ProgramData
APPDATA C:\Users\*********\AppData\Roaming
CLIENTNAME *********
CommonProgramFiles C:\Program Files\Common Files
CommonProgramFiles(x86) C:\Program Files (x86)\Common Files
CommonProgramW6432 C:\Program Files\Common Files
COMPUTERNAME *********
ComSpec C:\Windows\system32\cmd.exe
COR_ENABLE_PROFILING 7
COR_PROFILER {8019fee9-9590-4bd4-b2c9-815628f80f0f}
CORECLR_ENABLE_PROFILING 0
FP_NO_HOST_CHECK NO
HOMEDRIVE C:
HOMEPATH \Users\*********
JAVA_HOME C:\Progra~1\Java\jdk1.8.0_45
LOCALAPPDATA C:\Users\*********\AppData\Local
LOGONSERVER \\*********
NUMBER_OF_PROCESSORS 12
OS Windows_NT
Path C:\ProgramData\Oracle\Java\javapath;C:\Windows\system32;C:\Windows;C:\Windows\System3...
PATHEXT .COM;.EXE;.BAT;.CMD;.VBS;.VBE;.JS;.JSE;.WSF;.WSH;.MSC;.CPL
PROCESSOR_ARCHITECTURE AMD64
PROCESSOR_IDENTIFIER Intel64 Family 6 Model 63 Stepping 2, GenuineIntel
PROCESSOR_LEVEL 6
PROCESSOR_REVISION 3f02
ProgramData C:\ProgramData
ProgramFiles C:\Program Files
ProgramFiles(x86) C:\Program Files (x86)
ProgramW6432 C:\Program Files
PSModulePath C:\Users\*********\Documents\WindowsPowerShell\Modules;C:\Program Files\WindowsPow...
PUBLIC C:\Users\Public
SESSIONNAME RDP-Tcp#126
SystemDrive C:
SystemRoot C:\Windows
TEMP C:\Users\ACADWE~1\AppData\Local\Temp\2
TMP C:\Users\ACADWE~1\AppData\Local\Temp\2
USERDOMAIN *********
USERDOMAIN_ROAMINGPROFILE *********
USERNAME *********
USERPROFILE C:\Users\*********
windir C:\Windows

是什么导致了这 1 秒的缓慢?

是 JIT 编译器的问题吗?

是否有任何应在服务器中运行的 CLR 相关服务?

是否有任何可以禁用的应用程序验证检查?

此问题仅发生在 .NET exe 文件中。用 C++ 编译的简单可执行文件运行 0.01

编辑:

我尝试按照评论中的建议运行 ngen.exe ExecuteQueuedItems 但没有任何改变。以下是命令的结果:

PS C:\Windows\system32> C:\Windows\Microsoft.NET\Framework\v4.0.30319\ngen.exe ExecuteQueuedItems
Microsoft (R) CLR Native Image Generator - Version 4.0.30319.33440
Copyright (c) Microsoft Corporation. All rights reserved.
All compilation targets are up to date.

最佳答案

我发现了问题。

似乎服务器有dotMemory安装

还设置了以下环境变量:

COR_ENABLE_PROFILING           7
COR_PROFILER {8019fee9-9590-4bd4-b2c9-815628f80f0f}
CORECLR_ENABLE_PROFILING 0

卸载 dotMemory 并删除这些环境变量后,一切都按预期工作(每次 C# 应用程序运行 0.02 秒)

关于c# - 所有 .NET 程序集在 Windows Server 上运行都非常慢,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/31386810/

28 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com