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);
        }

 

posted @ 2017-04-06 23:03  zhidian  阅读(356)  评论(0编辑  收藏  举报