2

我有一个应用程序调度多个任务,这些任务正在调用不同的 Web 服务,一些相同的 Web 服务但不同的方法。每个任务都在一个时间间隔内执行,每个任务都在自己的线程中运行。为了获得对 web 服务的引用,我有一个 wsdl.exe 生成的代理类,它在每个任务中被实例化并且总是被处理掉。但是,在运行应用程序时,任务实际上是在服务请求中相互等待,Web 服务在完成处理来自任务 x 的请求之前不会处理来自任务 y 的服务请求(我可以看到这一点,因为来自任务 x 的服务调用可能需要5 分钟和任务 y 100 毫秒,但是如果 y 在 x 运行时开始,它会在 x 完成后 100 毫秒完成)。

这是来自任务的代码(在自己的线程中运行):

public class TaskX : TaskWrapper
{
    public TaskX(Guid id, string name, EventQueue eventqueue)
        : base(id, name, eventqueue)
    {
    }

    protected override void DoTask()
    {

        try
        {
            var factory = new ServiceReferenceFactory();
            using (var reference = factory.GetServiceReference())
            {

                bool result;
                bool isSpecified;

                reference.Run(out result, out isSpecified);
            }
        }
    }
}

这是上面提到的工厂方法的代码:

public ProxyClassService GetServiceReference()
    {
                    var refer = new ProxyClassServiceNamespace.ProxyClassService();
                    refer.Timeout = 1000 * 60 * 60;

                    return refer;
    }

有谁知道我为什么会遇到这种行为?

编辑:

这是我将 [ServiceBehavior(InstanceContextMode = InstanceContextMode.PerCall)] 添加到我的 wcf 服务的实现之后的一些任务日志。我没有对在 Visual Studio 2008 中创建的 wcf 服务进行任何配置更改。

15:02 - 任务开始:TaskXWithInternalException

15:02 - 任务开始:TaskYQuickOne

15:02 - 任务结束:TaskYQuickOne 任务经过时间:00:00:00.1214762

15:02 - 任务开始:TaskZSlowOne

15:03 - 任务开始:TaskXWithInternalException

15:03 - 任务开始:TaskYQuickOne

15:05 - 任务结束:TaskZSlowOne 任务经过时间:00:03:11.6510947

15:05 - 任务结束:TaskYQuickOne 任务经过时间:00:02:09.7311905

15:06 - 任务开始:TaskYQuickOne

15:06 - 任务结束:TaskYQuickOne 任务经过时间:00:00:00.0546980

4

1 回答 1

2

这可能与WCF 服务上的并发/实例化设置有关。

如果您的所有调用都转到同一个服务实例(例如InstanceContextMode = PerSession or Single),那么通常您需要确保已将 设置ConcurrencyModeMultiple,否则调用将以序列化方式进行服务。

你能告诉我们更多关于 WCF 服务(不是客户端)是如何设置的吗?

于 2011-05-13T12:20:19.343 回答