Java异常处理——请求能进到接口,但是服务没有响应?

问题描述:服务正常启动,其他接口调用正常,涉及到有数据库的接口,被多次请求后,前面几次能正常响应,请求几次后服务未响应,查看日志服务请求能进到接口,但是没有响应?

查找原因:服务重启后,又能正常请求响应,几次后又出现未响应。

根本原因:redis开启了事务,方法未设置@Transactional(rollbackFor = Exception.class),导致事务没有提交,占用连接池未释放,数据库连接一直再等待资源,因此没有响应值

我的redis配置信息:

<bean id="redisTemplateTx" class="org.springframework.data.redis.core.RedisTemplate" primary="false">
        <property name="enableTransactionSupport" value="true" />//开启事务
        <property name="connectionFactory" ref="jedisConnFactoryTx" />
        <property name="keySerializer">
            <bean class="org.springframework.data.redis.serializer.StringRedisSerializer" />
        </property>
        <property name="valueSerializer">
            <bean class="org.springframework.data.redis.serializer.JdkSerializationRedisSerializer" />
        </property>
        <property name="hashKeySerializer">
            <bean class="org.springframework.data.redis.serializer.StringRedisSerializer" />
        </property>
        <property name="hashValueSerializer">
            <bean class="org.springframework.data.redis.serializer.JdkSerializationRedisSerializer" />
        </property>
    </bean>

解决方案:在调用方法的业务处理层(service)方法上增加事务:@Transactional(rollbackFor = Exception.class)

    @Transactional(rollbackFor = Exception.class)
    @Override
    public Object addDo(OrderVoExtend orderVO, String openid, String wxAppId) throws Exception {
}
posted on 2021-03-18 11:43  依米欧  阅读(1797)  评论(0编辑  收藏  举报