负载平衡
增加 Windows Communication Foundation (WCF) 应用程序容量的方法之一是通过将它们部署到负载均衡的服务器场来扩展它们。 使用标准的负载均衡技术,包括诸如 Windows 网络负载均衡这样的软件负载均衡器以及基于硬件的负载均衡设备,可以使 WCF 应用程序实现负载均衡。
以下各节讨论对使用各种系统提供的绑定生成的 WCF 应用程序实现负载均衡时的注意事项。
基本 HTTP 绑定的负载平衡
从负载均衡的角度看,使用 BasicHttpBinding 进行通信的 WCF 应用程序与其他普通类型的 HTTP 网络流量(如静态 HTML 内容、ASP.NET 页或 ASMX Web 服务)并没有什么区别。 使用此绑定的 WCF 通道本质上是无状态的,当通道关闭时,其连接也会终止。 因此,BasicHttpBinding 可以很好地与现有的 HTTP 负载平衡技术一起使用。
默认情况下,BasicHttpBinding 会在消息中发送一个具有 Keep-Alive
值的连接 HTTP 标头,该标头可让客户端建立到支持这些客户端的服务的持续连接。 这种配置具有高的吞吐量,因为可以重新使用以前建立的连接向同一个服务器发送后续消息。 然而,重新使用连接可能导致客户端与负载平衡场中的特定服务器密切关联,从而降低循环负载平衡的效率。 如果不需要此行为,则可以使用 Keep-Alive
或用户定义的 KeepAliveEnabled 在使用 CustomBinding 属性的服务器上禁用 HTTP Binding。 下面的示例演示如何使用配置来执行该操作。
<?xml version="1.0" encoding="utf-8" ?>
<configuration>
<system.serviceModel>
<services>
<service
name="Microsoft.ServiceModel.Samples.CalculatorService"
behaviorConfiguration="CalculatorServiceBehavior">
<host>
<baseAddresses>
<add baseAddress="http://localhost:8000/servicemodelsamples/service"/>
</baseAddresses>
</host>
<!-- configure http endpoint, use base address provided by host
And the customBinding -->
<endpoint address=""
binding="customBinding"
bindingConfiguration="HttpBinding"
contract="Microsoft.ServiceModel.Samples.ICalculator" />
</service>
</services>
<bindings>
<customBinding>
<!-- Configure a CustomBinding that disables keepAliveEnabled-->
<binding name="HttpBinding" keepAliveEnabled="False"/>
</customBinding>
</bindings>
</system.serviceModel>
</configuration>
使用 .NET Framework 4 中引入的简化配置,可通过使用下面的简化配置实现相同的行为。
<?xml version="1.0" encoding="utf-8" ?>
<configuration>
<system.serviceModel>
<protocolMapping>
<add scheme="http" binding="customBinding" />
</protocolMapping>
<bindings>
<customBinding>
<!-- Configure a CustomBinding that disables keepAliveEnabled-->
<binding keepAliveEnabled="False"/>
</customBinding>
</bindings>
</system.serviceModel>
</configuration>
有关默认终结点、绑定和行为的详细信息,请参阅简化配置和 WCF 服务的简化配置。
WSHttp 绑定和 WSDualHttp 绑定的负载平衡
如果对默认的绑定配置进行一些修改,则 WSHttpBinding 和 WSDualHttpBinding 都可以使用 HTTP 负载平衡技术来实现负载平衡。
关闭安全性上下文制定或使用有状态安全会话。 通过将 WSHttpBinding 上的 EstablishSecurityContext 属性设置为
false
,可关闭安全性上下文制定。 若要使用 WSDualHttpBinding 或需要安全会话,则可以按照保证会话安全中的说明使用有状态安全会话。 有状态安全会话可使服务保持无状态,因为安全会话的所有状态都随每个请求作为保护安全令牌的一部分进行传输。 若要启用有状态安全会话,你必须使用 CustomBinding 或用户定义的 Binding,因为所需的配置设置不会在系统提供的 WSHttpBinding 和 WSDualHttpBinding 上公开。如果关闭安全性上下文制定,还需要关闭服务凭据协商。 若要将其关闭,请将 WSHttpBinding 上的 NegotiateServiceCredential 属性设置为
false
。 若要禁用服务凭据协商,你可能需要在客户端上显式指定终结点标识。不要使用可靠会话。 默认情况下此功能处于关闭状态。
使 Net.TCP 绑定实现负载平衡
可以使用 IP 层负载平衡技术实现 NetTcpBinding 的负载平衡。 不过,默认情况下,NetTcpBinding 会汇集 TCP 连接以减少连接延迟。 这是一种干扰负载平衡基本机制的优化。 用于优化 NetTcpBinding 的主配置值是租约超时,它是连接池设置的一部分。 连接池导致客户端连接与场内特定的服务器关联。 随着这些连接的生存期的增加(一个受租约超时设置控制的因素),场内不同服务器上的负载分布会变得不平衡。 结果使平均调用时间增加。 因此,在负载平衡方案中使用 NetTcpBinding 时,应考虑减少由绑定使用的默认租约超时。 虽然租约超时的最佳值取决于应用程序,但 30 秒的租约超时对于负载平衡方案不失为一个合理的始点。 有关通道租约超时和其他传输配额的详细信息,请参阅传输配额。
若要在负载平衡方案中获得最佳性能,请考虑使用 NetTcpSecurity(Transport 或 TransportWithMessageCredential)。