亚洲综合原千岁中文字幕_国产精品99久久久久久久vr_无码人妻aⅴ一区二区三区浪潮_成人h动漫精品一区二区三

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

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

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

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

事務(wù)的ACID特性

事務(wù)應(yīng)該具有4個屬性:原子性、一致性、隔離性、持續(xù)性

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

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

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

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

常見的分布式事務(wù)解決方案

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

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

XA實現(xiàn)分布式事務(wù)的原理如下:



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

Binlog作為內(nèi)部XA的協(xié)調(diào)者,在binlog中出現(xiàn)的內(nèi)部xid,在crash recover時,由binlog負(fù)責(zé)提交。(這是因為,binlog不進(jìn)行prepare, 只進(jìn)行commit,因此在binlog中出現(xiàn)的內(nèi)部xid,一定能夠保證其在底層各存儲引擎中已經(jīng)完成prepare)。

MySQL數(shù)據(jù)庫外部XA可以用在分布式數(shù)據(jù)庫代理層,實現(xiàn)對MySQL數(shù)據(jù)庫的分布式事務(wù)支持,例如開源的代理工具:網(wǎng)易的DDB,淘寶的TDDL,B2B的Cobar等等。

示例

public function testAction(){
    $goods_id=1;
    $goods_name = "關(guān)注PHP開源社區(qū)微信公眾號領(lǐng)取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);
     }

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

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

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

總結(jié)

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

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

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

標(biāo)簽:哈密 阿里 孝感 濟(jì)源 那曲 池州 北京 日照

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《深入理解PHP+Mysql分布式事務(wù)與解決方案》,本文關(guān)鍵詞  深入,理解,PHP+Mysql,分布式,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《深入理解PHP+Mysql分布式事務(wù)與解決方案》相關(guān)的同類信息!
  • 本頁收集關(guān)于深入理解PHP+Mysql分布式事務(wù)與解決方案的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    欧美激情一区二区三区视频高清 | 日韩在线观看视频免费| 午夜家庭影院| 九九久久99综合一区二区| 九九精品久久| 日本伦理片网站| 国产成人精品影视| 日韩在线观看视频免费| 国产成人精品影视| 亚洲第一页乱| 久久精品欧美一区二区| 可以免费在线看黄的网站| 欧美激情一区二区三区视频高清 | 久久国产一久久高清| 精品在线观看国产| 黄视频网站免费看| 日韩中文字幕一区二区不卡| 91麻豆国产| 免费国产在线视频| 欧美一区二区三区在线观看| 日本特黄特黄aaaaa大片| 国产伦久视频免费观看 视频| 日韩专区在线播放| 精品视频在线观看一区二区| 亚洲天堂免费| 久久久成人网| 日韩专区在线播放| 日韩一级黄色| 亚洲 激情| 久久国产精品自线拍免费| 好男人天堂网 久久精品国产这里是免费 国产精品成人一区二区 男人天堂网2021 男人的天堂在线观看 丁香六月综合激情 | 色综合久久天天综合绕观看| 国产美女在线一区二区三区| 九九干| 欧美1区2区3区| 日日夜人人澡人人澡人人看免| 免费毛片基地| 91麻豆国产| 九九热国产视频| 国产成+人+综合+亚洲不卡| 久久99中文字幕久久| 精品在线观看国产| 日韩专区在线播放| 色综合久久天天综合绕观看| 国产网站在线| 天天做日日爱夜夜爽| 精品国产一区二区三区久久久蜜臀 | 久久精品店| 韩国毛片| 99热精品在线| 一级女人毛片人一女人| 午夜在线影院| 91麻豆精品国产片在线观看| 99热精品在线| 九九干| 欧美日本免费| 尤物视频网站在线| 四虎影视库| 国产a毛片| 四虎论坛| 国产网站免费| 久久国产精品自线拍免费| 国产a毛片| 国产欧美精品| 美女免费精品视频在线观看| 青青久久精品| 久久国产一久久高清| 九九热国产视频| 久久精品欧美一区二区| 国产欧美精品| 亚洲 激情| 日韩在线观看视频免费| 欧美激情一区二区三区在线播放 | 日韩中文字幕一区二区不卡| 日韩欧美一及在线播放| 精品国产三级a| 沈樵在线观看福利| 九九精品久久| 日韩专区在线播放| 久久国产精品自线拍免费| 香蕉视频久久| 日本免费乱理伦片在线观看2018| 中文字幕一区二区三区精彩视频| 国产网站免费| 四虎论坛| 久草免费在线视频| 成人免费一级纶理片| 欧美另类videosbestsex久久| 国产成+人+综合+亚洲不卡| 韩国三级一区| 日韩在线观看视频免费| a级黄色毛片免费播放视频| 精品视频在线观看一区二区| 久草免费在线视频| 亚洲精品影院| 欧美1区2区3区| 日韩一级黄色| 九九精品久久| 欧美1区2区3区| 欧美大片aaaa一级毛片| 久久精品欧美一区二区| 精品国产一区二区三区久久久蜜臀 | 免费一级片在线| 久久精品欧美一区二区| 久久国产一久久高清| 久久精品欧美一区二区| 亚洲精品影院| 青草国产在线观看| 99色视频| 色综合久久天天综合绕观看| 高清一级毛片一本到免费观看| 精品久久久久久中文| 国产a毛片| 国产视频一区二区在线播放| 欧美一区二区三区在线观看| 午夜家庭影院| 91麻豆爱豆果冻天美星空| 国产伦理精品| 欧美激情影院| 日韩专区亚洲综合久久| 韩国三级视频网站| 国产福利免费视频| 国产高清在线精品一区a| 国产极品白嫩美女在线观看看| 日本久久久久久久 97久久精品一区二区三区 狠狠色噜噜狠狠狠狠97 日日干综合 五月天婷婷在线观看高清 九色福利视频 | 黄色福利| 四虎久久精品国产| 欧美激情影院| 国产不卡高清在线观看视频 | 国产网站免费视频| 日韩中文字幕在线播放| 韩国三级香港三级日本三级| 欧美18性精品| 亚洲第一色在线| 精品视频在线观看免费| 日本久久久久久久 97久久精品一区二区三区 狠狠色噜噜狠狠狠狠97 日日干综合 五月天婷婷在线观看高清 九色福利视频 | 亚洲精品久久久中文字| 欧美日本二区| 亚洲精品久久久中文字| 国产精品自拍一区| 成人影院一区二区三区| 欧美激情影院| 日韩在线观看免费完整版视频| 精品视频一区二区| 韩国三级香港三级日本三级| 国产网站免费视频| 免费国产在线观看| 久久精品大片| 一本高清在线| 欧美激情影院| 你懂的日韩| 九九久久国产精品大片| 色综合久久天天综线观看| 久久精品大片| 青青青草视频在线观看| 九九久久国产精品大片| 国产极品白嫩美女在线观看看| 亚洲女人国产香蕉久久精品| 精品久久久久久中文字幕2017| 欧美日本二区| 国产91精品系列在线观看| 精品国产亚一区二区三区| 99久久视频| 国产精品自拍一区| 99久久精品国产麻豆| 国产成人女人在线视频观看| 韩国三级香港三级日本三级| 午夜欧美成人久久久久久| 国产亚洲精品成人a在线| 美女免费毛片| 色综合久久天天综合| 日韩在线观看网站| 亚洲第一色在线| 成人影院一区二区三区| 国产视频一区二区在线观看| 日韩男人天堂| 久久精品大片| 日韩在线观看免费完整版视频| 欧美另类videosbestsex高清| 亚洲精品久久久中文字| 国产网站免费视频| 韩国三级香港三级日本三级| 国产成人精品综合久久久| 久久精品免视看国产成人2021| 99久久精品国产麻豆| 国产91精品系列在线观看| 日本久久久久久久 97久久精品一区二区三区 狠狠色噜噜狠狠狠狠97 日日干综合 五月天婷婷在线观看高清 九色福利视频 | 久久国产影视免费精品| 国产亚洲精品成人a在线| 国产成人精品综合久久久| 91麻豆精品国产自产在线观看一区| 国产不卡高清在线观看视频 | 日韩中文字幕在线播放| 久久成人亚洲| 一本高清在线| 日韩免费在线| 黄视频网站在线看| 久久成人亚洲| 999精品在线| 成人高清视频在线观看|