1、使用场景
- 1在我们系统中有一个
订单催付
的场景,我们的客户在天猫下的订单,淘宝会及时将订单推送给我们,如果在用户设定的时间内未付款那么就会给用户推送一条短信提醒
,很简单的一个功能对吧; - 2.但是上述情况,tmall商家对我们来说,肯定是要分大客户和小客户的对吧,比如像苹果,小米这样大商家一年起码能给我们创造很大的利润,所以理应当然,他们的订单必须得到优先处理,而
曾经我们的后端系统是使用 redis 来存放的定时轮询
,大家都知道 redis 只能用 List 做一个简简单单的消息队列
。 - 3.redis并不能实现一个优先级的场景,所以后来,当
订单量大了后采用 RabbitMQ 进行改造和优化,如果发现是大客户的订单给一个相对比较高的优先级
,否则就是默认优先级。
2、优先级的添加方法;
Map<String, Object> params = new HashMap();
params.put("x-max-priority", 10);
channel.queueDeclare("hello", true, false, false, params);
AMQP.BasicProperties properties = new
AMQP.BasicProperties().builder().priority(5).build();
- d.注意事项
- 要
让队列实现优先级需要做的事情有如下事情
:
- 1.队列需要设置为优先级队列
- 2.消息需要设置消息的优先级
- 3.消费者需要等待消息已经发送到队列中才去消费因为,这样才有机会对消息进行排序
3、实战