日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術(shù)文章
文章詳情頁

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

瀏覽:161日期:2022-09-08 15:59:46

事務(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ù)管理器的接口標準。目前,Oracle、Informix、DB2和Sybase等各大數(shù)據(jù)庫廠家都提供對XA的支持。XA協(xié)議采用兩階段提交方式來管理分布式事務(wù)。XA接口提供資源管理器與事務(wù)管理器之間進行通信的標準接口。XA協(xié)議包括兩套函數(shù),以xa_開頭的及以ax_開頭的。

以下的函數(shù)使事務(wù)管理器可以對資源管理器進行的操作: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:回滾一個已進行預(yù)提交的事務(wù)。5)ax_開頭的函數(shù)使資源管理器可以動態(tài)地在事務(wù)管理器中進行注冊,并可以對XID(TRANSACTION IDS)進行操作。6)ax_reg,ax_unreg;允許一個資源管理器在一個TMS(TRANSACTION MANAGER SERVER)中動態(tài)注冊或撤消注冊。

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

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

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

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

標簽: PHP
相關(guān)文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
国产欧美一区二区三区精品酒店| 国产亚洲一区二区三区啪| 欧美日韩亚洲一区三区| 尤物tv在线精品| 激情综合自拍| 在线综合亚洲| 亚洲另类黄色| 国产精品欧美一区二区三区不卡| 青青国产精品| 麻豆精品在线观看| 国产不卡人人| 狠狠爱www人成狠狠爱综合网| 红桃视频国产精品| 一区二区三区四区日韩| 欧美一区二区三区久久| 里番精品3d一二三区| 91欧美在线| 欧美 日韩 国产一区二区在线视频| 欧美二三四区| 99在线精品免费视频九九视| 偷拍亚洲精品| 精品少妇av| 久久三级福利| 日韩精品一级中文字幕精品视频免费观看 | 免播放器亚洲一区| 无码日韩精品一区二区免费| 国产乱码精品一区二区三区亚洲人 | 日韩啪啪电影网| 黄色在线一区| 国产精品v一区二区三区| 日韩电影免费网址| 日韩一区二区免费看| 日韩1区2区日韩1区2区| 国产日韩欧美一区| av高清不卡| 一区二区高清| 国内精品麻豆美女在线播放视频| 亚洲成人国产| 欧美永久精品| 91九色精品国产一区二区| 91成人在线精品视频| 欧美精品高清| 亚洲美女91| 日韩欧美1区| 婷婷综合国产| 91精品一区二区三区综合| 日韩欧美三区| 国产一区二区中文| 国产精品亚洲四区在线观看 | 国产精品婷婷| 国产成人在线中文字幕| 日韩专区在线视频| 特黄毛片在线观看| 欧美亚洲tv| 亚洲男女自偷自拍| 91免费精品| 国产欧美日韩一级| 午夜久久影院| 亚洲女同av| 日韩av中文在线观看| 在线日韩视频| 国产精品久久国产愉拍| 亚洲一区不卡| 久久精品二区三区| 精品国产中文字幕第一页| 日韩中文字幕亚洲一区二区va在线 | 久久国产欧美日韩精品| 欧美日韩色图| 捆绑调教美女网站视频一区 | 日韩av一区二区三区四区| 亚洲国产成人精品女人| 国产一区二区精品福利地址| 亚洲精品日韩久久| 亚洲女同中文字幕| 中文字幕高清在线播放| 国产美女撒尿一区二区| 免费视频最近日韩| 欧美亚洲精品在线| 日韩免费高清| 国产高清视频一区二区| 天堂久久一区| 亚洲一区二区成人| 欧美+亚洲+精品+三区| 另类综合日韩欧美亚洲| 日本视频中文字幕一区二区三区| 奶水喷射视频一区| 亚洲高清成人| 国产中文字幕一区二区三区| 国产乱人伦丫前精品视频| 日韩精品一区二区三区中文在线 | 女人天堂亚洲aⅴ在线观看| 国产精品毛片久久| 国产激情久久| 国产日韩欧美一区二区三区| 日韩 欧美一区二区三区| 久久国产小视频| 亚洲美女久久精品| 国产精品美女在线观看直播| 日韩精品视频一区二区三区| 亚洲欧美一级| 三级久久三级久久久| 久久高清免费观看| 国产精品丝袜xxxxxxx| 久久亚洲欧美| 免费人成精品欧美精品| 综合国产视频| 日韩激情精品| 日韩精品导航| 日本电影久久久| 亚洲一区二区三区中文字幕在线观看| 成人美女视频| 国产不卡人人| 国产欧美激情| 欧美欧美黄在线二区| 日本亚洲视频在线| 免费日韩av片| 国产麻豆综合| 亚洲性图久久| 99免费精品| 亚洲一区二区成人| 免费毛片在线不卡| 国产va在线视频| 国产一区二区三区四区大秀| 国产精品久久久亚洲一区| 日本va欧美va瓶| 视频在线在亚洲| 日欧美一区二区| 亚洲毛片一区| 亚洲我射av| 蜜臀av一区二区在线免费观看 | 国产精品久久久久久久久久齐齐| 久久亚洲欧洲| 亚洲综合丁香| 日韩天堂av| 亚洲激情偷拍| aa亚洲婷婷| 蜜臀av性久久久久蜜臀aⅴ四虎| 99pao成人国产永久免费视频| 国精品一区二区| 激情五月综合| 性色一区二区| 日产欧产美韩系列久久99| 日韩精品一区二区三区免费视频 | 日韩一区二区三区精品视频第3页| 综合精品一区| 婷婷综合福利| 国产精品3区| 黄色aa久久| 精品视频一区二区三区在线观看 | 99精品网站| 日韩天堂av| 视频一区在线视频| 亚洲精品在线二区| 国产精品一区二区三区四区在线观看 | 免费不卡中文字幕在线| 亚洲免费精品| 午夜久久av| 麻豆精品新av中文字幕| 色婷婷亚洲mv天堂mv在影片| 久久久精品久久久久久96| 日韩天堂av| 国产三级一区| 免费久久久久久久久| 丝袜国产日韩另类美女| 欧美日韩一区自拍| аⅴ资源天堂资源库在线| 国产91在线播放精品| 日韩精品第一区| 中国女人久久久| 国产午夜精品一区在线观看| 久久高清免费| 日韩精品亚洲专区在线观看| 麻豆中文一区二区| 免费视频国产一区| 日韩激情一区二区| 中文字幕人成乱码在线观看| 99精品综合| 亚洲精品三级| 国内在线观看一区二区三区 | 欧美日韩激情| 蜜臀精品一区二区三区在线观看 | 美腿丝袜亚洲三区| 欧美高清不卡| **爰片久久毛片| 日韩欧美二区| 日韩欧美中文字幕一区二区三区| 欧美一区91| 久久婷婷激情| 日本成人在线网站| 精品在线播放| 国产日韩欧美中文在线| 久久久久久黄| 欧美日韩亚洲国产精品| 日韩精品91| 日韩精品一区二区三区中文字幕| 日韩欧美一区二区三区在线观看| 日韩福利在线观看| 国产亚洲午夜| 黄色成人精品网站| 国产一区二区三区久久久久久久久|