主頁 > 資料庫 > Greenplum資料庫中segment故障檢測

Greenplum資料庫中segment故障檢測

2023-05-18 08:48:31 資料庫

1.Greenplum資料庫中segment故障檢測

1.1概述

Greenplum資料庫服務器(Postgres)有一個子行程,該子行程為ftsprobe,主要作用是處理故障檢測, ftsprobe 監視Greenplum資料庫陣列,它以可以配置的間隔連接并掃描所有segment和資料庫行程,

如果 ftsprobe無法連接到segment,它會在Greenplum資料庫系統目錄中將segment標記為”down”,在管理員啟動恢復行程之前,該segment是不可以被操作的,

啟用mirror備份后,如果primary segment不可用,Greenplum資料庫會自動故障轉移到mirror segment,如果segment實體或主機發生故障,系統仍可以運行,前提是所有在剩余的活動segment上資料都可用,

要恢復失敗的segment,管理員需要執行 gprecoverseg 恢復工具,此工具可以找到失敗的segment,驗證它們是否有效,并將事務狀態與當前活動的segment進行比較,以確定在segment脫機時所做的更改,gprecoverseg將更改的資料庫檔案與活動segment同步,并使該segment重新上線,管理員需要在在Greenplum資料庫啟動并運行時執行恢復操作,

禁用mirror備份時,如果segment實體失敗,系統將會自動關閉,管理員需要手動恢復所有失敗的segment,

1.2檢測和管理失敗的segment

1.2.1使用工具命令查看

啟用mirror備份后,當primary segment發生故障時,Greenplum會自動故障轉移到mirror segment,如果每個資料部分所在的segment實體都是在線的,則用戶可能無法意識到segment已經出現故障,如果在發生故障時正在進行事務,則正在進行的事務將回滾并在重新配置的segment集上自動重新啟動,

如果整個Greenplum資料庫系統由于segment故障而變得不可訪問(例如,如果未啟用mirror備份或沒有足夠的segment在線),則用戶在嘗試連接資料庫時將看到錯誤,回傳到客戶端程式的錯誤可能表示失敗,例如:

ERROR: All segment databases are unavailable

(1)在master節點上,運行gpstate命令,使用-e引數顯示錯誤的segment

$ gpstate -e

   標記為Change Tracking的segment節點表明對應的mirror segment已經宕機,

(2)要獲取有關故障segment的詳細資訊,可以查看 gp_segment_configuration目錄表,

$ psql -c "SELECT * FROM gp_segment_configuration WHERE status='d';"

(3) 對于失敗的segment實體,記下主機,埠,初始化時的角色和資料目錄,此資訊將幫助確定要進行故障排除的主機和segment實體,

(4) 顯示mirror segment詳細資訊,運行下面命名:

$ gpstate -m

1.2.2檢查日志檔案

日志檔案可以提供資訊以幫助確定錯誤的原因,Master實體和segment實體都有自己的日志檔案,這些日志檔案位于pg_log的目錄下,Master的日志檔案包含最多資訊,應該首先檢查它,

使用 gplogfilter工具檢查Greenplum資料庫日志檔案,可以獲取額外資訊,要檢查segment日志檔案,可以在master主機上使用gpssh命令運行 gplogfilter,

       (1)使用 gplogfilter 檢查master日志檔案的WARNING, ERROR, FATAL 或者 PANIC日志級別訊息

$ gplogfilter -t

       (2)使用 gpssh 檢查每個segment實體上的日志級別為WARNING, ERROR, FATAL 或者 PANIC的訊息,例如:

$ gpssh -f seg_hosts_file -e 'source

/usr/local/greenplum-db/greenplum_path.sh ; gplogfilter -t

/data1/primary/*/pg_log/gpdb*.log' > seglog.out

2.恢復失敗的segment

如果master服務器無法連接到segment實體,則會在Greenplum資料庫系統目錄中將該segment標記為“down”狀態,在管理員采取措施使segment實體重新上線之前,segment實體將保持脫機離線狀態,segment實體可能由于多種原因而不可用:

(1)segment主機不可用; 例如,由于網路或硬體故障,

(2)segment實體未運行; 例如,沒Postgres的資料庫監聽行程,

(3)segment實體的資料目錄損壞或丟失; 例如,無法訪問資料,檔案系統已損壞或磁盤發生故障,

2.1在啟用mirror segment的情況下進行恢復

(1)確保master主機能夠ping通失敗的segment主機

$ ping failed_seg_host_address

(2)如果是阻止master主機連接segment主機,則可以重啟該segment主機,

(3)如果該segment主機上線之后,可以通過master連接,則在master主機上運行下面命令,重新**失敗的segment

$ gprecoverseg

(4)恢復行程會顯示故障segment并標識需要同步的已更改檔案,這個程序可能需要一些時間, 等待該程序完成,在此程序中,資料庫不允許寫入操作,

(5)在 gprecoverseg完成后,系統進入重新同步模式并開始復制已更改的檔案,當系統處于聯機狀態并接受資料庫請求時,此行程在后臺運行,

(6)重新同步程序完成后,系統狀態為“已同步”( Synchronized),運行gpstate 命令用于驗證重新同步程序狀態

$ gpstate -m

2.2將所有的segment恢復到原來的角色設定

當primary segment發生故障時,mirror segment會被**為primary segment,運行gprecoverseg命令之后,當前活動的segment是primary segment,失敗的primary segment成為了mirror segment,segment實體不會回傳到在系統初始化時配置的首選角色,這意味著某些segment主機上可能運行多個primary segment實體,而某些segment主機上運行較少的segment,即系統可能處于潛在的不平衡狀態,要檢查不平衡的segment并重新平衡系統,可以使用如下命令:

$ gpstate -e

所有segment必須在線并完全同步以重新平衡系統,資料庫會話在重新平衡期間保持連接,但正在進行的查詢將被取消并回滾,

(1)運行下面命令,查看mirror segment的角色和同步狀態

$ gpstate -m

(2)如果有mirror segment處于非同步狀態,等待他們同步完成

(3)運行gprecoverseg命令,使用-r引數將segment恢復到原來初始化時的角色設定

$ gprecoverseg -r

(4)運行gpstate -e命令,確認所有的segment是否恢復到初始化時的角色設定

$ gpstate -e

2.3從雙重故障中恢復

在雙重故障情況下,即primary segment和mirror segment都處于失敗狀態,如果不同segment的主機同時發生硬體故障,則會導致primary segment和mirror segment都處于失敗狀態,如果發生雙重故障,Greenplum資料庫將不可用,要從雙重故障中恢復,執行如下步驟:

(1)重啟greenplum資料庫

$ gpstop -r

(2)再重啟系統之后,運行gprecoverseg命令

$ gprecoverseg

(3)在gprecoverseg執行結束后,運行gpstate命令查看mirror狀態資訊

$gpstate -m

(4)如果segment仍是“Change Tracking”狀態,則運行下面命令:

$ gprecoverseg -F

2.4從segment主機故障中恢復

如果主機處于不可操作狀態(例如,由于硬體故障),可以將segment恢復到備用主機上,如果啟用了mirror segment,則可以使用gprecoverseg命令將mirror segment恢復到備用主機,例如:

$ gprecoverseg -i recover_config_file

生成的recover_config_file檔案的格式為:

filespaceOrder=[filespace1_name[:filespace2_name:...]failed_host_address:

port:fselocation [recovery_host_address:port:replication_port:fselocation

[:fselocation:...]]

   例如,要在沒有配置其他檔案空間的情況下恢復到與故障主機不同的另一臺主機(除了默認的pg_system檔案空間):

filespaceOrder=sdw5-2:50002:/gpdata/gpseg2 sdw9-2:50002:53002:/gpdata/gpseg2

該gp_segment_configuration和pg_filespace_entry系統目錄表可以幫助確定當前的段配置,這樣可以計劃mirror的恢復配置,例如,運行以下查詢:

=# SELECT dbid, content, hostname, address, port,

replication_port, fselocation as datadir

FROM gp_segment_configuration, pg_filespace_entry

WHERE dbid=fsedbid

ORDER BY dbid;

轉自于:https://www.likecs.com/show-203344428.html#sc=1900

轉載請註明出處,本文鏈接:https://www.uj5u.com/shujuku/552744.html

標籤:大數據

上一篇:提高資料的安全性和可控性,數堆疊基于 Ranger 實作的 Spark SQL 權限控制實踐之路

下一篇:返回列表

標籤雲
其他(159240) Python(38148) JavaScript(25433) Java(18055) C(15228) 區塊鏈(8267) C#(7972) AI(7469) 爪哇(7425) MySQL(7191) html(6777) 基礎類(6313) sql(6102) 熊猫(6058) PHP(5871) 数组(5741) R(5409) Linux(5340) 反应(5209) 腳本語言(PerlPython)(5129) 非技術區(4971) Android(4572) 数据框(4311) css(4259) 节点.js(4032) C語言(3288) json(3245) 列表(3129) 扑(3119) C++語言(3117) 安卓(2998) 打字稿(2995) VBA(2789) Java相關(2746) 疑難問題(2699) 细绳(2522) 單片機工控(2479) iOS(2433) ASP.NET(2403) MongoDB(2323) 麻木的(2285) 正则表达式(2254) 字典(2211) 循环(2198) 迅速(2185) 擅长(2169) 镖(2155) .NET技术(1975) 功能(1967) Web開發(1951) HtmlCss(1938) python-3.x(1918) C++(1917) 弹簧靴(1913) xml(1889) PostgreSQL(1878) .NETCore(1861) 谷歌表格(1846) Unity3D(1843) for循环(1842)

熱門瀏覽
  • GPU虛擬機創建時間深度優化

    **?桔妹導讀:**GPU虛擬機實體創建速度慢是公有云面臨的普遍問題,由于通常情況下創建虛擬機屬于低頻操作而未引起業界的重視,實際生產中還是存在對GPU實體創建時間有苛刻要求的業務場景。本文將介紹滴滴云在解決該問題時的思路、方法、并展示最終的優化成果。 從公有云服務商那里購買過虛擬主機的資深用戶,一 ......

    uj5u.com 2020-09-10 06:09:13 more
  • 可編程網卡芯片在滴滴云網路的應用實踐

    **?桔妹導讀:**隨著云規模不斷擴大以及業務層面對延遲、帶寬的要求越來越高,采用DPDK 加速網路報文處理的方式在橫向縱向擴展都出現了局限性。可編程芯片成為業界熱點。本文主要講述了可編程網卡芯片在滴滴云網路中的應用實踐,遇到的問題、帶來的收益以及開源社區貢獻。 #1. 資料中心面臨的問題 隨著滴滴 ......

    uj5u.com 2020-09-10 06:10:21 more
  • 滴滴資料通道服務演進之路

    **?桔妹導讀:**滴滴資料通道引擎承載著全公司的資料同步,為下游實時和離線場景提供了必不可少的源資料。隨著任務量的不斷增加,資料通道的整體架構也隨之發生改變。本文介紹了滴滴資料通道的發展歷程,遇到的問題以及今后的規劃。 #1. 背景 資料,對于任何一家互聯網公司來說都是非常重要的資產,公司的大資料 ......

    uj5u.com 2020-09-10 06:11:05 more
  • 滴滴AI Labs斬獲國際機器翻譯大賽中譯英方向世界第三

    **桔妹導讀:**深耕人工智能領域,致力于探索AI讓出行更美好的滴滴AI Labs再次斬獲國際大獎,這次獲獎的專案是什么呢?一起來看看詳細報道吧! 近日,由國際計算語言學協會ACL(The Association for Computational Linguistics)舉辦的世界最具影響力的機器 ......

    uj5u.com 2020-09-10 06:11:29 more
  • MPP (Massively Parallel Processing)大規模并行處理

    1、什么是mpp? MPP (Massively Parallel Processing),即大規模并行處理,在資料庫非共享集群中,每個節點都有獨立的磁盤存盤系統和記憶體系統,業務資料根據資料庫模型和應用特點劃分到各個節點上,每臺資料節點通過專用網路或者商業通用網路互相連接,彼此協同計算,作為整體提供 ......

    uj5u.com 2020-09-10 06:11:41 more
  • 滴滴資料倉庫指標體系建設實踐

    **桔妹導讀:**指標體系是什么?如何使用OSM模型和AARRR模型搭建指標體系?如何統一流程、規范化、工具化管理指標體系?本文會對建設的方法論結合滴滴資料指標體系建設實踐進行解答分析。 #1. 什么是指標體系 ##1.1 指標體系定義 指標體系是將零散單點的具有相互聯系的指標,系統化的組織起來,通 ......

    uj5u.com 2020-09-10 06:12:52 more
  • 單表千萬行資料庫 LIKE 搜索優化手記

    我們經常在資料庫中使用 LIKE 運算子來完成對資料的模糊搜索,LIKE 運算子用于在 WHERE 子句中搜索列中的指定模式。 如果需要查找客戶表中所有姓氏是“張”的資料,可以使用下面的 SQL 陳述句: SELECT * FROM Customer WHERE Name LIKE '張%' 如果需要 ......

    uj5u.com 2020-09-10 06:13:25 more
  • 滴滴Ceph分布式存盤系統優化之鎖優化

    **桔妹導讀:**Ceph是國際知名的開源分布式存盤系統,在工業界和學術界都有著重要的影響。Ceph的架構和演算法設計發表在國際系統領域頂級會議OSDI、SOSP、SC等上。Ceph社區得到Red Hat、SUSE、Intel等大公司的大力支持。Ceph是國際云計算領域應用最廣泛的開源分布式存盤系統, ......

    uj5u.com 2020-09-10 06:14:51 more
  • es~通過ElasticsearchTemplate進行聚合~嵌套聚合

    之前寫過《es~通過ElasticsearchTemplate進行聚合操作》的文章,這一次主要寫一個嵌套的聚合,例如先對sex集合,再對desc聚合,最后再對age求和,共三層嵌套。 Aggregations的部分特性類似于SQL語言中的group by,avg,sum等函式,Aggregation ......

    uj5u.com 2020-09-10 06:14:59 more
  • 爬蟲日志監控 -- Elastc Stack(ELK)部署

    傻瓜式部署,只需替換IP與用戶 導讀: 現ELK四大組件分別為:Elasticsearch(核心)、logstash(處理)、filebeat(采集)、kibana(可視化) 下載均在https://www.elastic.co/cn/downloads/下tar包,各組件版本最好一致,配合fdm會 ......

    uj5u.com 2020-09-10 06:15:05 more
最新发布
  • Greenplum資料庫中segment故障檢測

    1.Greenplum資料庫中segment故障檢測 1.1概述 Greenplum資料庫服務器(Postgres)有一個子行程,該子行程為ftsprobe,主要作用是處理故障檢測。 ftsprobe 監視Greenplum資料庫陣列,它以可以配置的間隔連接并掃描所有segment和資料庫行程。 如 ......

    uj5u.com 2023-05-18 08:48:31 more
  • 提高資料的安全性和可控性,數堆疊基于 Ranger 實作的 Spark SQL

    在企業級應用中,資料的安全性和隱私保護是極其重要的。Spark 作為數堆疊底層計算引擎之一,必須確保資料只能被授權的人員訪問,避免出現資料泄露和濫用的情況。為了實作Spark SQL 對資料的精細化管理及提高資料的安全性和可控性,數堆疊基于 Apache Ranger 實作了 Spark SQL 對資料 ......

    uj5u.com 2023-05-18 08:48:21 more
  • 單表查詢

    第一章 簡單查詢 1.1、select陳述句 mysql 中查詢資料的基本陳述句是select陳述句。 語法: select [distinct] 欄位1,欄位2,欄位3..... from 表名 [where 條件運算式] [group by 欄位名] [having 條件運算式] [order by ......

    uj5u.com 2023-05-16 22:26:48 more
  • PostgreSQL一站式插件推薦 -- pg_enterprise_views

    近日發現PG官方插件串列中新收錄了一款插件 pg_enterprise_views,因為官方已經數年未添新的插件了很是新奇,找了臺設備測驗過后果斷上了生產,得空分享給大家。 該插件提供了數十張系統表及一個GUI工具,用以監控從作業系統到資料庫方方面面的性能情況,并支持對任意時段歷史資料的回溯,基本等 ......

    uj5u.com 2023-05-16 22:26:12 more
  • PostgreSQL一站式插件推薦 -- pg_enterprise_views

    近日發現PG官方插件串列中新收錄了一款插件 pg_enterprise_views,因為官方已經數年未添新的插件了很是新奇,找了臺設備測驗過后果斷上了生產,得空分享給大家。 該插件提供了數十張系統表及一個GUI工具,用以監控從作業系統到資料庫方方面面的性能情況,并支持對任意時段歷史資料的回溯,基本等 ......

    uj5u.com 2023-05-16 22:12:18 more
  • 單表查詢

    第一章 簡單查詢 1.1、select陳述句 mysql 中查詢資料的基本陳述句是select陳述句。 語法: select [distinct] 欄位1,欄位2,欄位3..... from 表名 [where 條件運算式] [group by 欄位名] [having 條件運算式] [order by ......

    uj5u.com 2023-05-16 22:10:09 more
  • hive 從入門到精通

    hive入門到精通 hive部署 啟動Hadoop # 啟動hadoop start-all.sh # 檢查hadoop行程 jps # 檢查各埠 netstat -aplnt | grep java 檢查MySQL是否啟動成功 ps -aux | grep mysql netstat -apln ......

    uj5u.com 2023-05-16 15:32:25 more
  • pg_enterprise_views偶然發現的PG神仙插件!

    一直從事資料庫相關的作業,對于PG而言最大的問題其實是在運維管理方面,其缺乏有效且直觀成體系的系統表,苦覓良久,今日在PG官網中發現了一款新收錄的免費插件,其提供了數十張系統表,內容涵蓋了從作業系統到資料庫的負載指標、等待事件、會話、客戶端、SQL、SQL執行計劃、超時鎖、長事務、資料庫物件、寫行程 ......

    uj5u.com 2023-05-16 15:32:13 more
  • MySQL 8.0不再擔心被垃圾SQL搞爆記憶體

    MySQL 8.0.28引入的新功能 MySQL 8.0.28開始,新增一個特性,支持監控統計并限制各個連接(會話)的記憶體消耗,避免大量用戶連接因為執行垃圾SQL消耗過多記憶體,造成可能被OOM kill的風險。 首先,需要先設定系統選項 global_connection_memory_tracki ......

    uj5u.com 2023-05-16 15:31:01 more
  • ClickHouse筆記: Ubuntu/Centos下的安裝, 配置和用戶管理

    ClickHouse 屬于 OLAP 資料庫, 與 OLTP (Transaction Process) 相比, 注重資料分析, 重點在查詢的性能. 在業務系統中, 往往使用 OLTP 資料庫做業務資料存盤, 用 OLAP 資料庫做查詢分析, 在一些場景下ClickHouse可以取代ES(Elast... ......

    uj5u.com 2023-05-16 15:30:55 more