【问题标题】:Best Practice for WCF Service Proxy lifetime?WCF 服务代理生命周期的最佳实践?
【发布时间】:2023-03-18 07:33:02
【问题描述】:

在使用 WCF 服务时,每次使用它时创建一个新的服务实例会更好吗?还是创建一个并重新使用它更好?为什么两种方法都更好?异步代理也一样吗?

【问题讨论】:

    标签: wcf proxy service


    【解决方案1】:

    还是创建一个并重新使用它更好?

    不要开始实施您自己的池实施。这已经在框架中完成了。 WCF 代理在下面使用缓存的通道工厂。因此,创建新代理并不太昂贵(但请参阅 Guy Starbuck 关于会话和安全性的回复!)。

    还要注意,代理会在一定的空闲时间(默认为 10 分钟)后超时。

    如果您想要更明确的控制,您可以考虑直接使用 ChannelFactories 和通道,而不是“易于使用、开箱即用”的 ClientBase 代理。

    http://msdn.microsoft.com/en-us/library/ms734681.aspx

    关于这个主题的“必读”是: http://blogs.msdn.com/wenlong/archive/2007/10/27/performance-improvement-of-wcf-client-proxy-creation-and-best-practices.aspx

    【讨论】:

      【解决方案2】:

      除了 Guy Starbuck 提到的事情之外,一个关键因素是您正在使用的安全模型(结合会话要求) - 如果您不重复使用您的代理,则无法重复使用安全会话。

      这意味着客户端必须在每次调用时都验证自己的身份,这是一种浪费。

      但是,如果您决定这样做,请确保将客户端配置为不建立安全上下文(因为您永远不会使用它),这将为您节省几次往返服务器的时间: -)

      【讨论】:

        【解决方案3】:

        还要考虑的一点是通道故障。按照设计,WCF 不允许在发生未处理的异常后使用客户端代理。

        IMyContract proxy = new MyContractClient( );
        try
        {
           proxy.MyMethod( );
        }
        catch
        {}
        
        //Throws CommunicationObjectFaultedException
        proxy.MyMethod( );
        

        【讨论】:

          【解决方案4】:

          这里有一个推论,即 .NET Remoting 中的服务器激活对象(被 WCF 取代的技术之一),它有两种模式,“Single Call”(无状态)和“Singleton”(有状态)。

          您在 WCF 中采用的方法应该基于您的性能和扩展需求以及您的消费者的需求,以及服务器端设计约束。

          如果您必须在对服务的调用之间维护状态,那么您显然希望拥有一个有状态的实例,但如果您不这样做,您可能应该实现它以便它是静态的,这样应该可以更好地扩展(您可以更容易进行负载平衡等)。

          【讨论】:

          • 我相信布赖恩问的是客户端代理的重用。这与服务器端实例的生命周期无关
          • 我投反对票的原因与安德烈相同。我看不出服务器端的 InstanceManagement 与客户端代理的生命周期有什么关系。也许你能解释一下?
          • 您说的都对,看来我最初将此问题解释为与服务器生命周期有关,而不是与客户端代理有关。我将继续在此处留下我的答案作为讨论的一部分,因为它在其他人的答案中被引用。
          猜你喜欢
          • 1970-01-01
          • 1970-01-01
          • 1970-01-01
          • 1970-01-01
          • 1970-01-01
          • 1970-01-01
          • 2010-09-19
          • 1970-01-01
          • 1970-01-01
          相关资源
          最近更新 更多