IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 大数据 -> 【参赛作品24】MogDB/openGauss与PG的repmgr对比 -> 正文阅读

[大数据]【参赛作品24】MogDB/openGauss与PG的repmgr对比

作者:阎书利
提到PG的repmgr,大家可能并不陌生,他是现在PG比较流行的一套开源工具,用于管理PostgreSQL服务器集群中的复制管理和故障转移,也就是相当于一个集群管理+HA工具。当前PG的高可用方案,大致有keepalived、pgpool、repmgr、pacemaker+corosync、etcd+patroni等等。其中etcd+patroni和repmgr是目前用的较多的高可用。patroni的话需要至少三个以上且为奇数的 etcd 节点,而且大部分参数都需要通过更改 etcd 中键值来修改。而repmgr相对来说配置简单、添加节点比较方便。

从openGauss数据库开源以来,也研究MogDB/openGauss一年了,个人感觉MogDB/openGauss加上云和恩墨自主研发的MogHA高可用工具 和 PG的repmgr高可用方案比较类似。

众所周知MogDB/openGauss数据库是基于PostgreSQL研发而出,因此一些功能和工具也比较类似。

工具的话比较常用的gs_basebackup/pg_basebackup,gs_probackup/pg_probackup,pg_resetxlog等等。今天对于工具这边就不做详细说明了。如下,是我对MogDB/openGauss集群管理、MogHA高可用软件以及PG的repmgr相对应的功能的一些对比。接触过MogDB/openGauss或者repmgr单一一种的可以试着了解一下另外一部分的,上手应该会比较快。

1.查看集群状态
2.MogDB/openGauss全量build  & repmgr clone
3.MogDB/openGauss增量build & repmgr node rejoin --force-rewind
4.switchover
5.MogDB/openGauss高可用工具MogHA & repmgr 切换

一、查看集群状态

1.MogHA/openGauss:

MogHA/openGauss的数据库可以通过OM工具来查看集群状态。


     [omm@node1 ~]$ gs_om -t status --detail
    [   Cluster State   ]
cluster_state   : Normal
redistributing  : No
current_az      : AZ_ALL

[  Datanode State   ]

## node     node_ip         instance                  state            | node     node_ip         instance                  state

1  node1 172.20.10.7     6001 /gaussdb/data/dn1 P Primary Normal | 2  node2 172.20.10.8     6002 /gaussdb/data/dn1 S Standby Normal

2.PG repmgr

    /home/postgres/repmgr-5.1.0/repmgr -f /home/postgres/repmgr.conf cluster show
DEBUG: connecting to: "user=repmgr connect_timeout=2 dbname=repmgr host=172.20.10.1 port=6000 fallback_application_name=repmgr"
DEBUG: connecting to: "user=repmgr connect_timeout=2 dbname=repmgr host=172.20.10.1 port=6000 fallback_application_name=repmgr"
DEBUG: connecting to: "user=repmgr connect_timeout=2 dbname=repmgr host=172.20.10.2 port=6000 fallback_application_name=repmgr"
DEBUG: connecting to: "user=repmgr connect_timeout=2 dbname=repmgr host=172.20.10.1 port=6000 fallback_application_name=repmgr"
DEBUG: connecting to: "user=repmgr connect_timeout=2 dbname=repmgr host=172.20.10.3 port=6000 fallback_application_name=repmgr"
DEBUG: connecting to: "user=repmgr connect_timeout=2 dbname=repmgr host=172.20.10.1 port=6000 fallback_application_name=repmgr"
 ID | Name        | Role    | Status    | Upstream    | Location | Priority | Timeline | Connection string
----+-------------+---------+-----------+-------------+----------+----------+----------+------------------------------------------------------------------------
 1  | enmo_6001 | primary | * running |             | default  | 100      | 1        | host=172.20.10.1 port=6000 user=repmgr dbname=repmgr connect_timeout=2
 2  | enmo_6002 | standby |   running | enmo_6001 | default  | 100      | 1        | host=172.20.10.2 port=6000 user=repmgr dbname=repmgr connect_timeout=2
 3  | enmo_6003 | standby |   running | enmo_6001 | default  | 100      | 1        | host=172.20.10.3 port=6000 user=repmgr dbname=repmgr connect_timeout=2

二、MogDB/openGauss全量build & repmgr clone

这两种方法,MogDB/openGauss的build一般用在主备的数据不一致,且日志追不上的情况,备库从主库重新拉取一份数据目录数据,且在拉取之前会清空数据目录,repmgr一般用在重新搭建主从,或者主备的数据不一致,且日志追不上的情况,或者timeline存在问题的时候。clone要在备机register之前做。

1.MogDB/openGauss

gs\_ctl build -D /gaussdb/data/dn1/ -b full

MogDB/openGauss的全量build是通过全量镜像的方式重新同步主机的数据目录 。

 [omm@node2 ~]$ gs_ctl build -D /gaussdb/data/dn1/ -b full
    [2021-09-30 07:27:48.355][18280][][gs_ctl]: gs_ctl full build ,datadir is /gaussdb/data/dn1
    waiting for server to shut down.... done
    server stopped
    [2021-09-30 07:27:49.375][18280][][gs_ctl]: current workdir is (/home/omm).
    [2021-09-30 07:27:49.375][18280][][gs_ctl]:  fopen build pid file "/gaussdb/data/dn1/gs_build.pid" success
    [2021-09-30 07:27:49.375][18280][][gs_ctl]:  fprintf build pid file "/gaussdb/data/dn1/gs_build.pid" success
    [2021-09-30 07:27:49.376][18280][][gs_ctl]:  fsync build pid file "/gaussdb/data/dn1/gs_build.pid" success
    [2021-09-30 07:27:49.376][18280][][gs_ctl]: set gaussdb state file when full build:db state(BUILDING_STATE), server mode(STANDBY_MODE), build mode(FULL_BUILD).
    [2021-09-30 07:27:49.381][18280][dn_6001_6002][gs_ctl]: connect to server success, build started.
    [2021-09-30 07:27:49.381][18280][dn_6001_6002][gs_ctl]: create build tag file success
    [2021-09-30 07:27:49.806][18280][dn_6001_6002][gs_ctl]: clear old target dir success
    [2021-09-30 07:27:49.806][18280][dn_6001_6002][gs_ctl]: create build tag file again success
    [2021-09-30 07:27:49.806][18280][dn_6001_6002][gs_ctl]: get system identifier success
    [2021-09-30 07:27:49.806][18280][dn_6001_6002][gs_ctl]: receiving and unpacking files...
    [2021-09-30 07:27:49.806][18280][dn_6001_6002][gs_ctl]: create backup label success
    [2021-09-30 07:27:50.634][18280][dn_6001_6002][gs_ctl]: xlog start point: 0/3A000028
    [2021-09-30 07:27:50.634][18280][dn_6001_6002][gs_ctl]: begin build tablespace list
    [2021-09-30 07:27:50.635][18280][dn_6001_6002][gs_ctl]: finish build tablespace list
    [2021-09-30 07:27:50.635][18280][dn_6001_6002][gs_ctl]: begin get xlog by xlogstream
    [2021-09-30 07:27:50.635][18280][dn_6001_6002][gs_ctl]: starting background WAL receiver
    [2021-09-30 07:27:50.635][18280][dn_6001_6002][gs_ctl]: starting walreceiver
    [2021-09-30 07:27:50.635][18280][dn_6001_6002][gs_ctl]: begin receive tar files
    [2021-09-30 07:27:50.636][18280][dn_6001_6002][gs_ctl]: receiving and unpacking files...
    [2021-09-30 07:27:50.656][18280][dn_6001_6002][gs_ctl]:  check identify system success
    [2021-09-30 07:27:50.657][18280][dn_6001_6002][gs_ctl]:  send START_REPLICATION 0/3A000000 success
    [2021-09-30 07:28:01.151][18280][dn_6001_6002][gs_ctl]: finish receive tar files
    [2021-09-30 07:28:01.151][18280][dn_6001_6002][gs_ctl]: xlog end point: 0/3A000170
    [2021-09-30 07:28:01.151][18280][dn_6001_6002][gs_ctl]: fetching MOT checkpoint
    [2021-09-30 07:28:01.152][18280][dn_6001_6002][gs_ctl]: waiting for background process to finish streaming...
    [2021-09-30 07:28:05.805][18280][dn_6001_6002][gs_ctl]: build dummy dw file success
    [2021-09-30 07:28:05.805][18280][dn_6001_6002][gs_ctl]: rename build status file success
    [2021-09-30 07:28:05.805][18280][dn_6001_6002][gs_ctl]: build completed(/gaussdb/data/dn1).
    [2021-09-30 07:28:06.157][18280][dn_6001_6002][gs_ctl]: waiting for server to start...

2.PG repmgr

repmgr -h 172.20.10.7 -p6000 -U repmgr -d repmgr -f

而repmgr默认是通过pg_basebackup的方式,在日志里会打印出来,且查看源码发现还支持barman的方式,openGauss的全量build在源码里暂未找到调用gs_basebackup的相关代码(可能我没找到,欢迎帮我指正交流)

[postgres@enmo-02 ~]$repmgr -h 172.20.10.1 -p6000 -U repmgr -d repmgr -f /home/postgres/repmgr.conf standby clone 
 NOTICE: destination directory "/home/postgres/data" provided
 INFO: connecting to source node
 DETAIL: connection string is: host=172.20.10.1 port=6000 user=repmgr 
 dbname=repmgr
 DETAIL: current installation size is 42 MB
 DEBUG: 1 node records returned by source node
 DEBUG: connecting to: "user=repmgr connect_timeout=2 dbname=repmgr 
 host=172.20.10.1 port=6000 fallback_application_name=repmgr"
 DEBUG: upstream_node_id determined as 11
 NOTICE: checking for available walsenders on the source node (2 
 required)
 NOTICE: checking replication connections can be made to the source 
 server (2 required)
 INFO: checking and correcting permissions on existing directory 
 "/home/postgres/data"
 NOTICE: starting backup (using pg_basebackup)...
 HINT: this may take some time; consider using the -c/--fastcheckpoint option
 INFO: executing:
  /usr/pgsql-11/bin/pg_basebackup -l "repmgr base backup" -D 
 /home/postgres/data -h 172.20.10.7 -p 6000 -U repmgr -X stream 

image.png
image.png

除此之外,发现MogDB/openGauss和repmgr在做全量build或者clone的时候,MogDB/openGauss会把数据目录清空,而repmgr的clone则是覆盖。

MogHA/openGauss:
image.png
image.png
repmgr:
image.png
当然,repmgr加上 -F/–force也不能覆盖一个活跃的目录。
image.png

三.MogDB/openGauss增量build & repmgr node rejoin --force-rewind

MogHA/openGauss:

可以看到,MogHA/openGauss:在通过-b increment做增量build的时候,用到了gs_rewind,与其类似的repmgr也可以通过 repmgr node rejoin --force-rewind,实现类似的功能。

[omm@node2 ~]$ gs_ctl build -D /gaussdb/data/dn1/ -b increment
   [2021-09-30 07:54:12.879][27818][][gs_ctl]: gs_ctl incremental build ,datadir is /gaussdb/data/dn1
   waiting for server to shut down.... done
   server stopped
   [2021-09-30 07:54:13.897][27818][][gs_ctl]:  fopen build pid file "/gaussdb/data/dn1/gs_build.pid" success
   [2021-09-30 07:54:13.897][27818][][gs_ctl]:  fprintf build pid file "/gaussdb/data/dn1/gs_build.pid" success
   [2021-09-30 07:54:13.897][27818][][gs_ctl]:  fsync build pid file "/gaussdb/data/dn1/gs_build.pid" success
   [2021-09-30 07:54:13.902][27818][dn_6001_6002][gs_rewind]: set gaussdb state file when rewind:db state(BUILDING_STATE), server mode(STANDBY_MODE), build mode(INC_BUILD).
   [2021-09-30 07:54:13.965][27818][dn_6001_6002][gs_rewind]: connected to server: host=172.20.10.7 port=26001 dbname=postgres application_name=gs_rewind connect_timeout=5
   [2021-09-30 07:54:13.970][27818][dn_6001_6002][gs_rewind]: connect to primary success
   [2021-09-30 07:54:13.971][27818][dn_6001_6002][gs_rewind]: get pg_control success
   [2021-09-30 07:54:13.972][27818][dn_6001_6002][gs_rewind]: target server was interrupted in mode 2.
   [2021-09-30 07:54:13.972][27818][dn_6001_6002][gs_rewind]: sanityChecks success
   [2021-09-30 07:54:13.972][27818][dn_6001_6002][gs_rewind]: find last checkpoint at 0/3B3CE868 and checkpoint redo at 0/3B3CE7E8 from source control file
   [2021-09-30 07:54:13.972][27818][dn_6001_6002][gs_rewind]: find last checkpoint at 0/3B3CE868 and checkpoint redo at 0/3B3CE7E8 from target control file
   [2021-09-30 07:54:13.974][27818][dn_6001_6002][gs_rewind]: find max lsn success, find max lsn rec (0/3B3CE868) success.

[2021-09-30 07:54:13.979][27818][dn_6001_6002][gs_rewind]: request lsn is 0/3B3CE868 and its crc(source, target):[3849081485, 3849081485]
[2021-09-30 07:54:13.979][27818][dn_6001_6002][gs_rewind]: find common checkpoint 0/3B3CE868
[2021-09-30 07:54:13.979][27818][dn_6001_6002][gs_rewind]: find diverge point success
[2021-09-30 07:54:13.979][27818][dn_6001_6002][gs_rewind]: read checkpoint redo (0/3B3CE7E8) success before rewinding.
[2021-09-30 07:54:13.979][27818][dn_6001_6002][gs_rewind]: rewinding from checkpoint redo point at 0/3B3CE7E8 on timeline 1
[2021-09-30 07:54:13.979][27818][dn_6001_6002][gs_rewind]: diverge xlogfile is 00000001000000000000003B, older ones will not be copied or removed.
[2021-09-30 07:54:13.980][27818][dn_6001_6002][gs_rewind]: targetFileStatThread success pid 139740617094912.
[2021-09-30 07:54:13.980][27818][dn_6001_6002][gs_rewind]: reading source file list
[2021-09-30 07:54:13.980][27818][dn_6001_6002][gs_rewind]: traverse_datadir start.
[2021-09-30 07:54:13.983][27818][dn_6001_6002][gs_rewind]: filemap_list_to_array start.
[2021-09-30 07:54:13.983][27818][dn_6001_6002][gs_rewind]: filemap_list_to_array end sort start. length is 2704
[2021-09-30 07:54:13.983][27818][dn_6001_6002][gs_rewind]: sort end.
[2021-09-30 07:54:13.990][27818][dn_6001_6002][gs_rewind]: targetFileStatThread return success.
[2021-09-30 07:54:14.001][27818][dn_6001_6002][gs_rewind]: reading target file list
[2021-09-30 07:54:14.005][27818][dn_6001_6002][gs_rewind]: traverse target datadir success
[2021-09-30 07:54:14.005][27818][dn_6001_6002][gs_rewind]: reading WAL in target
[2021-09-30 07:54:14.005][27818][dn_6001_6002][gs_rewind]: could not read WAL record at 0/3B3CE900: invalid record length at 0/3B3CE900: wanted 32, got 0
[2021-09-30 07:54:14.006][27818][dn_6001_6002][gs_rewind]: calculate totals rewind success
[2021-09-30 07:54:14.006][27818][dn_6001_6002][gs_rewind]: need to copy 17MB (total source directory size is 540MB)
[2021-09-30 07:54:14.006][27818][dn_6001_6002][gs_rewind]: starting background WAL receiver
[2021-09-30 07:54:14.006][27818][dn_6001_6002][gs_rewind]: Starting copy xlog, start point: 0/3B3CE7E8
[2021-09-30 07:54:14.006][27818][dn_6001_6002][gs_rewind]: in gs_rewind proecess,so no need remove.
[2021-09-30 07:54:14.012][27818][dn_6001_6002][gs_rewind]: check identify system success
[2021-09-30 07:54:14.012][27818][dn_6001_6002][gs_rewind]: send START_REPLICATION 0/3B000000 success
[2021-09-30 07:54:14.047][27818][dn_6001_6002][gs_rewind]: receiving and unpacking files…
[2021-09-30 07:54:14.173][27818][dn_6001_6002][gs_rewind]: execute file map success
[2021-09-30 07:54:14.174][27818][dn_6001_6002][gs_rewind]: find minRecoveryPoint success from xlog insert location 0/3B3D2D80
[2021-09-30 07:54:14.174][27818][dn_6001_6002][gs_rewind]: update pg_control file success, minRecoveryPoint: 0/3B3D2D80, ckpLoc:0/3B3CE868, ckpRedo:0/3B3CE7E8, preCkp:0/3B3CE750
[2021-09-30 07:54:14.176][27818][dn_6001_6002][gs_rewind]: update pg_dw file success
[2021-09-30 07:54:14.177][27818][dn_6001_6002][gs_rewind]: xlog end point: 0/3B3D2D80
[2021-09-30 07:54:14.177][27818][dn_6001_6002][gs_rewind]: waiting for background process to finish streaming…
[2021-09-30 07:54:19.086][27818][dn_6001_6002][gs_rewind]: creating backup label and updating control file
[2021-09-30 07:54:19.086][27818][dn_6001_6002][gs_rewind]: create backup label success
[2021-09-30 07:54:19.086][27818][dn_6001_6002][gs_rewind]: read checkpoint redo (0/3B3CE7E8) success.
[2021-09-30 07:54:19.086][27818][dn_6001_6002][gs_rewind]: read checkpoint rec (0/3B3CE868) success.
[2021-09-30 07:54:19.086][27818][dn_6001_6002][gs_rewind]: dn incremental build completed.
[2021-09-30 07:54:19.090][27818][dn_6001_6002][gs_rewind]: fetching MOT checkpoint
[2021-09-30 07:54:19.201][27818][dn_6001_6002][gs_ctl]: waiting for server to start…

repmgr:

命令为:

repmgr node rejoin -d ‘host=172.20.10.1 user=repmgr dbname=repmgr connect\_timeout=2’ --force-rewind --verbose

四.switchover

都是在备机执行,将本节点提升为主库,同时主节点降级为该新主的备机。

MogHA/openGauss:

gs_ctl switchover -D /gaussdb/data/dn1

    [omm@node2 ~]$ gs_ctl switchover -D /gaussdb/data/dn1
    [2021-09-30 08:02:09.192][30742][][gs_ctl]: gs_ctl switchover ,datadir is /gaussdb/data/dn1
    [2021-09-30 08:02:09.192][30742][][gs_ctl]: switchover term (1)
    [2021-09-30 08:02:09.196][30742][][gs_ctl]: waiting for server to switchover..........
    [2021-09-30 08:02:16.327][30742][][gs_ctl]: done
    [2021-09-30 08:02:16.327][30742][][gs_ctl]: switchover completed (/gaussdb/data/dn1)

repmgr:

repmgr -f /home/postgres/repmgr.conf standby switchover -U repmgr --verbose

[postgres@enmo-02 ~]$ repmgr -f /home/postgres/repmgr.conf standby switchover -U repmgr  --verbose
NOTICE: using provided configuration file "/home/postgres/repmgr.conf"

WARNING: following problems with command line parameters detected:

  database connection parameters not required when executing STANDBY SWITCHOVER

DEBUG: connecting to: "user=repmgr connect_timeout=2 dbname=repmgr host=10.28.3.134 port=6000 fallback_application_name=repmgr"

DEBUG: set_config():

  SET synchronous_commit TO 'local'

DEBUG: get_node_record():

  SELECT n.node_id, n.type, n.upstream_node_id, n.node_name,  n.conninfo, n.repluser, n.slot_name, n.location, n.priority, n.active, n.config_file, '' AS upstream_node_name, NULL AS attached   FROM repmgr.nodes n  WHERE n.node_id = 2

NOTICE: executing switchover on node "falcon_6002" (ID: 2)

DEBUG: get_recovery_type(): SELECT pg_catalog.pg_is_in_recovery()

INFO: searching for primary node

DEBUG: get_primary_connection():

五.MogDB/openGauss高可用工具MogHA & repmgr 切换

在这一方面MogHA/openGauss的集群管理工具是gs_om,通过gs_om -t status --detail或者gs_om -t query 查看集群的相关状态,但是OM工具本身是不支持高可用的自动切换的,因此,针对这个问题,云和恩墨自主研发了MogHA高可用工具,它可以通过网络,主备角色状态,孤单检查,心跳检查等多个维度对数据库和主备节点进行检查,确保MogHA/openGauss数据库集群能提供长稳运行,且最大程度降低故障切换对业务的影响。支持脑裂检查以及假主处理,vip自动漂移到新主节点的功能,是一款比较方便且可信的高可用工具。

而repmgr在这边可以通过编写repmgr_promote.sh和repmgr_follow.shd脚本的方式,实现数据库的高可用自动切换。和MogDB/openGauss+MogHA+OM的一套体系相比,缺少了MogHA在switchover之后对数据库节点角色检查并vip飘移到新主的功能,可能是美中不足。

  大数据 最新文章
实现Kafka至少消费一次
亚马逊云科技:还在苦于ETL?Zero ETL的时代
初探MapReduce
【SpringBoot框架篇】32.基于注解+redis实现
Elasticsearch:如何减少 Elasticsearch 集
Go redis操作
Redis面试题
专题五 Redis高并发场景
基于GBase8s和Calcite的多数据源查询
Redis——底层数据结构原理
上一篇文章      下一篇文章      查看所有文章
加:2021-12-19 18:25:59  更:2021-12-19 18:26:14 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/17 7:54:23-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码