IHttpClientFactory通过复用HttpMessageHandler池解决端口耗尽问题,避免每次new HttpClient()导致TIME_WAIT堆积;它按命名分组复用handler并自动轮换过期实例,客户端实例短期创建但底层handler长期复用、健康检查。为什么直接 new HttpClient() 会耗尽端口因为 HttpClient 是线程安全、设计为长期复用的对象,但很多人误把它当一次性工具------每次请求都 new HttpClient() 再 .Dispose(),导致底层 Socket 连接未及时释放,堆积在 TIME_WAIT 状态,几分钟内就可能占满本地端口(尤其高并发时)。Windows 默认 65535 个端口,实际可用远少于这个数。常见错误现象:SocketException: Only one usage of each socket address is normally permitted 或响应变慢、超时陡增。别在方法里 new HttpClient(),哪怕加了 using别把 HttpClient 声明为 static 字段手动单例------它不自动处理 DNS 变更和连接过期别给每个 API 封装类配一个独立的 HttpClient 实例(比如 UserClient、OrderClient 各持一个)IHttpClientFactory 是怎么解决这个问题的IHttpClientFactory 不是"造 HttpClient 的工厂",而是管理 HttpClient 实例生命周期 + 复用底层 HttpMessageHandler 的协调器。它背后维护一个 HttpMessageHandler 池,按命名分组复用 handler,同时自动轮换过期 handler(比如 DNS 变更后重建连接)。关键点:你拿到的 HttpClient 实例本身是短期的(每次 CreateClient() 都新对象),但它内部的 Handler 是共享、复用、带健康检查的。注册方式必须在 Program.cs(.NET 6+)或 Startup.ConfigureServices 里调用 services.AddHttpClient()命名客户端(如 AddHttpClient("github"))适合不同 BaseAddress / Handler 配置的场景类型化客户端(AddHttpClient<GitHubService>())适合封装业务逻辑,构造函数注入 HttpClient不要自己 Dispose() 工厂创建的 HttpClient------它由工厂托管释放配置超时、重试、日志这些事该写在哪所有策略配置必须落在 HttpMessageHandler 层或工厂注册阶段,而不是对 HttpClient 实例赋值------因为实例随时被丢弃,改了也白改。 AI Code Reviewer AI自动审核代码
C#怎么实现HttpClient最佳实践 C#如何用IHttpClientFactory管理HttpClient避免端口耗尽【网络】
m0_609160492026-05-09 9:42
相关推荐
程序猿阿伟19 分钟前
《一套完整方法论:搞定图形应用的Docker镜像优化》二等饼干~za89866828 分钟前
geo优化源码开发搭建技术分享隐于花海,等待花开35 分钟前
16.Python 常用第三方库概览 深度解析我材不敲代码36 分钟前
Python 函数核心:位置参数与关键字参数详解风落无尘38 分钟前
第十一章《对齐与安全》 完整学习资料Kratzdisteln40 分钟前
【无标题】hakesashou1 小时前
python文件操作需要导入模块吗数据库小学妹1 小时前
HTAP混合负载架构:如何用一个数据库同时搞定交易和分析wuxinyan1231 小时前
工业级大模型学习之路029:解决双智能体调用数据库报错问题SunnyDays10111 小时前
Python操作Excel批注:从基础添加到高级自定义的完整指南