WCF - 回拨给客户端(双工?)

时间:2010-04-29 06:01:55

标签: .net wcf .net-3.5 wcf-binding

我对选择什么解决方案有疑问.. 我有一台运行服务的服务器,可以从网站接收订单。 对于此服务器,多个客户端(远程计算机)以某种方式连接。

我真的想使用WCF进行所有通信,但不确定是否可行。

我不想在其路由器中配置所有客户端防火墙设置,因此客户端必须连接到服务器。

但是当在服务器上收到订单时,应该将其转移到特定的客户端。

一种解决方案可能是让客户端使用双工绑定进行连接,但它必须以某种方式保持连接处于活动状态才能从服务器接收数据......这是一个很好的方法吗?

通常连接超时,可能是有充分理由的......

任何人都能对这个问题有所了解。

对于任何建议都很多: - )

最诚挚的问候 SørenMüller

2 个答案:

答案 0 :(得分:5)

这正是双工绑定的设计目标。您拥有的两个最佳选择是NetTcpBindingPollingDuplexBinding

前者使用的TCP协议可能不适合您的客户,如果他们不在您的网络上。但是,它确实允许通过客户端启动的套接字进行双向通信。因此客户端不需要能够接受传入的连接。我最近在一个项目上使用它,它运行得很好。它也非常敏感。当客户端应用程序关闭时,服务器上的会话立即结束。

第二个选项PollingDuplexBinding包含在Silverlight SDK中。它使用客户端发起的“长”HTTP请求。请求等待需要发送到客户端的消息,当它们到达时,客户端请求返回。然后,客户端将新的HTTP请求发送回服务器。换句话说,客户端始终具有挂起的HTTP请求。这适用于防火墙,应该在您处理Internet客户端时使用。但是,我发现这不像NetTcpBinding那样响应。我可能一直在做错事,但似乎尝试向已放弃的客户端会话发送回调需要一段时间来“超时”。


以下是我最近项目中使用NetTcpBinding进行双工通信的配置文件示例。请注意,除了对服务限制的一些调整之外,我几乎使用此绑定的默认值。但there's all kinds of things你可以调整,如receiveTimeout,inactivityTimeout等

<configuration>
    <system.serviceModel>

        <serviceHostingEnvironment multipleSiteBindingsEnabled="true" />

        <behaviors>
            <serviceBehaviors>
                <behavior name="">
                    <serviceMetadata httpGetEnabled="true" />
                    <serviceDebug includeExceptionDetailInFaults="true" />
                    <serviceThrottling maxConcurrentCalls="65535" 
                                       maxConcurrentSessions="65535" 
                                       maxConcurrentInstances="65535" />
                </behavior>
            </serviceBehaviors>
        </behaviors>

        <bindings>
            <netTcpBinding>
                <binding maxConnections="65535">
                    <security mode="None" />
                </binding>
            </netTcpBinding>
        </bindings>

        <services>
            <service name="BroadcastService">
                <endpoint address="" binding="netTcpBinding" contract="BroadcastService" />
            </service>
        </services>

    </system.serviceModel>
</configuration>

[ServiceContract( CallbackContract = typeof( IBroadcastCallback ) )]
[ServiceBehavior( ConcurrencyMode = ConcurrencyMode.Multiple )]
public class BroadcastService : IDisposable
{

    [OperationContract(IsInitiating=true)]
    public long Subscribe( Guid clientID )
    {
        // clients call this to initiate the session
    }

    [OperationContract(IsOneWay = true)]
    public void Publish( BroadcastMessage message )
    {
        // client calls this to broadcast a message to
        // all other subscribed clients via callback
    }

}

[ServiceContract( Name = "BroadcastCallback" )]
public interface IBroadcastCallback
{

    [OperationContract( IsOneWay = true, AsyncPattern = true )]
    IAsyncResult BeginBroadcast(BroadcastMessage Message, AsyncCallback callback, object state);

    void EndBroadcast( IAsyncResult asyncResult );

}   // interface

答案 1 :(得分:0)

我已经做了一些研究来选择双工通信的最佳方法。我提出了以下解决方案。

使用wsDualhttpbinding的WCF服务:
如果服务器和这种方法很好 客户都有公共IP。客户端和服务器使用http进行通信,因此没有防火墙限制但是,当启动双工通信时,客户端必须与服务器建立单独的连接,以便客户端也需要具有公共IP。

使用NetTcpbinding的WCF服务:
此方法使用TCP协议进行双工通信,如果您使用WCF,这是可行的方法。唯一不利的是一些防火墙阻塞TCP端口。在这种情况下,您需要防火墙例外。

使用网络套接字的WCF NetHttpBinding:
这种方法使用http协议,因此没有防火墙限制。在此方法中,客户端启动http连接,然后升级到TCP连接以进行双工通信。目前只赢8或赢得2012操作系统支持WCF网络套接字。所有服务器和客户都是风8或赢2013年这是要走的路。

使用第三方框架的Web套接字(信号R,Xsocket.net):
这不是WCF,但您仍然可以实现其他Web服务或Windows服务应用程序。使用http协议,然后升级到TCP进行双工通信