1) 利用mq做限流, 合理的入库时间
2) 减轻数据库的压力
3) 保证项目的稳定性
【生产场景】
多个用户同时excel导入数据, 采用多线程保存数据, 对数据库压力过大,
把数据直接放到mq里
/**
* 监听核验身份队列
*
* @param tag
* @param msg
* @param channel
* @throws IOException
*/
@RabbitHandler
@RabbitListener(queues = Constant.QueueName.CHECK_CARD_NO)
public void receiverCardNo(@Header("amqp_deliveryTag") long tag, String msg, Channel channel) throws IOException {
try {
logger.info("核验身份队列:{},队列内容:{}", Constant.QueueName.CHECK_CARD_NO, msg);
queueService.receiverCardNo(msg);
} catch (Exception ex) {
throw new CvsException(ResCode.FAIL_MQ_ERROR, ex);
} finally {
channel.basicAck(tag, false);
}
}
手动配置为35,同时启动35个线程处理入库操作,大小根据cpu数配置就可以
@RabbitListener(queues = Constant.QueueName.CHECK_CARD_NO, concurrency = "35")
默认分支, 因该是2
@RabbitListener(queues = Constant.QueueName.CHECK_CARD_NO)
**粗体** _斜体_ [链接](http://example.com) `代码` - 列表 > 引用
。你还可以使用@
来通知其他用户。