婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

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

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

熱門(mén)標(biāo)簽:長(zhǎng)沙電銷(xiāo)外呼防封卡是什么 小裙科技電銷(xiāo)機(jī)器人怎樣 青白江400企業(yè)電話申請(qǐng) 外呼線路資源屬于電信業(yè)務(wù)嗎 智能外呼系統(tǒng)官網(wǎng) 內(nèi)蒙古營(yíng)銷(xiāo)智能外呼系統(tǒng)哪個(gè)好 呼和浩特外呼系統(tǒng)原理是什么 crm外呼系統(tǒng)聯(lián)系方式 河南電話外呼系統(tǒng)招商

背景

數(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í)行成功,不管怎樣都要寫(xiě)對(duì)于的WAL日志,還有CLOG,然后數(shù)據(jù)庫(kù)要將執(zhí)行結(jié)果返回給客戶端ACK。

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

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

UNKNOWN 事務(wù)的處理

unknown事務(wù),就是客戶端沒(méi)有收到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)問(wèn)題

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

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

2、非兩階段事務(wù),rollback unknown無(wú)須處理,rollback失敗或成功對(duì)于客戶端來(lái)說(shuō)結(jié)果是一樣的。因?yàn)椴还茉鯓佣紩?huì)回滾掉,這是數(shù)據(jù)庫(kù)原子性保障的。

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

事務(wù)開(kāi)始時(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)來(lái)查看事務(wù)是否提交。這里利用了事務(wù)的原子特性,既要么全成功要么全失敗。可以舉個(gè)使用例子。

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

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

您可能感興趣的文章:
  • PostgreSQL存儲(chǔ)過(guò)程用法實(shí)戰(zhàn)詳解
  • Mybatis調(diào)用PostgreSQL存儲(chǔ)過(guò)程實(shí)現(xiàn)數(shù)組入?yún)鬟f
  • PostgreSQL中調(diào)用存儲(chǔ)過(guò)程并返回?cái)?shù)據(jù)集實(shí)例
  • 初識(shí)PostgreSQL存儲(chǔ)過(guò)程
  • PostgreSQL教程(十六):系統(tǒng)視圖詳解
  • 15個(gè)postgresql數(shù)據(jù)庫(kù)實(shí)用命令分享
  • PostgreSQL 安裝和簡(jiǎn)單使用
  • PostgreSQL 創(chuàng)建表分區(qū)
  • PostgreSQL新手入門(mén)教程
  • Postgresql ALTER語(yǔ)句常用操作小結(jié)
  • PostgreSQL數(shù)據(jù)庫(kù)事務(wù)實(shí)現(xiàn)方法分析

標(biāo)簽:舟山 黃石 楚雄 白山 菏澤 呼倫貝爾 安順 池州

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《PostgreSQL數(shù)據(jù)庫(kù)事務(wù)出現(xiàn)未知狀態(tài)的處理方法》,本文關(guān)鍵詞  PostgreSQL,數(shù)據(jù)庫(kù),事務(wù),出現(xiàn),;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問(wèn)題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《PostgreSQL數(shù)據(jù)庫(kù)事務(wù)出現(xiàn)未知狀態(tài)的處理方法》相關(guān)的同類(lèi)信息!
  • 本頁(yè)收集關(guān)于PostgreSQL數(shù)據(jù)庫(kù)事務(wù)出現(xiàn)未知狀態(tài)的處理方法的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    主站蜘蛛池模板: 香格里拉县| 融水| 彭水| 闽侯县| 大宁县| 通化市| 汾西县| 时尚| 武清区| 桦川县| 长阳| 满洲里市| 海门市| 通城县| 柞水县| 黄陵县| 谷城县| 会宁县| 咸阳市| 阆中市| 卢龙县| 本溪市| 五家渠市| 小金县| 宣化县| 白水县| 于都县| 长沙县| 和田市| 尉犁县| 灯塔市| 三原县| 鹤壁市| 光泽县| 土默特左旗| 大城县| 四子王旗| 丹巴县| 宁德市| 葵青区| 通河县|