说说这两种的区别,各自适合什么场景?
用线程池ExecutorService异步处理:我理解ExecutorService
其实也是内部使用了队列(如LinkedBlockingQueue
),所以从设计上,其实和使用中间价的消息队列是差不多一致的。只是这里应用服务器既充当生产者又充当消费者,也是消息队列中间价的实现者。这种应该适合非分布式的架构,比如简单的只有一台服务器。
使用消息队列:消息队列(指activeMQ,rabbitMQ,kafaKa,Redis等)因为一般都是中间件,部署在其他机器,需要一定的网络消耗。
本着解耦的目的,使用后者更合理,因为应用服务器一般内存也不会太多,队列长度不易太长。让应用服务器只处理逻辑比较合理。适合分布式架构。
1.使用JDK
提供的异步框架ExecutorService
。
threadPool.execute(new Runnable() {
@Override
public void run() {
// 这里是异步处理的,比较耗时的逻辑,比如数据库操作
userService.setDefaultAddressId(user.getUserId(), bookingForm.getAddressId());
}
});
2.将消息发送到消息队列,如使用redis
的List
简单实现,然后后台线程消费消息。
// 生产消息
redisTemplate.opsForList().leftPush(LOG_MQ_KEY, JsonUtil.beanToJson(httpRequestLog));
// 后台线程异步消费消息
String popValue = redisTemplate.opsForList().rightPopAndLeftPush(LOG_MQ_KEY, TEMP_LOG_MQ_KEY);
白衣染霜花
相关分类