繁体   English   中英

Azure QueueClient MaxConcurrentCalls 不起作用

[英]Azure QueueClient MaxConcurrentCalls Not Working

我的任务是提高处理来自队列的消息的工作角色的性能。

它使用queueclient.OnMessage模型, MaxConcurrentCalls设置为 1。

在处理过程中,thread.sleep 会持续 5 分钟,这会影响整体性能,即如果队列中有 10 条消息,则在处理第 10 条消息之前至少需要 45 分钟

我想如果我将 MaxConcurrentCalls 更改为 5,那么它应该并行处理 5 条消息并将等待时间减少 25 分钟,但这不起作用:(

我也尝试将 OnMessageAsync 与 MaxConcurrentCalls 一起使用,但没有运气。 下面是我试过的片段,

.OnMessageAsync( async (brokeredMessage) =>
{                
    bool shouldAbandon = false;
    try
    {
        logger.Debug("Rcvd:" + brokeredMessage.SequenceNumber);
        SomeTask(brokeredMessage);
        await brokeredMessage.CompleteAsync();
    }
    catch (Exception ex)
    {
        logger.Error(String.Format("An Error occured {0}", ex.ToString()));
        shouldAbandon = true;
    }
    if (shouldAbandon)
    {
        await brokeredMessage.AbandonAsync();
    }   
}, new OnMessageOptions { AutoComplete = false, MaxConcurrentCalls = 10 });

private void SomeTask(BrokeredMessage bm)
{            
    logger.Debug("id: " + bm.MessageId + "on thread: " + Thread.CurrentThread.ManagedThreadId);
    Thread.Sleep(30 * 1000);
    logger.Debug("seq: " + bm.SequenceNumber);
    logger.Debug("body: " + bm.GetBody<string>());
}

我能想到的最后一个选项是在 OnMessage 事件上启动一个新任务。 有几件事我需要处理(确保已完成的任务从集合/主线程中删除,并从 BrokeredMessage 传递一个对象,因为 BrokeredMessage 已被释放,因此我无法在任务线程上使用)并且我有理智也对其进行了测试,但我不相信这是最好的解决方案。

SomeTask实现替换为以下内容:

async Task SomeTask(BrokeredMessage bm)
{
     logger.Debug("id: " + bm.MessageId + "on thread: " + Thread.CurrentThread.ManagedThreadId);
     await Task.Delay(30 * 1000).ConfigureAwait(false);
     logger.Debug("seq: " + bm.SequenceNumber);
     logger.Debug("body: " + bm.GetBody<string>());
}

Thread.Sleep在同一个线程上与async混合时(在你的情况下),它会导致线程“停止”所有任务。 由于没有 UI 工作,更喜欢在异步操作上使用.ConfigureAwait(false)以允许调度程序管理要执行的线程。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM