Java实现高并发秒杀API--Service层2
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Java实现高并发秒杀API--Service层2相关的知识,希望对你有一定的参考价值。
今天完成了整个Java实现高并发秒杀API--Service层的学习:
1、接口的编码以及实现类的逻辑编写
2、利用spring ioc对Service进行管理
3、利用spring声明式事务对事务进行控制:
事务主要配置:
<!--配置事务管理器 -->
<bean id="transactionManager"
class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
<property name="dataSource" ref="dataSource"></property>
</bean>
<!-- 配置基于注解的声明式事务 默认使用注解来管理事务行为 -->
<tx:annotation-driven transaction-manager="transactionManager" />
并且了解到spring使用事务的3种方式,最终决定使用声明式事务,原因如下:
* 1、开发团队达成一致约定,明确标注事务方法的变成风格
* 2、保证事务方法的执行时间尽可能短,不要穿插其他网络操作,RPC/HTTP请求或者剥离到事务方法外
* 3、不是所有的方法都需要事务,如只有一条修改操作,只读操作不需要事务控制
最后使用了junit进行集成测试,测试的注意点为
在对接口方法进行测试完成之后还需要对业务逻辑进行测试。即可能存在2个接口通过一定业务流程的绑定测试。
@Test
public void testSeckillLogic() {
long id = 1001L;
Exposer exportSeckillUrl = seckillService.exportSeckillUrl(id);
if (exportSeckillUrl.isExposed()) {
logger.info("exposer={}", exportSeckillUrl);
long phone = 15068751236L;
String md5 = exportSeckillUrl.getMd5();
try {
SeckillExectuion executeSeckill = seckillService.executeSeckill(id, phone, md5);
logger.info("result={}", executeSeckill);
} catch (RepeatKillException e) {
logger.error(e.getMessage());
} catch (SeckillCloseException e) {
logger.error(e.getMessage());
}
} else {
logger.warn("exposer={}", exportSeckillUrl);
}
以上是关于Java实现高并发秒杀API--Service层2的主要内容,如果未能解决你的问题,请参考以下文章