news 2026/1/13 16:55:13

【压测数据分享】C#的 `ThreadPool.SetMaxThreads()` 配置最大线程数到底对性能有多大影响

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
【压测数据分享】C#的 `ThreadPool.SetMaxThreads()` 配置最大线程数到底对性能有多大影响

结论

先说结论:

以 async 的方法 + kestrel 库来提供 http 服务,性能非常强悍。直观感受上,性能不输 golang.

物理线程的数量必然影响性能:

ThreadPool.SetMinThreads( 4,4) ThreadPool.SetMaxThreads(4,4) 线程池的线程数与核数一致时,性能最好。(CPU 占用达到 360%)

不限制线程池的最大和最小线程数,性能下降约 1.37%。猜测在任务更复杂的情况下,下降的比例会更明显。(CPU 占用达到 360%)

ThreadPool.SetMinThreads( 2,2) ThreadPool.SetMaxThreads(2,2) 当线程池最大值只有核数的一半时,性能下降 51.07% (CPU 占用达到 215%)

程序中宜限制线程池最大线程数不要超过核数,否则一定产生劣化影响。

从稳定性考虑:线程池最大值 = 核数 - 1 是个好主意。

某些特定任务可以开额外的线程来运行

负责处理请求的线程数稳定,不至于在过载的时候完全卡死整个应用。

最重要的:kestrel 的处理路径上完全 async,没有阻塞!

实验方法

使用 DotNet 的 Kestrel 库开发一个 http 1.1 的 echo 服务器(请求后,把请求头作为输出)

使用了自定义的 metrics 统计方式

往 stdout 输出了 json 格式的请求流水日志

编译为 linux 下的二进制程序

编译参数如下:

dotnet publish $(PROJECT) -c Release -r linux-x64 -p:PublishAot=true --self-contained true -o $(PUBLISH_DIR)

在基础镜像 mcr.microsoft.com/dotnet/aspnet:8.0 中运行

docker 运行时绑定到固定的 cpu 上:

使用 4 个 cpu 核

docker run \

-d \

--name=kestrel_exp_0 \

--rm \

--cpuset-cpus="8,9,10,11" \

-m 1G \

-p 8081:8081 \

kestrel-server:latest \

/app/KestrelServer -addr=0.0.0.0:8081 -threadpool.min=4 -threadpool.max=4

关键实验代码如下:

if (minThreads > 0)

{

ThreadPool.SetMinThreads(minThreads, minThreads);

}

if (maxThreads > 0)

{

ThreadPool.SetMaxThreads(maxThreads, maxThreads);

}

实验数据:

qps CPU

Threadpool.MaxThread = 核数 88594.4 / core / s 360%

Threadpool.MaxThread 不限制 87164.7 / core / s 360%

Threadpool.MaxThread = 核数 / 2 58645.8 / core / s 215.70%

Threadpool.MaxThread = 核数 * 2 81888.8 / core / s 315%

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2025/12/15 15:56:16

电科金仓 KES Oracle 迁移避坑:核心问题排查与解决

电科金仓 KES Oracle 迁移避坑:核心问题排查与解决一、连接KES报“OCI-21500”?先查这4个关键点1.1 问题现象1.2 底层原因1.3 排查思路:按这个流程走,少走弯路1.4 实操解决:一步步来,稳准狠二、PL/SQL匿名块…

作者头像 李华
网站建设 2026/1/11 18:00:51

重学计算机基础015:除法运算的底层逻辑——除法是乘法的逆运算?实则是移位+累减的全加器复用

上一章我们搞懂了乘法运算的核心:通过“移位累加”把复杂乘法拆解为多次加法,最终靠全加器完成运算。顺着运算体系的脉络,我们自然会触及最后一个基础运算——除法。提到除法,很多人会先想到“乘法的逆运算”,但从计算…

作者头像 李华
网站建设 2025/12/15 15:53:38

AutoGPT远程管理界面搭建教程

AutoGPT远程管理界面搭建教程 在企业智能化转型的浪潮中,越来越多团队开始尝试部署自主AI代理来处理复杂任务。然而现实往往令人沮丧:一个功能强大的AutoGPT实例,却只能通过SSH连接到服务器、盯着满屏滚动的日志去“猜”它到底干了什么——这…

作者头像 李华
网站建设 2025/12/18 7:18:37

毕设分享 stm32 wifi远程可视化与农业灌溉系统(源码+硬件+论文)

文章目录 0 前言1 主要功能2 硬件设计(原理图)3 核心软件设计4 实现效果5 最后 0 前言 🔥 这两年开始毕业设计和毕业答辩的要求和难度不断提升,传统的毕设题目缺少创新和亮点,往往达不到毕业答辩的要求,这两年不断有学弟学妹告诉…

作者头像 李华
网站建设 2026/1/9 6:14:56

FICO 校验与替代技术点

GB01 - 允许替代的字段表 存储了所有允许被替代的字段列表业务场景:在一次做凭证行项目替代时,做了工厂字段的替代,但是始终不生效,查阅资料发现不是所有BSEG表中字段都允许做替代,需要调整配置表:GB01先决…

作者头像 李华