好湿?好紧?好多水好爽自慰,久久久噜久噜久久综合,成人做爰A片免费看黄冈,机机对机机30分钟无遮挡

主頁 > 知識庫 > PostgreSQL數據庫事務出現未知狀態的處理方法

PostgreSQL數據庫事務出現未知狀態的處理方法

熱門標簽:長沙電銷外呼防封卡是什么 小裙科技電銷機器人怎樣 青白江400企業電話申請 外呼線路資源屬于電信業務嗎 智能外呼系統官網 內蒙古營銷智能外呼系統哪個好 呼和浩特外呼系統原理是什么 crm外呼系統聯系方式 河南電話外呼系統招商

背景

數據庫的事務是原子操作,要么成功,要么失敗。但是實際上在客戶端的視角,可能有第三種狀態:unknown狀態。

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

這里存在幾種可能,導致客戶端不知道執行到底怎么樣了?

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

UNKNOWN 事務的處理

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

多節點(quorum based sync replication)與單節點都可能出現UNKNOWN事務,效果、形態一致。

如何處理unknown事務呢?

unknown事務分為以下幾種情況.

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

1、兩階段解決unknown狀態問題

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

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

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

3、非兩階段事務,commit unknown處理,極度嚴謹的場景,程序可以設計事務狀態可回溯,例如:

事務開始時,記錄事務號或唯一流水號,事務號在數據庫中是一個唯一的流水,可以根據事務號查詢它的狀態,比如postgresql。

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

使用業務流水實現事務狀態判斷的例子:

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

您可能感興趣的文章:
  • PostgreSQL存儲過程用法實戰詳解
  • Mybatis調用PostgreSQL存儲過程實現數組入參傳遞
  • PostgreSQL中調用存儲過程并返回數據集實例
  • 初識PostgreSQL存儲過程
  • PostgreSQL教程(十六):系統視圖詳解
  • 15個postgresql數據庫實用命令分享
  • PostgreSQL 安裝和簡單使用
  • PostgreSQL 創建表分區
  • PostgreSQL新手入門教程
  • Postgresql ALTER語句常用操作小結
  • PostgreSQL數據庫事務實現方法分析

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

巨人網絡通訊聲明:本文標題《PostgreSQL數據庫事務出現未知狀態的處理方法》,本文關鍵詞  PostgreSQL,數據庫,事務,出現,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《PostgreSQL數據庫事務出現未知狀態的處理方法》相關的同類信息!
  • 本頁收集關于PostgreSQL數據庫事務出現未知狀態的處理方法的相關信息資訊供網民參考!
  • 推薦文章
    主站蜘蛛池模板: 欧美乱论| 聂小雨无码AV无码视频| 精品一区二区三区免费站| 全程露脸4p继续战斗| 新3D金?梅龚玥菲正片| 日本少妇婬乱高潮AAAA片| 乱肥老妇| 好属妞这里只有精品久久| 国产成人久久久日韩美女网站直播| 亚洲AV国产日韩丝袜在线| 欧美激情一区二区三区在线| 男女狂吻捏胸扒内裤内衣长视频| 色一情一欲一爱一乱相关话题| 最新亚洲AV一区二区精品莹莹| 国产精品视频第二区第二页| 欧美激情伦理| 凌霄之上| 日本少妇高潮XXXXⅩOOO| 99久久精品国产毛片| 国产高清亚洲精品26u| 欧美三级视频在线观看| 李恩美三级无删减版电影| 免费观看欧美成人AA片爱我多深| 手机看片一区二区| 我和黑帮大佬的365天第二部 | 一本一道精品无码亚洲道久久| 辣妹子影院在线观看电视剧高清| 男女吃奶一进一出动态图| 村上丽奈所有三级作品| 伸入乳罩揉她的乳尖| 性色A片三級三級三級鸭王争锋 | 窥情窃爱全文免费阅读| 许晴被强扒裤衩露出奶头| 性色蜜月aV一区二区三区小说| 成人久久久精品乱码一区二区三区 | 很黄很刺激小说| 国产99久一区二区三区A片| 57pao成人免费一二区| 嗯啊灬别停啊灬用力灬| 国产成人免费高清在线观看| 女人用手帮男人自慰|