使用多线程提高REST服务性能 异步处理rest服务

使用Runnable
使用DeferredResult
异步处理配置

异步处理

在这里插入图片描述

Callable

//		Callable<String> result = new Callable<String>() {
//			@Override
//			public String call() throws Exception {
//				logger.info("副线程开始");
//				Thread.sleep(1000);
//				logger.info("副线程返回");
//				return "success";
//			}
//		};

由主线程调用 子线程

DeferredResult

在这里插入图片描述

线程1,和线程2 是 隔离的,谁也不知道谁的存在

MockQueue

@Component
public class MockQueue {
	private String placeOrder; //提供get set
	private String completeOrder;
	private Logger logger = LoggerFactory.getLogger(getClass());
	public void setPlaceOrder(String placeOrder) throws Exception {
		new Thread(() -> {
			logger.info("接到下单请求, " + placeOrder);
			try {
				Thread.sleep(1000);
			} catch (Exception e) {
				e.printStackTrace();
			}
			this.completeOrder = placeOrder;
			logger.info("下单请求处理完毕," + placeOrder);
		}).start();
	}

DeferredResultHolder

@Component
public class DeferredResultHolder {
//提供get set
	private Map<String, DeferredResult<String>> map = new HashMap<String, DeferredResult<String>>();
}

QueueListener

@Component
public class QueueListener implements ApplicationListener<ContextRefreshedEvent> {

	@Autowired
	private MockQueue mockQueue;

	@Autowired
	private DeferredResultHolder deferredResultHolder;
	
	private Logger logger = LoggerFactory.getLogger(getClass());

	@Override
	public void onApplicationEvent(ContextRefreshedEvent event) {
		new Thread(() -> {
			while (true) {

				if (StringUtils.isNotBlank(mockQueue.getCompleteOrder())) {
					//如果完成订单有值
					String orderNumber = mockQueue.getCompleteOrder();
					logger.info("返回订单处理结果:"+orderNumber);
					//获取 DeferredResult 设置 返回值
					deferredResultHolder.getMap().get(orderNumber).setResult("place order success");
					mockQueue.setCompleteOrder(null);
					
				}else{
					try {
						Thread.sleep(100);
					} catch (InterruptedException e) {
						e.printStackTrace();
					}
				}

			}
		}).start();
	}
}

AsyncController

@RestController
public class AsyncController {
	@Autowired
	private MockQueue mockQueue;
	@Autowired
	private DeferredResultHolder deferredResultHolder;
	private Logger logger = LoggerFactory.getLogger(getClass());
	
	@RequestMapping("/order")
	public DeferredResult<String> order() throws Exception {
		logger.info("主线程开始");
		//随机生成一个8位的 号
		String orderNumber = RandomStringUtils.randomNumeric(8);
		//设置 
		mockQueue.setPlaceOrder(orderNumber);
		//创建 DeferredResult
		DeferredResult<String> result = new DeferredResult<>();
		//设置到deferredResultHolder
		deferredResultHolder.getMap().put(orderNumber, result);
		
		return result;
		
	}

}

多线程的配置

@Configuration
public class WebConfig extends WebMvcConfigurerAdapter {
	
	@SuppressWarnings("unused")
	@Autowired
	private TimeInterceptor timeInterceptor;

	@Override
	public void configureAsyncSupport(AsyncSupportConfigurer configurer) {
		configurer.registerCallableInterceptors();//需要用这两个方法,单独注册拦截器
		configurer.registerDeferredResultInterceptors();
		configurer.setDefaultTimeout(); //超时
		configurer.setTaskExecutor();//设置可重用的线程池,默认是不可重用线程池
		super.configureAsyncSupport(configurer);
	}
  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值