读写分离时事务回滚的问题

浏览:3069 发布日期:2015/04/14 分类:求助交流 关键字: 分布式 读写分离 事务
数据库采用mysql主从读写分离
执行一段事务,代码大致如下        try{
            M()->startTrans();
            //do something
        } catch (Exception $ex) {
            M()->rollback();
            $this->error($ex->getMessage());
        }
        M()->commit();
问题来了,当do something里只进行了查询,默认的链接是从服务器,但是事务的开启在主服务器上,所以回滚的时候直接提示不存在事务。
经过尝试,在rollback()方法加入$this->initConnect(true);可以让链接先指向主服务器,解决此问题,修改的方法如下:    public function rollback() {
        if ($this->transTimes > 0) {
            $this->initConnect(true);
            $result = $this->_linkID->rollback();
            $this->transTimes = 0;
            if(!$result){
                $this->error();
                return false;
            }
        }
        return true;
    }
这样的话就改了核心代码,大家有没有更好的处理方法
最佳答案
评论( 相关
后面还有条评论,点击查看>>