MySQL數(shù)據(jù)庫中間件如何實現(xiàn)分布式事務(wù)
問題描述
假設(shè)我有兩個MySQL數(shù)據(jù)庫節(jié)點,在這兩個節(jié)點前面有一個數(shù)據(jù)庫中間件,應(yīng)用通過數(shù)據(jù)庫中間件來使用后面的兩個MySQL節(jié)點, 結(jié)構(gòu)如下圖所示:
當應(yīng)用通過中間件執(zhí)行一個事務(wù)時,這個事務(wù)需要由中間件轉(zhuǎn)發(fā)給兩個MySQL節(jié)點,于是在中間件這一層,原本普通的事務(wù)現(xiàn)在升級成了跨越兩個MySQL節(jié)點的分布式事務(wù)。對于應(yīng)用程序來說,應(yīng)用程序希望這個事務(wù)要么都被兩個MySQL節(jié)點執(zhí)行成功,要么都不成功。
當應(yīng)用程序begin了事務(wù),執(zhí)行一系列SQL語句后,應(yīng)用程序進行commit,此時數(shù)據(jù)庫中間件會分別向兩個MySQL節(jié)點發(fā)送commit命令,假設(shè)兩個MySQL節(jié)點都接收到了commit命令,并成功提交,那么事務(wù)執(zhí)行成功。如果其中一個節(jié)點commit成功,而另外一個節(jié)點由于一些原因無法執(zhí)行commit(可能網(wǎng)絡(luò)斷開,或者MySQL數(shù)據(jù)庫出現(xiàn)錯誤),又由于已經(jīng)commit的事務(wù)無法rollback,所以此時兩個MySQL節(jié)點就出現(xiàn)了數(shù)據(jù)不一致的情況。
我的問題是:目前是否有上述問題的解決方法或解決思路,先謝謝了
問題解答
回答1:xa
事務(wù)資源預分配
業(yè)務(wù)原子操作
相關(guān)文章:
1. javascript - 分類編輯保留之前分類名稱2. css - 移動端 line-height安卓錯位,蘋果機正常用,縮放解決了,可是又出來了占位的問題3. 求救一下,用新版的phpstudy,數(shù)據(jù)庫過段時間會消失是什么情況?4. javascript - 彈出一個子窗口,操作之后關(guān)閉,主窗口會得到相應(yīng)的響應(yīng),例如網(wǎng)站的某些登錄界面,django后臺的管理等,這是怎么實現(xiàn)的呢?5. javascript - 函數(shù)設(shè)置參數(shù)默認值的問題6. list - python 求助7. javascript 的console.log 問題8. 環(huán)境搭建 - anaconda 創(chuàng)建python2.7環(huán)境中打開編譯器確是3.6版本9. mysql replace 死鎖10. extra沒有加載出來
