0

0

c# 服务器GC和工作站GC的区别和设置

煙雲

煙雲

发布时间:2026-01-02 09:34:02

|

138人浏览过

|

来源于php中文网

原创

服务器GC是Web服务默认选择,.NET运行时自动启用;工作站GC仅适用于单用户桌面应用。可通过GCSettings.IsServerGC或性能计数器验证,配置优先级为环境变量>csproj>自动检测。

c# 服务器gc和工作站gc的区别和设置

工作站GC适合单用户桌面应用,服务器GC才是Web服务的默认选择

ASP.NET Core 或传统 ASP.NET 应用在 IIS 或 Kestrel 上运行时,默认启用的是 server GC,不是 workstation GC。这个决定由运行时自动判断——只要检测到多核 CPU 和非交互式环境(比如 Windows Server 或 Linux 容器),.NET 运行时就会启用服务器 GC。你手动改错配置,反而可能让 GC 压力更大、暂停更长。

如何确认当前用的是哪种 GC 模式

最直接的方式是查 System.Runtime.GCSettings.IsServerGC 的返回值:

Console.WriteLine($"IsServerGC: {System.Runtime.GCSettings.IsServerGC}");

也可以通过性能计数器验证(Windows):.NET CLR Memory\# of Heaps 在服务器 GC 下通常是 CPU 核心数的 2 倍(每个线程池线程对应一个 GC 线程 + 后台 GC 线程),而工作站 GC 固定为 1 个堆。

常见误判点:

  • 本地开发时跑在 Windows 10 上,但用了 true,结果没生效——因为 .NET 6+ 默认按运行环境自动选型,显式配置只在项目文件中有效且需重启进程
  • 容器里跑 Linux,却依赖 Windows 性能计数器去查,查不到就以为没启服务器 GC

在 csproj 中强制设置 GC 模式(仅限需要干预时)

绝大多数 Web 服务不需要改,但如果你在低配 VM(如 1 vCPU)上跑高吞吐 API,或做 GC 行为对比测试,才考虑显式控制。修改方式是在 .csproj 文件的 里加:

云枫工作室企业网站源代码(.net)4.0
云枫工作室企业网站源代码(.net)4.0

云枫工作室企业网站源代码(.net)Version 4.0 是云枫工作室基于.net环境独立开发的一套适用于企业使用的企业网站系统。.net+access.网站使用了模板动态生成静态页面技术,前台页面是生成纯静态的。网站包括了信息管理,产品管理,新闻管理和在线留言。可以在后台设置网站名称,标题,关键字和网站描述。配置说明:服务器空间需要支持.net2.0,还要有可写的权限(这个是必要的,因为网站前

下载

  true

注意:

  • true = 服务器 GC(推荐 Web 服务);false = 工作站 GC(适合 WinForms/WPF)
  • 该设置只在编译时写入 runtimeconfig.json,运行时无法动态切换
  • 若同时设置了环境变量 DOTNET_gcServer,它会覆盖 csproj 配置(优先级:环境变量 > csproj > 自动检测)
  • 在 Docker 中,建议用 ENV DOTNET_gcServer=true 而不是改 csproj,避免镜像复用时配置僵化

服务器GC的关键行为差异和实际影响

服务器 GC 不是“更快的 GC”,而是“为吞吐和并发设计的 GC”:

  • 堆数量 = CPU 核心数 × 2(.NET 5+ 默认启用 concurrent GC,后台线程独立工作)
  • 每次 GC 暂停时间更长(毫秒级),但频率更低,整体吞吐更高
  • 内存占用通常比工作站 GC 高 10%–30%,因为各堆独立管理,碎片和保留内存更多
  • 不支持 GC.Collect() 的“紧急回收”语义——调用它只会触发本线程所在堆的 GC,其他堆不受影响
  • 在 .NET 6+ 中,GCSettings.LatencyMode(如 GCLatencyMode.LowLatency)对服务器 GC 效果有限,仅短暂抑制后台 GC,不能替代正确对象生命周期管理

真正容易被忽略的是:服务器 GC 下的 Gen2 回收成本极高,如果频繁分配大对象(>85KB),会直接进 LOH,而 LOH 在服务器 GC 中不压缩(除非 .NET 5+ 开启 gcServer + gcConcurrent 并配合 GCSettings.LargeObjectHeapCompactionMode 显式触发),长期运行后容易出现 OutOfMemoryException —— 这不是 GC 类型选错了,是对象尺寸或复用策略有问题。

相关专题

更多
json数据格式
json数据格式

JSON是一种轻量级的数据交换格式。本专题为大家带来json数据格式相关文章,帮助大家解决问题。

403

2023.08.07

json是什么
json是什么

JSON是一种轻量级的数据交换格式,具有简洁、易读、跨平台和语言的特点,JSON数据是通过键值对的方式进行组织,其中键是字符串,值可以是字符串、数值、布尔值、数组、对象或者null,在Web开发、数据交换和配置文件等方面得到广泛应用。本专题为大家提供json相关的文章、下载、课程内容,供大家免费下载体验。

528

2023.08.23

jquery怎么操作json
jquery怎么操作json

操作的方法有:1、“$.parseJSON(jsonString)”2、“$.getJSON(url, data, success)”;3、“$.each(obj, callback)”;4、“$.ajax()”。更多jquery怎么操作json的详细内容,可以访问本专题下面的文章。

307

2023.10.13

go语言处理json数据方法
go语言处理json数据方法

本专题整合了go语言中处理json数据方法,阅读专题下面的文章了解更多详细内容。

74

2025.09.10

堆和栈的区别
堆和栈的区别

堆和栈的区别:1、内存分配方式不同;2、大小不同;3、数据访问方式不同;4、数据的生命周期。本专题为大家提供堆和栈的区别的相关的文章、下载、课程内容,供大家免费下载体验。

371

2023.07.18

堆和栈区别
堆和栈区别

堆(Heap)和栈(Stack)是计算机中两种常见的内存分配机制。它们在内存管理的方式、分配方式以及使用场景上有很大的区别。本文将详细介绍堆和栈的特点、区别以及各自的使用场景。php中文网给大家带来了相关的教程以及文章欢迎大家前来学习阅读。

563

2023.08.10

线程和进程的区别
线程和进程的区别

线程和进程的区别:线程是进程的一部分,用于实现并发和并行操作,而线程共享进程的资源,通信更方便快捷,切换开销较小。本专题为大家提供线程和进程区别相关的各种文章、以及下载和课程。

472

2023.08.10

windows查看端口占用情况
windows查看端口占用情况

Windows端口可以认为是计算机与外界通讯交流的出入口。逻辑意义上的端口一般是指TCP/IP协议中的端口,端口号的范围从0到65535,比如用于浏览网页服务的80端口,用于FTP服务的21端口等等。怎么查看windows端口占用情况呢?php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

521

2023.07.26

php源码安装教程大全
php源码安装教程大全

本专题整合了php源码安装教程,阅读专题下面的文章了解更多详细内容。

74

2025.12.31

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
PostgreSQL 教程
PostgreSQL 教程

共48课时 | 6.4万人学习

Git 教程
Git 教程

共21课时 | 2.3万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号