成人在线亚洲_国产日韩视频一区二区三区_久久久国产精品_99国内精品久久久久久久

您的位置:首頁技術文章
文章詳情頁

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

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

事務(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實現分布式事務的原理如下:

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

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

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分布式事務內容請搜索好吧啦網以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持好吧啦網!

標簽: PHP
相關文章:
成人在线亚洲_国产日韩视频一区二区三区_久久久国产精品_99国内精品久久久久久久
亚洲国产一区二区视频| 亚洲综合激情| 亚洲欧美视频| 久久新电视剧免费观看| 国产美女精品人人做人人爽| 日韩视频免费| 成人免费在线视频观看| 91蝌蚪porny九色| 欧美成人精品1314www| 国内精品免费**视频| 在线视频你懂得一区| 首页国产欧美久久| 久久久久国产一区二区| 午夜激情一区二区三区| 久久精品亚洲| 午夜影视日本亚洲欧洲精品| 国产农村妇女精品一二区 | 色综合婷婷久久| 精品国产一区二区亚洲人成毛片 | 亚洲一区激情| 一区二区三区在线观看动漫| 亚洲精品乱码久久久久久蜜桃麻豆 | 日韩精品一区二区三区在线 | 青青草国产成人av片免费| 蜜桃久久av| 日本va欧美va瓶| 欧美日韩国产一区二区三区地区| 国产一区999| 欧美一区二区三区视频在线| 欧美69视频| 国产精品丝袜一区| 影音先锋一区| 一区2区3区在线看| 日本精品视频一区二区三区| 青青草97国产精品免费观看无弹窗版| 在线视频欧美区| 蜜桃一区二区三区在线| 欧美日韩三级一区| 国产91丝袜在线播放九色| 久久伊99综合婷婷久久伊| 91麻豆国产福利在线观看| 国产欧美日韩麻豆91| 伊人久久亚洲影院| 亚洲男人天堂av| 久久精品一区| 精品一区二区久久久| 日韩欧美另类在线| 欧美日韩成人| 亚洲一区二区三区在线看| 久久婷婷丁香| 国产乱人伦精品一区二区在线观看| 884aa四虎影成人精品一区| 国产激情一区二区三区四区| 精品99一区二区| 国产精品国码视频| 亚洲国产成人av| 欧美日韩国产一二三| 97国产一区二区| 亚洲精品国产品国语在线app| 亚洲综合二区| 国产麻豆成人传媒免费观看| 久久久精品免费免费| 国产日韩欧美一区二区三区四区 | 午夜视频一区在线观看| 欧美日韩久久不卡| 成人午夜短视频| 亚洲欧洲国产日韩| 色国产综合视频| 成人午夜又粗又硬又大| 国产精品传媒入口麻豆| 久久精品中文| 成人免费看片app下载| 亚洲色大成网站www久久九九| 久久网站免费| 成人一区在线看| 亚洲精品免费在线| 欧美精品vⅰdeose4hd| 欧美午夜电影在线观看| 五月天婷婷综合| 精品日本一线二线三线不卡| 亚洲片区在线| 国产真实乱对白精彩久久| 久久久久久99久久久精品网站| 国产精品一卡| 国产成人99久久亚洲综合精品| 中文字幕日韩av资源站| 欧美伊人精品成人久久综合97| 99精品欧美一区二区三区小说 | 成人一二三区视频| 夜夜精品浪潮av一区二区三区| 欧美精品色一区二区三区| 欧美体内she精视频在线观看| 婷婷国产在线综合| 精品国产精品网麻豆系列| 国产精品久久久免费| 国产高清久久久久| 亚洲男人天堂一区| 日韩亚洲欧美成人一区| 99精品99久久久久久宅男| 国产乱淫av一区二区三区| 亚洲精品乱码久久久久久久久 | 欧美日韩精品免费观看 | 亚洲乱码国产乱码精品精小说| 欧美日本在线一区| 黄色精品免费| 国内一区二区在线| 亚洲欧美日韩精品久久久久| 欧美乱熟臀69xxxxxx| 一区二区免费在线视频| 粉嫩av一区二区三区粉嫩| 亚洲一区二区三区在线看| 久久久五月婷婷| 欧美日韩国产精品成人| 亚洲国产精品第一区二区三区 | 丝袜美腿亚洲综合| 欧美激情一区二区三区不卡| 欧美午夜精品一区二区三区| 欧美精选在线| 国产综合色产在线精品| 国产精品高清亚洲| 欧美成人aa大片| 欧美自拍丝袜亚洲| 在线观看亚洲| youjizz国产精品| 麻豆精品一区二区综合av| 成人免费在线播放视频| 精品少妇一区二区三区在线视频| 久久综合九色| 日韩香蕉视频| 午夜免费电影一区在线观看| 国产伦精品一区二区三区视频青涩| 亚洲精品欧美二区三区中文字幕| 欧美成人vps| 欧美日韩在线免费视频| 国产精品久久久对白| 午夜视频一区| 99精品桃花视频在线观看| 国产精品综合在线视频| 日韩av在线播放中文字幕| 亚洲精品日产精品乱码不卡| 中文字幕乱码亚洲精品一区| 亚洲精品在线观看网站| 制服丝袜亚洲精品中文字幕| 色欧美88888久久久久久影院| 91久久亚洲| 欧美极品一区| 91视频精品在这里| 岛国av在线一区| 国产精品一二三区在线| 麻豆精品国产91久久久久久| 亚洲国产成人tv| 亚洲国产成人av| 亚洲影视在线观看| 亚洲一区自拍偷拍| 一区二区在线电影| 亚洲日本电影在线| 最新久久zyz资源站| 国产精品国产三级国产aⅴ中文| 国产亚洲成aⅴ人片在线观看| 精品国产一区久久| 欧美成人国产一区二区| 欧美一卡二卡在线| 欧美日韩国产乱码电影| 欧美日韩久久一区| 欧美精品久久久久久久多人混战| 在线观看日韩高清av| 日本韩国视频一区二区| 久久综合伊人77777麻豆| 久热精品在线| 欧洲亚洲精品在线| 欧美吻胸吃奶大尺度电影| 欧美性极品少妇| 欧美久久久久中文字幕| 69p69国产精品| 欧美老肥妇做.爰bbww视频| 欧美午夜精品一区二区蜜桃| 欧洲一区二区三区在线| 欧美在线制服丝袜| 精品视频一区三区九区| 欧美日韩精品一区二区三区| 欧美日韩不卡视频| 日韩欧美一区二区三区在线| 精品盗摄一区二区三区| 久久久久久久久一| 国产农村妇女毛片精品久久麻豆| 国产精品色哟哟网站| 亚洲精品国产成人久久av盗摄| 亚洲一区二区三区在线播放| 日韩精品国产精品| 久久91精品国产91久久小草| 国产一区二区免费在线| 高清不卡一区二区| 99re亚洲国产精品| 欧美女人交a| 99re热精品| 久久久久一区二区| 在线播放中文一区| 久久久久久久久久美女| 亚洲人成人一区二区在线观看| 亚洲国产综合91精品麻豆|