加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

c# – 为什么BrokeredMessage.RenewLock()只更新锁几秒钟?

发布时间:2020-12-15 17:48:42 所属栏目:百科 来源:网络整理
导读:我有一个BrokeredMessageContext类,它使用Timer定期检查并更新BrokeredMessage实例上的锁,以防处理此消息的进程运行的时间超过预期.它通过调用BrokeredMessage实例上的RenewLock()方法来更新锁. 我希望这个调用给我一个与原始锁(MSDN states that “You can
我有一个BrokeredMessageContext类,它使用Timer定期检查并更新BrokeredMessage实例上的锁,以防处理此消息的进程运行的时间超过预期.它通过调用BrokeredMessage实例上的RenewLock()方法来更新锁.

我希望这个调用给我一个与原始锁(MSDN states that “You can renew locks for the same duration as the entity lock timeout,and there is no maximum duration for a lock renewal.”)具有相同超时的新锁,但是在调试时,锁定超时似乎增加了“任意”10-15秒.我在BrokeredMessage实例上设置了一个监视器,我可以看到每次调用RenewLock()时,LockedUntilUtc属性都会增加10-15秒.

有谁知道为什么会这样?可以做任何事情来延长锁定时间吗?

编辑:

Mike的回答如下,是正确的.事实上,我发现事实上,我试图从开始就每隔十秒更新一次锁,即使我的代码是为了在锁定到期之前的20秒之前更新锁定.这一切都归结为一个时间比较问题,以及我机器上的时间错误的事实(它提前了将近一分钟). D’哦!

解决方法

当您调用RenewLock时,它会重置消息被队列或订阅上设置的LockDuration锁定的时间.如果正在执行续订的类具有每10-15秒触发一次的计时器,那么您看到的行为是正确的.

例:
我有一个锁定持续时间为1分钟的队列(默认值).
我在UTC时间凌晨1点20分收到消息,因此LockedUntilUtc应该在UTC上午1:21阅读.
如果进入处理10秒钟我呼叫Renew锁定,呼叫将在凌晨1:20:10触发,因此LockedUntilUtc将变为1:21.10 AM.

它将锁定持续时间值添加到服务器的当前时间,而不是之前的LockedUntilUtc值.这会延长您对邮件的锁定时间.

这个答案假定您经常在Timer上触发触发器而不是等待接近实际的锁定超时.如果您想要更精确,可以将计时器设置为在锁定设置为到期之前大约10-20秒,然后执行续订锁定.

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读