在ASP.NET应用中实施负载均衡的核心方法是通过配置网络设备或软件,将传入的HTTP/HTTPS请求智能地分发到后端运行相同应用程序的多个服务器(Web Farm)上,最常见的实现方式包括硬件负载均衡器(F5, Citrix ADC)、软件负载均衡器(Nginx, HAProxy)以及基于Windows Server的解决方案(如IIS ARR + URL Rewrite),核心设置步骤涉及配置负载均衡器本身、调整Web服务器(IIS)设置以及确保应用程序支持无状态或正确处理会话状态。

负载均衡器基础配置
-
定义服务器池(Server Farm / Backend Pool)
- 在负载均衡器管理界面中,创建一个新的服务器池(命名如
ASPNet_WebFarm)。 - 将运行ASP.NET应用程序的所有后端Web服务器(如
WebServer1:80,WebServer2:80,WebServer3:80)添加为该池的成员。 - 配置健康检查(Health Probe):这是至关重要的一步,负载均衡器需要定期(例如每5-10秒)向每台服务器发送一个HTTP(S)请求(如
GET /healthcheck.aspx或GET /),以确认其是否在线并能正常响应,只有健康的服务器才会接收流量,确保你的应用有一个轻量级、快速响应的健康检查端点。
- 在负载均衡器管理界面中,创建一个新的服务器池(命名如
-
配置虚拟服务器(Virtual Server / Listener)
- 创建一个虚拟服务器(VIP – Virtual IP),它代表应用程序对外的入口点(如
public-vip:80或public-vip:443)。 - 绑定前端IP地址、端口(80/HTTP 或 443/HTTPS)以及协议。
- 将该虚拟服务器关联到之前创建的服务器池(
ASPNet_WebFarm)。 - 配置负载均衡算法:
- 轮询(Round Robin):依次分发请求(最简单)。
- 最少连接数(Least Connections):将新请求发给当前连接数最少的服务器(更均衡)。
- 源IP哈希(Source IP Hash):基于客户端IP将请求固定到特定服务器(常用于解决会话问题,但非最优解)。
- 加权算法(Weighted):为性能不同的服务器分配不同权重。
- 创建一个虚拟服务器(VIP – Virtual IP),它代表应用程序对外的入口点(如
-
SSL终止(可选但推荐)
- 如果使用HTTPS,强烈建议在负载均衡器上配置SSL终止,这意味着负载均衡器负责处理SSL/TLS加解密,然后将明文的HTTP请求转发给后端Web服务器。
- 优点:减轻Web服务器CPU负担(加解密开销大),简化后端服务器证书管理。
- 在负载均衡器上安装并绑定你的公网SSL证书。
- 配置后端连接为HTTP(负载均衡器到Web服务器),或使用内部私有证书进行二次加密(较少见)。
IIS (Web服务器) 关键配置
-
启用ARR(Application Request Routing)与 URL Rewrite (仅当使用IIS ARR作为负载均衡器时)
- 在IIS管理器中安装“Application Request Routing”和“URL Rewrite”模块。
- 打开ARR配置:在服务器级别或站点级别,启用代理功能,并配置ARR指向你的服务器池(如果使用IIS ARR做LB)。
- 创建入站规则:使用URL Rewrite模块创建规则,将所有请求路由到ARR定义的服务器农场,规则模式通常为 。
-
配置服务器标识(推荐)

- 在每台Web服务器的IIS中,为托管ASP.NET应用的站点设置唯一的“服务器名称”(在站点绑定 -> 主机名 中设置,如
webserver1.internal,webserver2.internal),这有助于在日志和错误信息中清晰识别请求实际由哪台服务器处理。
- 在每台Web服务器的IIS中,为托管ASP.NET应用的站点设置唯一的“服务器名称”(在站点绑定 -> 主机名 中设置,如
-
共享配置(可选但推荐用于一致性)
- 使用IIS的“共享配置”功能,将
applicationHost.config和配置加密密钥集中存储在文件共享或Azure文件存储上,确保所有Web服务器都指向此共享配置。 - 优点:保证所有服务器的IIS站点、应用程序池、绑定等配置完全一致,简化管理。
- 使用IIS的“共享配置”功能,将
ASP.NET 应用程序关键调整
负载均衡的核心挑战是状态管理,默认的In-Proc会话状态在Web Farm中会失效。
-
会话状态外部化(State Server 或 SQL Server)
- ASP.NET State Service (Out-of-Proc):
- 在专用服务器上运行
aspnet_state.exe服务(通常Windows Server自带)。 - 在Web.config中配置:
<system.web> <sessionState mode="StateServer" stateConnectionString="tcpip=StateServerName:42424" cookieless="false" timeout="20" /> </system.web> - 优点:简单,比In-Proc更可靠,缺点:非持久化(服务重启丢失数据),性能一般,单点故障。
- 在专用服务器上运行
- SQL Server Session State:
- 运行
aspnet_regsql.exe工具(在.NET Framework目录下)创建会话状态数据库(ASPState)。 - 在Web.config中配置:
<system.web> <sessionState mode="SQLServer" sqlConnectionString="Data Source=YourDBServer;Initial Catalog=ASPState;User Id=...;Password=..." allowCustomSqlDatabase="true" cookieless="false" timeout="20" /> </system.web> - 优点:持久化,可扩展,高可用(配合SQL集群/AlwaysOn),缺点:数据库成为性能瓶颈点,增加数据库开销。
- 运行
- 分布式缓存(强烈推荐 – Redis, NCache):
- 使用如Redis或NCache等高性能、分布式内存缓存存储会话。
- 安装相应的Session State Provider NuGet包(如
Microsoft.Web.RedisSessionStateProvider)。 - 在Web.config中配置连接字符串和提供程序:
<system.web> <sessionState mode="Custom" customProvider="MyRedisSessionProvider"> <providers> <add name="MyRedisSessionProvider" type="Microsoft.Web.Redis.RedisSessionStateProvider" connectionString="YourRedisConnectionString" applicationName="YourAppName"/> </providers> </sessionState> </system.web> - 优点:性能极佳,高可用,可扩展性强,低延迟,是现代ASP.NET应用的首选方案。
- ASP.NET State Service (Out-of-Proc):
-
文件上传与共享存储
- 如果应用涉及用户上传文件,绝不能将文件只保存在单台Web服务器的本地磁盘上,必须使用共享存储:
- 网络文件共享(SMB/NFS)
- 云存储(Azure Blob Storage, AWS S3)
- 分布式文件系统(DFS)
- 确保所有Web服务器对共享存储具有读写权限,应用代码需将上传的文件保存到共享路径或直接上传到云存储。
- 如果应用涉及用户上传文件,绝不能将文件只保存在单台Web服务器的本地磁盘上,必须使用共享存储:
-
处理静态内容
- 对于大量静态资源(图片、CSS、JS),考虑使用CDN(内容分发网络)进行分发,减轻Web服务器和负载均衡器压力,并提升全球访问速度。
- 确保静态资源的URL在CDN上配置正确。
-
确保无状态设计(理想目标)

- 尽可能将应用程序设计为无状态(Stateless),将会话数据最小化或完全避免使用服务器端会话(Session),转而使用客户端令牌(如JWT)或将少量必要状态存储在加密的Cookie中(注意安全性和大小限制)。
- 无状态应用是水平扩展性最佳、最易负载均衡的。
粘性会话(会话保持) – 谨慎使用
- 原理: 负载均衡器通过Cookie(或源IP)将特定用户的后续请求始终路由到之前处理过其请求的同一台服务器,这可以规避会话状态共享问题。
- 实现: 在负载均衡器配置中启用“持久性”(Persistence)或“粘性会话”(Sticky Session),通常基于负载均衡器注入的Cookie(如
ARRAffinityin Azure App Gateway/ARR,JSESSIONIDin some LBs)。 - 缺点:
- 破坏了负载均衡的随机性/均衡性,可能导致服务器负载不均。
- 目标服务器故障时,用户会话会丢失(即使会话状态外部化,因为未处理的请求也丢失了)。
- 增加负载均衡器复杂度。
- 建议: 优先采用外部化会话状态(特别是Redis)来实现真正的无状态后端,仅在外部化方案不可行或迁移过渡期,且能接受其缺点时才考虑粘性会话。
健康检查与故障转移
- 确保负载均衡器的健康检查配置正确指向应用的有效健康检查端点。
- 健康检查端点应快速响应(200 OK),并能反映应用核心依赖(如数据库连接)是否正常,避免检查过于复杂的逻辑。
- 负载均衡器检测到服务器不健康时,会自动将其从池中移除,停止向其发送流量。
- 当服务器恢复健康后,负载均衡器会自动将其重新加入池中。
总结与最佳实践
成功设置ASP.NET负载均衡是一个系统工程,涉及网络层、服务器层和应用层:
- 选择合适的负载均衡器: 根据规模、预算、功能需求选择硬件、软件或云服务LB。
- 严格配置健康检查: 这是负载均衡稳定运行的基石。
- 彻底解决会话状态问题: 强烈推荐使用分布式缓存(Redis)存储会话状态,这是性能、扩展性和可靠性的最佳平衡,其次是SQL Server方案,避免使用State Server或In-Proc。
- 处理文件共享: 使用网络共享、DFS或云存储处理用户上传文件。
- 拥抱无状态设计: 尽量减少对服务器端会话的依赖。
- 谨慎使用粘性会话: 仅在必要且理解其局限性时使用。
- 监控与日志: 密切监控负载均衡器、Web服务器、数据库/缓存性能指标和错误日志,集中式日志(如ELK, Application Insights)至关重要。
- 测试: 在生产环境部署前,务必在预生产环境中全面测试负载均衡配置、故障转移、会话状态共享和文件上传功能。
通过遵循这些步骤和最佳实践,你可以构建一个高可用、可扩展且性能优异的ASP.NET应用架构,从容应对用户量增长和流量高峰。
您在配置ASP.NET负载均衡时,遇到最棘手的挑战是什么?是会话状态共享、文件存储,还是特定的负载均衡器配置问题?欢迎在评论区分享您的经验和解决方案!
原创文章,作者:世雄 - 原生数据库架构专家,如若转载,请注明出处:https://idctop.com/article/14280.html