流复制备库停机维护前检查步骤

文章目录

环境

系统平台:银河麒麟 (鲲鹏)

版本:4.5.10

文档用途

未安装HAC集群软件,仅配置流复制主备架构。确保在停备库进行硬件更换或系统维护前,所有必要的检查项都已执行,避免因遗漏检查导致主库WAL日志被清理、复制中断无法恢复等问题

详细信息

一、检查授权是否到期(授权到期,会无法启动数据库)

复制代码
4.5.7及之前版本:check_lic
4.5.8及新版本:hg_lic

二、检查流复制状态

在主库执行查询:

复制代码
SELECT 
    application_name,      -- 备库名称
    state,                 -- streaming(正常)
    sync_state,            -- sync(同步)| async(异步)
    sync_priority,         -- 同步优先级
    pg_size_pretty(pg_wal_lsn_diff(pg_current_wal_lsn(), replay_lsn)) AS replay_lag_size  -- 延迟字节数
FROM pg_stat_replication;

正常状态判断:
state = streaming:流复制正常
replay_lag_size 为 0 或较小值:延迟可接受
replay_lag_size 持续增长:备库追不上主库,需排查

三、检查是否使用复制槽

(作用:有复制槽时,主库会保留备库需要的所有WAL文件。但需注意,若备库长期未重连或复制槽处于非活跃(active = f)状态,WAL文件将无限堆积,可能撑爆主库数据目录磁盘。建议在停机前评估主库WAL生成速率及可用磁盘空间,确保预留空间充足)

在主库执行查询:

复制代码
SELECT slot_name, slot_type, active FROM pg_replication_slots;
如果输出无记录,未使用复制槽

四、如果没有使用复制槽

复制代码
主库执行手动创建复制槽:
select * from pg_create_physical_replication_slot('node_b_slot');
查看已创建的复制槽:
SELECT slot_name, slot_type, active FROM pg_replication_slots;

注意:创建复制槽后,如果备库长期未重连,WAL会无限堆积,需监控磁盘空间

五、检查同步提交模式

在主库执行查询:

复制代码
SELECT 
    application_name,      -- 备库名称
    sync_state,            -- sync(同步)| async(异步)
    sync_priority         -- 同步优先级
FROM pg_stat_replication;

如果 sync_state = sync:该备库为同步备库,备库停机会阻塞主库写操作
如果 sync_state = async:该备库为异步备库,停机不影响主库
如果为同步备库,停机前需临时修改为异步

查看synchronous_standby_names配置参数并记录:
show synchronous_standby_names;
清空同步备库列表(转为异步模式):
ALTER SYSTEM SET synchronous_standby_names = '';
重载配置:
select pg_reload_conf();
查看当前同步状态,sync_state 应变为 async:
SELECT application_name, sync_state FROM pg_stat_replication;

备库恢复后恢复同步模式

复制代码
恢复原来的 synchronous_standby_names 配置:
ALTER SYSTEM SET synchronous_standby_names = '原来的配置值';
重载配置:
SELECT pg_reload_conf();
相关推荐
持敬chijing1 小时前
Web渗透之SQL注入-SQLMAP使用笔记
数据库·sql·安全·web安全·网络安全·网络攻击模型
BomanGe21 小时前
NSK直线导轨LH55EL与NH55EM替代指南
前端·javascript·数据库·经验分享·规格说明书
JAVA面经实录9171 小时前
MongoDB(文档型 NoSQL)
java·数据库·mongodb·nosql
睡不醒男孩0308231 小时前
第十篇:PostgreSQL 生产环境高可用选型:CLUP 与 Patroni 深度架构对比与踩坑实录
数据库·postgresql·架构
JAVA面经实录9171 小时前
HBase 知识点梳理(文档型 NoSQL)
大数据·数据库·nosql数据库·hbase
小二·1 小时前
PostgreSQL 高级特性与性能调优
数据库·postgresql
风味蘑菇干2 小时前
JDBC(数据库连接池&DBUtils)
java·数据库
标书畅畅行2 小时前
深度解析钛投标AI标书工具:全流程企业级AI投标解决方案,重构投标数字化生产力
大数据·数据库·人工智能
Wait....2 小时前
MySQL底层知识总结
数据库·mysql