博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
EasyDBO-0.6.0中事务处理中的严重Bug
阅读量:4192 次
发布时间:2019-05-26

本文共 1650 字,大约阅读时间需要 5 分钟。

 1、在EasyDBO-0.6的事务处理中,默认在不使用事务的情况下并没有释放数据源,这样会造成数据源的浪费,导致系统死机。

   需要在EasyJDBEngine引擎中JDBC相关操作的finally子句中加入释放数据源的代码,修改大致如下:
   finally {
           try {
               dba.close();
               if(autoCommit)releaseConnection();
           } catch (Exception e) {
               logger.error("释放数据库资源错误:" + e);
           }
       }
   这种默认的情况下就像使用简单的JDBC一样,执行add,update,del等相关方法后,都会自动释放数据源。
  2、在事务处理的JDBCContext上下文中,由于EasyJDBEngine是一作为一个工具类供EasyJDB调用的,以前的代码如下:
  public EasyJDBEngine(){
       private JDBCContext jdbcContext;
   public Connection getConnection() {
       Connection conn = null;
       try {            
           conn =jdbcContext.getConnection();
       } catch (Exception e) {
           logger.error("无没取得数据源,请确认数据源配置是否正确!");
           return null;
       }
       return conn;
   }
   }
  
   在这个设计中,事务只能在单线程的情况下才起作用。在多线程中,将造成一个线程关闭另一个线程中的数据源,因此就会出错。
  为了能让事务处理在多线程环境中也能正常工作,需要引入ThreadLocal静态变量,修改后的getConnection()方法如下:
   public Connection getConnection() {
       Connection conn = null;
       try {            
           conn =JDBCContext.getJdbcContext(dataSource).getConnection();
       } catch (Exception e) {
           logger.error("无没取得数据源,请确认数据源配置是否正确!");
           return null;
       }
       return conn;
   }
  
  JDBCContext要作重大的调整,加入ThreadLocal,代码大致如下:
  public class JDBCContext{
   private DataSource ds;
   protected Connection connection;
   private boolean isValid = true;
   private static ThreadLocal jdbcContext;
   /**
    * @param ds
    */
   private JDBCContext(DataSource ds){
       this.ds = ds;
       createConnection();
       System.out.println("创建数据源访问上下文!");
   }
   public static JDBCContext getJdbcContext(javax.sql.DataSource ds)
   {        
       if(jdbcContext==null)jdbcContext=new JDBCContextThreadLocal(ds);
       JDBCContext context = (JDBCContext) jdbcContext.get();
       if (context == null) {
           context = new JDBCContext(ds);
       }
       return context;
   }
   ....
   }
   

Trackback: http://tb.blog.csdn.net/TrackBack.aspx?PostId=1162142

你可能感兴趣的文章
点评锤子新机外观被前下属骂“厚颜无耻” 罗永浩道歉:希望还来得及补偿
查看>>
安兔兔发布9月份Android性能榜:855霸榜,华为竟垫底
查看>>
iOS 13新增防骚扰功能,但开启后用户吐槽声一片
查看>>
任正非:不要过度消费客户及民众对我们的同情与支持
查看>>
10月15日发布!谷歌Pixel 4系列或将全系支持5G
查看>>
高通首席技术官:5G+AI是至关重要的组合
查看>>
国庆档票房近50亿创纪录 背后影视股却遭遇集体下跌
查看>>
来了!索尼官宣PS5游戏主机:比预计的时间稍晚一些
查看>>
英雄互娱:中止代理的《NBA LIVE》在中国大陆地区所有推广活动
查看>>
有望年前发布?魅族16s Pro Plus曝光:下半年旗舰担当
查看>>
千万量级只是5G商用起点?高通专家:5G部署速度比当初的4G更快
查看>>
摩拜单车又涨价了!真的要骑不起了
查看>>
2019胡润百富榜:马云老师仍是首富 丁磊卖考拉翻身 李彦宏、雷军掉队
查看>>
支付宝又“上新”!余额宝兄弟“余额佳”上线
查看>>
不敢摔!三星Galaxy Fold换屏费用可以入手一部华为Mate 30了
查看>>
古迪纳夫等3人获得诺贝尔化学奖 确立锂离子电池构成
查看>>
有戏!低于4000的iPhone SE2买不买?
查看>>
全球最快65W闪充!OPPO Reno Ace正式发布 高达限量定制版售价仅3599元
查看>>
支付宝封杀比特币,可以说是毫不留情!
查看>>
坑哭了!老牌教育机构也崩盘,疑失联跑路,学员却还得继续还贷
查看>>