欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

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

 更新時間:2017年07月16日 09:50:35   投稿:hebedich  
這篇文章主要給大家介紹了PostgreSQL數(shù)據(jù)庫事務(wù)出現(xiàn)未知狀態(tài)的處理方法,需要的朋友可以參考下

背景

數(shù)據(jù)庫的事務(wù)是原子操作,要么成功,要么失敗。但是實際上在客戶端的視角,可能有第三種狀態(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é)點(quorum based sync replication)與單節(jié)點都可能出現(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ù)流水實現(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ù)是原子操作) 

相關(guān)文章

  • PostgreSQL入門簡介

    PostgreSQL入門簡介

    PostgreSQL是一個免費的對象-關(guān)系型數(shù)據(jù)庫服務(wù)器(ORDBMS),遵循靈活的開源協(xié)議BSD。這篇文章主要介紹了PostgreSQL入門簡介,需要的朋友可以參考下
    2020-12-12
  • Postgresql查詢效率計算初探

    Postgresql查詢效率計算初探

    這篇文章主要給大家介紹了關(guān)于Postgresql查詢效率計算的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家學(xué)習(xí)或者使用Postgresql具有一定的參考學(xué)習(xí)價值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-05-05
  • 基于PostgreSQL 權(quán)限解讀

    基于PostgreSQL 權(quán)限解讀

    這篇文章主要介紹了基于PostgreSQL 權(quán)限解讀,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2021-01-01
  • PostgreSQL之pgdump備份恢復(fù)操作

    PostgreSQL之pgdump備份恢復(fù)操作

    這篇文章主要介紹了PostgreSQL之pgdump備份恢復(fù)操作,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-12-12
  • postgres之jsonb屬性的使用操作

    postgres之jsonb屬性的使用操作

    這篇文章主要介紹了postgres之jsonb屬性的使用操作,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2021-06-06
  • Postgresql通過查詢進(jìn)行更新的操作

    Postgresql通過查詢進(jìn)行更新的操作

    這篇文章主要介紹了Postgresql通過查詢進(jìn)行更新的操作,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2021-01-01
  • 快速解決PostgreSQL中的Permission denied問題

    快速解決PostgreSQL中的Permission denied問題

    這篇文章主要介紹了快速解決PostgreSQL中的Permission denied問題,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2021-01-01
  • PostgreSQL配置遠(yuǎn)程連接簡單圖文教程

    PostgreSQL配置遠(yuǎn)程連接簡單圖文教程

    這篇文章主要給大家介紹了關(guān)于PostgreSQL配置遠(yuǎn)程連接的相關(guān)資料,PostgreSQL是一個功能非常強(qiáng)大的關(guān)系型數(shù)據(jù)庫管理系統(tǒng)(RDBMS),文中通過代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2023-12-12
  • PostgreSQL模式匹配與正則表達(dá)式方法總結(jié)

    PostgreSQL模式匹配與正則表達(dá)式方法總結(jié)

    在postgresql中使用正則表達(dá)式時需要使用關(guān)鍵字“~”,以表示該關(guān)鍵字之前的內(nèi)容需匹配之后的正則表達(dá)式,這篇文章主要給大家介紹了關(guān)于PostgreSQL模式匹配與正則表達(dá)式的相關(guān)資料,需要的朋友可以參考下
    2022-11-11
  • PostgreSQL中的OID和XID 說明

    PostgreSQL中的OID和XID 說明

    在PostgreSQL中經(jīng)常碰到OID和XID,剛才不明白這些東西是干什么的。
    2009-09-09

最新評論