婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > 深入理解PHP+Mysql分布式事務與解決方案

深入理解PHP+Mysql分布式事務與解決方案

熱門標簽:中原區電話機器人價格 gps 地圖標注軟件 ai電話機器人加盟代理 電銷機器人便宜的有嗎 OMG地圖標注app 地圖標注視頻廣告入駐 招標自動語音外呼系統 黔江400電話如何辦理 400電話鄭州申請

事務(Transaction)是訪問并可能更新數據庫中各種數據項的一個程序執行單元;

事務的ACID特性

事務應該具有4個屬性:原子性、一致性、隔離性、持續性

原子性(atomicity)。一個事務是一個不可分割的工作單位,事務中包括的諸操作要么都做,要么都不做。
一致性(consistency)。事務必須是使數據庫從一個一致性狀態變到另一個一致性狀態。一致性與原子性是密切相關的。

隔離性(isolation)。一個事務的執行不能被其他事務干擾。即一個事務內部的操作及使用的數據對并發的其他事務是隔離的,并發執行的各個事務之間不能互相干擾。
持久性(durability)。持續性也稱永久性(permanence),指一個事務一旦提交,它對數據庫中數據的改變就應該是永久性的。接下來的其他操作或故障不應該對其有任何影響。

分布式事務:分布式事務的參與者、資源管理器、事務管理器等位于不用的節點上,這些不同的節點相互協作共同完成一個具有邏輯完整性的事務。

mysql從5.0開始支持XA DataSource。Connector/J 版本要使用5.0版本,5.0以下的不支持。

常見的分布式事務解決方案

基于XA協議的兩階段提交
XA協議由Tuxedo首先提出的,并交給X/Open組織,作為資源管理器(數據庫)與事務管理器的接口標準。目前,Oracle、Informix、DB2和Sybase等各大數據庫廠家都提供對XA的支持。XA協議采用兩階段提交方式來管理分布式事務。XA接口提供資源管理器與事務管理器之間進行通信的標準接口。XA協議包括兩套函數,以xa_開頭的及以ax_開頭的。

以下的函數使事務管理器可以對資源管理器進行的操作:
1)xa_open,xa_close:建立和關閉與資源管理器的連接。
2)xa_start,xa_end:開始和結束一個本地事務。
3)xa_prepare,xa_commit,xa_rollback:預提交、提交和回滾一個本地事務。
4)xa_recover:回滾一個已進行預提交的事務。
5)ax_開頭的函數使資源管理器可以動態地在事務管理器中進行注冊,并可以對XID(TRANSACTION IDS)進行操作。
6)ax_reg,ax_unreg;允許一個資源管理器在一個TMS(TRANSACTION MANAGER SERVER)中動態注冊或撤消注冊。

XA實現分布式事務的原理如下:



MySQL XA分為兩類,內部XA與外部XA;內部XA用于同一實例下跨多個引擎的事務,由大家熟悉的Binlog作為協調者;外部XA用于跨多MySQL實例的分 布式事務,需要應用層介入作為協調者(崩潰時的懸掛事務,全局提交還是回滾,需要由應用層決定,對應用層的實現要求較高);

Binlog作為內部XA的協調者,在binlog中出現的內部xid,在crash recover時,由binlog負責提交。(這是因為,binlog不進行prepare, 只進行commit,因此在binlog中出現的內部xid,一定能夠保證其在底層各存儲引擎中已經完成prepare)。

MySQL數據庫外部XA可以用在分布式數據庫代理層,實現對MySQL數據庫的分布式事務支持,例如開源的代理工具:網易的DDB,淘寶的TDDL,B2B的Cobar等等。

示例

public function testAction(){
    $goods_id=1;
    $goods_name = "關注PHP開源社區微信公眾號領取PHP大廠面試題";
    $num = 1;
    $rs_order = $this->test->createorder($goods_id,$goods_name,$num);
    $rs_goods = $this->test->deduction($goods_id,$num);
    if($rs_order['status'] =="success"  $rs_goods['status']=="success"){
      $this->test->commitdb($rs_order['XA']);
      $this->test->commitdb1($rs_goods['XA']);
    }else{
      $this->test->rollbackdb($rs_order['XA']);
      $this->test->rollbackdb1($rs_goods['XA']);
    }

    print_r($rs_order);
    echo "br />";
    print_r($rs_goods);
    die("dddd");
  }
  public function createorder($goods_id,$goods_name,$num){
    $XA = uniqid("");
    $this->_db->query("XA START '$XA'");
    $_rs = true;
    try {
      $data = array();
      $data['order_id'] = "V".date("YmdHis");
      $data['goods_name'] = $goods_name;
      $data['goods_num'] = $num;
      $this->_db->insert("temp_orders",$data);
      $rs = $this->_db->lastInsertId();
      if($rs){
        $_rs = true;
      }else{
        $_rs = false;
      }
    } catch (Exception $e) {
      $_rs = false;
    }
    $this->_db->query("XA END '$XA'");
     if($_rs){
         $this->_db->query("XA PREPARE '$XA'");
         return array("status"=>"success","XA"=>$XA);
     }else{
         return array("status"=>"nosuccess","XA"=>$XA);
     }
  }
   public function deduction($id){
    $XA = uniqid("");
    $this->db1->query("XA START '$XA'");
    $last_rs = true;
    try {
        $sql = "select * from temp_goods where id = '$id' and goods_num>0";
        $rs = $this->db1->fetchRow($sql);
        if(!empty($rs)){
          $sql = "update temp_goods set goods_num = goods_num-1 where id = '$id'";
          $rd = $this->db1->query($sql);
          if($rd){
            $last_rs = true;
          }else{
            $last_rs = false;
          }
        }else{
            $last_rs = false;;
        }
    } catch (Exception $e) {
       $last_rs = false;;
    }
     $this->db1->query("XA END '$XA'");
     if($last_rs){
         $this->db1->query("XA PREPARE '$XA'");
         return array("status"=>"success","XA"=>$XA);
     }else{
         return array("status"=>"nosuccess","XA"=>$XA);
     }

  }
  //提交事務!
  public function commitdb($xa){
    return $this->_db->query("XA COMMIT '$xa'");
  }

  //回滾事務
  public function rollbackdb($xa){
    return $this->_db->query("XA ROLLBACK '$xa'");
  }

  //提交事務!
  public function commitdb1($xa){
    return $this->db1->query("XA COMMIT '$xa'");
  }
   //回滾事務
  public function rollbackdb1($xa){
    return $this->db1->query("XA ROLLBACK '$xa'");
  }

總結

分布式事務,本質上是對多個數據庫的事務進行統一控制,按照控制力度可以分為:不控制、部分控制和完全控制。不控制就是不引入分布式事務,部分控制就是各種變種的兩階段提交,包括上面提到的消息事務+最終一致性、TCC模式,而完全控制就是完全實現兩階段提交。部分控制的好處是并發量和性能很好,缺點是數據一致性減弱了,完全控制則是犧牲了性能,保障了一致性,具體用哪種方式,最終還是取決于業務場景。作為技術人員,一定不能忘了技術是為業務服務的,不要為了技術而技術,針對不同業務進行技術選型也是一種很重要的能力

到此這篇關于深入理解PHP+Mysql分布式事務與解決方案的文章就介紹到這了,更多相關PHP Mysql分布式事務內容請搜索腳本之家以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持腳本之家!

您可能感興趣的文章:
  • Android和PHP MYSQL交互開發實例
  • Mac M1安裝mnmp(Mac+Nginx+MySQL+PHP)開發環境
  • PHP加MySQL消息隊列深入理解
  • PHP+Mysql分布式事務與解決方案深入理解
  • PHP連接MySQL數據庫三種實現方法
  • Aliyun Linux 編譯安裝 php7.3 tengine2.3.2 mysql8.0 redis5的過程詳解
  • php7連接MySQL實現簡易查詢程序的方法
  • PHP之mysql位運算案例講解

標簽:哈密 阿里 孝感 濟源 那曲 池州 北京 日照

巨人網絡通訊聲明:本文標題《深入理解PHP+Mysql分布式事務與解決方案》,本文關鍵詞  深入,理解,PHP+Mysql,分布式,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《深入理解PHP+Mysql分布式事務與解決方案》相關的同類信息!
  • 本頁收集關于深入理解PHP+Mysql分布式事務與解決方案的相關信息資訊供網民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    欧美日韩亚洲高清一区二区| 欧美丰满嫩嫩电影| 色综合婷婷久久| 中文字幕一区二区在线观看| 粉嫩13p一区二区三区| 国产欧美一区视频| 精品一区二区在线看| 日韩欧美一级二级| 韩国女主播成人在线观看| 欧美变态tickling挠脚心| 国产一区二区三区av电影| 精品国产乱码久久久久久老虎| 日本欧美大码aⅴ在线播放| 91精品欧美一区二区三区综合在| 麻豆免费精品视频| 日韩一区二区三区三四区视频在线观看 | 欧美日韩亚洲综合一区| 五月婷婷激情综合网| 日韩精品专区在线影院重磅| 国内精品伊人久久久久影院对白| 中国av一区二区三区| 99国产欧美另类久久久精品| 丝袜美腿亚洲色图| 国产色一区二区| 在线观看免费亚洲| 精品一区二区三区影院在线午夜| 精品久久久三级丝袜| 国产精品一级片| 亚洲欧美激情一区二区| 日韩欧美在线一区二区三区| av成人动漫在线观看| 日本中文字幕一区二区视频| 亚洲国产电影在线观看| 欧美日韩成人激情| 成人免费观看av| 麻豆国产一区二区| 亚洲综合色成人| 国产精品美女久久久久久2018| 欧美日韩视频在线一区二区| 成人精品在线视频观看| 九九精品一区二区| 香蕉av福利精品导航| 中文字幕日韩一区| 国产欧美一区二区三区在线老狼 | 不卡的av电影| 久久99精品一区二区三区三区| 一区二区三区四区在线免费观看 | 久久久一区二区三区| 欧美日韩一区二区不卡| 国产91色综合久久免费分享| 激情丁香综合五月| 日韩美女视频19| 国内成人精品2018免费看| 成人国产视频在线观看| 成人免费在线播放视频| 日韩片之四级片| 亚洲欧美另类小说| 亚洲蜜臀av乱码久久精品| 午夜精品福利一区二区三区蜜桃| 日本女优在线视频一区二区| 久久综合九色综合欧美98| 91精品国产麻豆国产自产在线 | 国产精品久久久久aaaa樱花| 久久噜噜亚洲综合| 日韩和欧美一区二区| 国产91精品一区二区| 欧美性做爰猛烈叫床潮| 国产精品久久久久久久久果冻传媒| 麻豆国产欧美一区二区三区| 成人免费看片app下载| 日本一区二区三区在线不卡 | 欧美日韩美女一区二区| 亚洲欧美日韩成人高清在线一区| 日韩一区二区视频| 成人欧美一区二区三区白人| 国产一区在线看| 成人黄色小视频| 91精品午夜视频| 视频一区二区三区中文字幕| 丰满白嫩尤物一区二区| 欧美少妇性性性| 日韩美女久久久| 欧美综合一区二区| 亚洲一级二级在线| 99久久综合99久久综合网站| 精品99999| 豆国产96在线|亚洲| 国产午夜精品久久| 国产一区二区免费看| 欧美三级资源在线| 日日摸夜夜添夜夜添国产精品| 欧美福利视频导航| 天堂影院一区二区| 精品国产3级a| 盗摄精品av一区二区三区| 久久精品网站免费观看| 国产69精品久久99不卡| 国产精品久久久久久久久久久免费看 | 亚洲国产一区二区三区青草影视| 日韩一区二区三区电影在线观看 | 在线视频国产一区| 亚洲人xxxx| 欧美丝袜丝nylons| 成人午夜免费av| 麻豆精品久久久| 午夜一区二区三区视频| 日韩一级二级三级精品视频| 欧美在线综合视频| 国产精品白丝av| 日韩av一二三| 日本伊人色综合网| 亚洲成人你懂的| 日韩av二区在线播放| 亚洲激情校园春色| 一区二区三区在线播放| 日本一区二区在线不卡| 日韩精品中文字幕一区二区三区| 99在线精品免费| 91污片在线观看| 欧洲激情一区二区| 欧美探花视频资源| 51精品久久久久久久蜜臀| 91精品国产一区二区三区香蕉 | 亚洲成人激情综合网| 欧美亚洲愉拍一区二区| 国产精品911| 国产福利电影一区二区三区| aa级大片欧美| 亚洲一二三四在线| 日韩电影一二三区| 成人自拍视频在线| 99热国产精品| 欧美日韩高清一区二区不卡| 91精品在线麻豆| 国产精品久久久久婷婷二区次| 国产精品国产三级国产aⅴ入口| 国产精品久久久久久福利一牛影视| 国产精品剧情在线亚洲| 亚洲午夜三级在线| 成人免费视频一区| 2020国产精品久久精品美国| 亚洲一区二区在线播放相泽| 蜜桃视频一区二区三区在线观看| 丰满白嫩尤物一区二区| 日韩精品在线一区二区| 夜夜精品浪潮av一区二区三区| 欧美视频自拍偷拍| 中文天堂在线一区| 免费在线视频一区| 日韩欧美在线1卡| 玖玖九九国产精品| 欧美一区二区三区四区视频| 亚洲国产aⅴ天堂久久| 欧美性受极品xxxx喷水| 国产婷婷精品av在线| 蜜臀久久99精品久久久画质超高清| 91亚洲精品乱码久久久久久蜜桃 | 中文乱码免费一区二区| 93久久精品日日躁夜夜躁欧美| 亚洲天堂成人网| 在线免费观看日本一区| 亚洲一区二区三区小说| 在线精品视频免费观看| 日韩激情在线观看| 国产日韩欧美在线一区| 成人免费毛片片v| 香蕉久久夜色精品国产使用方法| 91猫先生在线| 视频在线在亚洲| 欧美韩国一区二区| 欧美自拍偷拍午夜视频| 黄色成人免费在线| 亚洲一二三四区不卡| 久久婷婷国产综合国色天香| 91一区在线观看| 国产成人亚洲综合a∨婷婷图片| 樱花影视一区二区| 91精品国产综合久久香蕉麻豆 | 国产精品电影一区二区三区| 欧美午夜片在线观看| 99精品国产热久久91蜜凸| 国产一区二区三区在线观看精品 | 5566中文字幕一区二区电影| 国产一区二区三区四| 日韩精品免费视频人成| 亚洲色图欧洲色图| 亚洲欧洲精品一区二区三区不卡| 亚洲色图视频网站| 国产精品嫩草久久久久| 日韩精品一区二区三区swag| 极品销魂美女一区二区三区| 午夜精品久久久久久久| 亚洲精品中文字幕乱码三区| 久久女同互慰一区二区三区| 欧美日韩国产精选| 色噜噜偷拍精品综合在线| 成人av综合在线| 色综合天天综合在线视频| 色婷婷综合久久久久中文| 欧美这里有精品|