设为首页 - 加入收藏 ASP站长网(Aspzz.Cn)- 科技、建站、经验、云计算、5G、大数据,站长网!
热搜: 手机 数据 公司
当前位置: 首页 > 服务器 > 安全 > 正文

一篇文了解分布式队列编程:从模型、实战到优化(9)

发布时间:2021-01-08 08:29 所属栏目:53 来源:网络整理
导读:状态机队列实施(QueueCoordinator) 接口定义 状态机队列集中管理所有请求的排重状态机,所以其操作和单个状态机一样,即enQueue和deQueuqe接口.这两个接口的实现需要识别特定请求的状态机,所以它们的入参应该是请求.

状态机队列实施(QueueCoordinator)
接口定义

状态机队列集中管理所有请求的排重状态机,所以其操作和单个状态机一样,即enQueue和deQueuqe接口.这两个接口的实现需要识别特定请求的状态机,所以它们的入参应该是请求.为了兼容不同类型的请求消息,我们采用了Java泛型编程.接口定义如下:

enQueue操作

enQueue操作过程如下:

首先,根据传入的请求key值,获取状态机,如果不存在则创建一个新的状态机,并保存在ConcurrentHashMap中.

接下来,获取线程id作为该消费者的唯一标识,并对对应状态机进行enQueue操作.

如果状态机返回值为ACCEPT或者DECLINE,返回业务层处理代码,ACCEPT意味着业务层需要处理该消息,DECLINE表示业务层可以抛弃当前消息.如果状态机返回值为Block,则该线程保持等待状态.

在某些情况下,头部请求线程可能由于异常,未能对状态机进行deQueue操作(作为组件提供方,不能假定所有的规范被使用方实施).为了避免处于阻塞状态的消费者无期限地等待,建议对状态机设置安全超时时限.超过了一定时间后,状态机强制清空头部请求,返回到业务层,业务层开始处理该请求.

代码如下:

deQueue操作

deQueue操作首先从ConcurrentHashMap获取改请求所对应的状态机,接着获取该线程的线程id,对状态机进行deQueue操作.

enQueue代码如下:

源代码

完整源代码可以在QueueCoordinator获取.链接:

https://github.com/dinglau2008/QueueCoordinator/tree/master/src

文章出处:美团点评技术团队

(编辑:ASP站长网)

网友评论
推荐文章
    热点阅读