日韩小视频-日韩久久一区二区三区-日韩久久一级毛片-日韩久久久精品中文字幕-国产精品亚洲精品影院-国产精品亚洲欧美云霸高清

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

軟件下載吧

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

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

時(shí)間:2024-02-14 10:20作者:下載吧人氣:39

背景

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

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

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

收到客戶端請(qǐng)求后,數(shù)據(jù)庫(kù)沒有返回任何ACK給客戶端,客戶端對(duì)這次請(qǐng)求很茫然,它只能人為數(shù)據(jù)庫(kù)處于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則說明失敗了,那么整個(gè)事務(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失敗或成功對(duì)于客戶端來說結(jié)果是一樣的。因?yàn)椴还茉鯓佣紩?huì)回滾掉,這是數(shù)據(jù)庫(kù)原子性保障的。

3、非兩階段事務(wù),commit unknown處理,極度嚴(yán)謹(jǐn)?shù)膱?chǎng)景,程序可以設(shè)計(jì)事務(wù)狀態(tài)可回溯,例如:

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

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

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

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

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

相關(guān)下載

查看所有評(píng)論+

網(wǎng)友評(píng)論

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

熱門閱覽

最新排行

公眾號(hào)

主站蜘蛛池模板: 欧美高清在线视频一区二区 | 久久影视一区 | 亚洲欧美一区在线 | 美女被拍拍拍拍拍拍拍拍 | 成人国产精品999视频 | 男人桶女人暴爽的视频 | 欧美成人免费夜夜黄啪啪 | 精品一区二区三区高清免费不卡 | 男人好大好硬好爽免费视频 | 91久久国产综合精品女同国语 | 高清一区在线 | 欧美一级永久免费毛片在线 | 成人18免费视频 | 国产一区二三区 | 久久只有这才是精品99 | 欧美国产一区二区三区 | 最刺激黄a大片免费观看下截 | 欧美特黄三级成人 | 久久精品视频在线观看 | 欧美一区二区三区四区在线观看 | 欧美人与zoxxxx另类9 | 免费看日韩欧美一级毛片 | 91香蕉国产在线观看免费永久 | 国产天堂在线一区二区三区 | 成人免费视频日本 | 免费一级特黄 | 99久久精品国产一区二区三区 | 中文国产成人精品久久水 | 色偷偷亚洲第一成人综合网址 | 国产精品一在线观看 | 韩国一级毛片大全女教师 | 亚洲毛片视频 | 久久99国产乱子伦精品免费 | 国产在线视频欧美亚综合 | 国产亚洲精品线观看77 | 亚洲精品亚洲人成毛片不卡 | 做爰www免费看视频 1024色淫免费视频 | 久久久91精品国产一区二区 | 2022免费国产精品福利在线 | 欧美精品一区二区三区在线 | 在线观看一区二区三区四区 |