码迷,mamicode.com
首页 > 编程语言 > 详细

Java实现高并发秒杀API--Service层2

时间:2017-04-06 23:13:47      阅读:198      评论:0      收藏:0      [点我收藏+]

标签:业务   sed   unit   else   one   bean   erro   message   请求   

今天完成了整个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

标签:业务   sed   unit   else   one   bean   erro   message   请求   

原文地址:http://www.cnblogs.com/XuZhiDian/p/6675931.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!