下載吧 - 綠色安全的游戲和軟件下載中心

          軟件下載吧

          當(dāng)前位置:軟件下載吧 > 技術(shù)開發(fā) > 數(shù)據(jù)庫 > PostgreSQL數(shù)據(jù)庫事務(wù)出現(xiàn)未知狀態(tài)的處理方法

          PostgreSQL數(shù)據(jù)庫事務(wù)出現(xiàn)未知狀態(tài)的處理方法

          時間:2024-02-14 10:20作者:下載吧人氣:40

          背景

          數(shù)據(jù)庫的事務(wù)是原子操作,要么成功,要么失敗。但是實(shí)際上在客戶端的視角,可能有第三種狀態(tài):unknown狀態(tài)。

          當(dāng)客戶端提交事務(wù)結(jié)束(rollback , commit , prepare xact , rollback pxact , commit pxact)的請求后,數(shù)據(jù)庫收到請求,數(shù)據(jù)庫可能執(zhí)行失敗,也可能執(zhí)行成功,不管怎樣都要寫對于的WAL日志,還有CLOG,然后數(shù)據(jù)庫要將執(zhí)行結(jié)果返回給客戶端ACK。

          這里存在幾種可能,導(dǎo)致客戶端不知道執(zhí)行到底怎么樣了?

          收到客戶端請求后,數(shù)據(jù)庫沒有返回任何ACK給客戶端,客戶端對這次請求很茫然,它只能人為數(shù)據(jù)庫處于UNKNOWN的狀態(tài)。

          UNKNOWN 事務(wù)的處理

          unknown事務(wù),就是客戶端沒有收到commit/rollback ACK的事務(wù)。不知道是成功還是失敗。

          多節(jié)點(diǎn)(quorum based sync replication)與單節(jié)點(diǎn)都可能出現(xiàn)UNKNOWN事務(wù),效果、形態(tài)一致。

          如何處理unknown事務(wù)呢?

          unknown事務(wù)分為以下幾種情況.

          rollback , commit , prepare xact , rollback pxact , commit pxact 幾種情況的unknown處理方法:

          1、兩階段解決unknown狀態(tài)問題

          prepare 階段unknown, 切換leader后,客戶端通過pg_prepared_xacts視圖檢查prepare xact狀態(tài),如果沒有prepare xact則說明失敗了,那么整個事務(wù)重新發(fā)起即可。如果prepare xact存在,說明prepare xact成功了。

          commit or rollback prepare xact階段unknown, 切換后檢查prepare xact狀態(tài),存在則重試commit or rollback prepare xact。不存在則說明已經(jīng)成功(我們認(rèn)為2PC是一定成功的),無須處理。

          2、非兩階段事務(wù),rollback unknown無須處理,rollback失敗或成功對于客戶端來說結(jié)果是一樣的。因為不管怎樣都會回滾掉,這是數(shù)據(jù)庫原子性保障的。

          3、非兩階段事務(wù),commit unknown處理,極度嚴(yán)謹(jǐn)?shù)膱鼍埃绦蚩梢栽O(shè)計事務(wù)狀態(tài)可回溯,例如:

          事務(wù)開始時,記錄事務(wù)號或唯一流水號,事務(wù)號在數(shù)據(jù)庫中是一個唯一的流水,可以根據(jù)事務(wù)號查詢它的狀態(tài),比如postgresql。

          但是并不是所有數(shù)據(jù)庫都有這種接口,比如非物理流式復(fù)制的數(shù)據(jù)庫,則可以在事務(wù)中增加全局唯一流水號來查看事務(wù)是否提交。這里利用了事務(wù)的原子特性,既要么全成功要么全失敗。可以舉個使用例子。

          使用業(yè)務(wù)流水實(shí)現(xiàn)事務(wù)狀態(tài)判斷的例子:

          begin; 
          生成唯一業(yè)務(wù)流水ID, 寫入到某個流水表,同時在程序或其他數(shù)據(jù)庫中記錄這個流水號,備查。 
          執(zhí)行事務(wù) 
          提交事務(wù); 
           
          — 出現(xiàn)unknown 
           
          通過唯一業(yè)務(wù)流水ID,查詢數(shù)據(jù)庫中是否存在這條記錄。 
          如果不存在,說明事務(wù)提交失敗。 
          如果存在,說明事務(wù)提交成功。(因為數(shù)據(jù)庫的事務(wù)是原子操作) 

          標(biāo)簽[db:關(guān)鍵字]

          相關(guān)下載

          查看所有評論+

          網(wǎng)友評論

          網(wǎng)友
          您的評論需要經(jīng)過審核才能顯示

          熱門閱覽

          最新排行

          公眾號

          主站蜘蛛池模板: 亚洲福利视频一区二区| 久久久久人妻一区二区三区vr| 麻豆天美国产一区在线播放| 国产精品视频分类一区| 国产精品久久久久一区二区 | 99热门精品一区二区三区无码| 日本精品啪啪一区二区三区| 色狠狠一区二区三区香蕉蜜桃| 亚洲AV成人精品日韩一区| 国模无码人体一区二区| 福利一区二区三区视频午夜观看| 久久久无码一区二区三区| 精品国产一区二区三区AV性色 | 国产伦理一区二区| 一区二区网站在线观看| 精品女同一区二区三区免费站| 国产精品一区二区在线观看| 国产精品第一区揄拍| 久久99精品一区二区三区| 中文字幕在线视频一区| 免费国产在线精品一区| 国产视频一区在线播放| 日韩精品人妻一区二区三区四区| 熟妇人妻AV无码一区二区三区| 精品国产一区二区22| 色综合视频一区二区三区| 国产成人精品一区二三区| 麻豆国产在线不卡一区二区| 精品无码一区二区三区电影 | 日韩一区二区在线视频| 久久久无码精品国产一区| 又硬又粗又大一区二区三区视频| 国产福利电影一区二区三区久久老子无码午夜伦不 | 亚洲AV无码一区二区三区国产 | 一区二区三区四区在线播放| 国产色欲AV一区二区三区| 精品国产一区二区三区在线 | 日韩精品中文字幕无码一区 | 国产一区二区三区小向美奈子 | 中文字幕日韩人妻不卡一区| 国产在线视频一区|