一、生产者可靠性
(1)生产者重连(不建议使用)
data:image/s3,"s3://crabby-images/3f8ae/3f8aedbfee52a8fd82737a63d78ea10156461aeb" alt=""
logging:
pattern:
dateformat: MM-dd HH:mm:ss:SSS
spring:
rabbitmq:
virtual-host: /hamll
port: 5672
host: 192.168.92.136
username: hmall
password: 123
listener:
simple:
prefetch: 1
connection-timeout: 1s
template:
retry:
enabled: true
initial-interval: 1000ms
multiplier: 1
max-attempts: 3
(2)生产者确认
data:image/s3,"s3://crabby-images/40903/409039f8a1c1909d6b3f20e43cba10d065e1a00f" alt=""
data:image/s3,"s3://crabby-images/821dc/821dca253e9e87ddd9f771ec34493accd7606d86" alt=""
引入日志依赖
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-logging</artifactId>
</dependency>
二、MQ持久化
(1)持久化介绍
data:image/s3,"s3://crabby-images/c84eb/c84ebe138da84a21dd30c7c0e4ead24c395d6dd9" alt=""
data:image/s3,"s3://crabby-images/59968/5996897753835cdd87896688be25e395eb024f7a" alt=""
data:image/s3,"s3://crabby-images/d1d25/d1d2537b534ba69f9e5c4b16f9625771de1c2307" alt=""
发送100万条消息给队列,需要先在application.yml中取消生产者确认
publisher-confirm-type: none
publisher-returns: false
没有持久化的测试用例,会出行阻塞的状态:
data:image/s3,"s3://crabby-images/dc331/dc33158f4d70bbef4d2c426cf304c5170c6fb1d2" alt=""
改为持久化后的测试用例:
data:image/s3,"s3://crabby-images/23aaa/23aaaf300ab363879aff4087572c50d0040cae3f" alt=""
(2)最好的持久化方式Lazy Queue
data:image/s3,"s3://crabby-images/44296/442963c3ff0bfec759698e0911c6ce68af844494" alt=""
data:image/s3,"s3://crabby-images/798e9/798e9cc9f579b1b50675b461214b87ce17abcef4" alt=""
三、消息可靠性
(1)消费者确认
data:image/s3,"s3://crabby-images/8d814/8d814600b736422df1960b11ed078d578d9e633f" alt=""
使用auto自动模式
data:image/s3,"s3://crabby-images/6be11/6be11fdf946c99c748ce798196b942102c703c5a" alt=""
data:image/s3,"s3://crabby-images/cba33/cba33a8463054fb59b64e0a8639019d2c823029c" alt=""
(2)失败重试机制
data:image/s3,"s3://crabby-images/6ef92/6ef92c3ed85deecbf4c35e1cde484f33d32df400" alt=""
data:image/s3,"s3://crabby-images/f6044/f6044b1c131053cb1ff3fc663f55ab2650b3c12e" alt=""
(3)业务幂等性
data:image/s3,"s3://crabby-images/b3429/b34294ba81410706fec0555ee85fc087425345c5" alt=""
四、延迟消息
data:image/s3,"s3://crabby-images/8b70b/8b70b090764eff97982eed025d1d0404da5ee645" alt=""
(1)死信交换机
注意:创建的simple.queue需要Add Dead letter exchange,其他都跟之前创建的操作差不多
data:image/s3,"s3://crabby-images/4d183/4d183d459713df5d8bdf79a456da0f9eed4c318a" alt=""
监听
@RabbitListener(queues = "dlx.queue")
public void listenDlxQueue(String msg){
log.info("dlx.queue消费者收到消息:"+msg);
}
测试用例
@Test
void testSendTTLMessage(){
rabbitTemplate.convertAndSend("simple.direct", "hi", "hello", new MessagePostProcessor() {
@Override
public Message postProcessMessage(Message message) throws AmqpException {
message.getMessageProperties().setExpiration("10000");
return message;
}
});
log.info("消息发送成功!");
}
(2)延迟消息插件
data:image/s3,"s3://crabby-images/c8ac2/c8ac22806cc436d5cc124537e6f19095ea4006b1" alt=""
data:image/s3,"s3://crabby-images/cd6c1/cd6c1dbc76dffb0eb1cf79f413443a670de44313" alt=""
(3)取消订单
data:image/s3,"s3://crabby-images/61804/6180470f5ca9d169eb23b77ce1baa789c0589d72" alt=""