zoukankan      html  css  js  c++  java
  • 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 {
    }
  • 相关阅读:
    行行网电子书多线程爬取
    51CTO学院IT技术课程抓取
    chromeF12 谷歌开发者工具详解 Network篇
    pyspider无法启动webui
    Python告诉你今天最冷的地方在哪里
    matplotlib画图中文及负号显示问题
    数据分析案例
    seaborn.barplot用法
    Python大数据分析之数据分析
    python中yield的用法详解
  • 原文地址:https://www.cnblogs.com/ouyanxia/p/14554801.html
Copyright © 2011-2022 走看看