前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >谁说postgresql 没有靠谱的高可用(6)

谁说postgresql 没有靠谱的高可用(6)

作者头像
AustinDatabases
发布2020-02-13 17:55:05
2.3K0
发布2020-02-13 17:55:05
举报
文章被收录于专栏:AustinDatabases

接上期,(如果看不懂的,请从第一期看,否则可能和看天书没两样),最近在梳理一些问题的时候,发现一个现象,大部分出现问题后,解决就完了,网上很多文字,大多都是这样,先提出一个问题,然后就给出答案,然后就么有然后后了。而这样的结果一般是好不了的,这和狗熊掰棒子没啥区别。所以才有了这期,这期是要说说repmgr 的一些系统表,一些常见的被问及的问题,(一些深层的问题,还得继续研究)

截止到目前本文的时间点,repmgr 已经支持了postgresql 12, repmgr 的系统表我们看看有什么,如果你说我看不到,或者里面啥都没有,你一定是没有通过 repmgr 这个账号登录repmgr库

events表中包含了相关的在这个节点,所有关于repmgr 相关的事件的记录,这个表并不会自动清理,需要自己进行清理,或自己写脚本处理。下方的 nodes 表则记录了数据库集群中的已经注册的节点

另外还有一些常见的命令

repmgr -f /etc/repmgr.conf node status

具体的常见的命令可以去官网去看比我介绍的要好的多。

常见的疑问

1 repmgr 需要初始化数据或者有metadata 吗

为了有效地管理复制集群,repmgr需要将集群中服务器的信息存储在专用的数据库模式中。该模式由repmgr扩展自动创建,该扩展在初始化repmgr管理的集群

其中这些元数据包含

  • repmgr.events
  • repmgr.nodes
  • repmgr.monitoring_history

以及两个 VIEW

2 repmgr 的版本和POSTGRESQL 的版本对应,有严格的区分吗?

目前repmgr 最高的版本已经不是 4.4 ,而是 5.0 ,5.0 的版本兼容所有目前正式版的postgresql ,同时一个集群中的各个节点的repmgr 的版本应该是一致的,不能存在不同版本的混用的做法。

部分版本支持的postgresql 列表

3 repmgr 包可以不用二进制方式安装吗

可以,可以下载2象限的yum 源,可以直接 rpm 包安装,如果在yum 安装时出现问题,请检查下面的依赖包装没有装

  • flex
  • libselinux-devel
  • libxml2-devel
  • libxslt-devel
  • openssl-devel
  • pam-devel
  • readline-devel

4 在一台服务器上安装多个 postgresql cluster 是否也可以使用 repmgr

是的可以这样使用,但不建议

5 repmgr 的使用中是否对 postgresql,conf 的设置有一些要求

本身没有,但针对于复制来说,还是需要在重复一下

1 是否有足够的 replication_slots

2 wal_level 设置的是否对

3 host_standby 是否设置了

4 archive 是否开了

代码语言:javascript
复制
max_replication_slots = 10
代码语言:javascript
复制
wal_level = 'hot_standby'
代码语言:javascript
复制
hot_standby = on
代码语言:javascript
复制
archive_mode = on

archive_command =

6 对于pg_hba.conf 文件有什么要求

需要对于repmgr 有相关正确的权限,否则会对切换和数据的操作都有操作的隔阂,或失败

7 repmgr.conf 我放到postgresql 的配置文件路径下合适吗

不合适,repmgr 应该独立防止在非postgresql 配置路径下,防止误操作后的数据丢失和数据恢复后的配置文件丢失或覆盖

8 wal_log_hints 是否需要打开

这要视是否需要打开pg_rewind 如果需要则需要打开,默认建议打开

9 需要主库和备库的使用表空间但在不同的物理位置的映射表是否可以做?

可以,repmgr提供了一个tablespace_mapping配置文件选项,可以将源节点上的表空间映射到本地节点上的不同位置。

其实postgresql 的高可用方法有很多,这六期仅仅是说了其中一种,高可用可以有很多的变化,即使是repmgr 也可以搭配其他的多种中间件来进行高可用的使用。

学无止境,适合就好。

本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2020-01-13,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 AustinDatabases 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
相关产品与服务
数据库
云数据库为企业提供了完善的关系型数据库、非关系型数据库、分析型数据库和数据库生态工具。您可以通过产品选择和组合搭建,轻松实现高可靠、高可用性、高性能等数据库需求。云数据库服务也可大幅减少您的运维工作量,更专注于业务发展,让企业一站式享受数据上云及分布式架构的技术红利!
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档