centos7.9部署postgresql13.8主从流复制
在CentOS 7.9上部署PostgreSQL 13.8主从流复制的步骤如下:
- 安装PostgreSQL 13.8:
sudo yum install -y https://download.postgresql.org/pub/repos/yum/reporpms/EL-7-x86_64/pgdg-redhat-repo-latest.noarch.rpm
sudo yum install -y postgresql13-server
sudo /usr/pgsql-13/bin/postgresql-13-setup initdb
sudo systemctl enable postgresql-13
sudo systemctl start postgresql-13
- 配置主数据库(Master):
编辑PostgreSQL配置文件postgresql.conf
,通常位于/var/lib/pgsql/13/data/
目录下,设置监听地址,启用日志记录,指定流复制模式:
listen_addresses = '*'
wal_level = replica
max_wal_senders = 3
max_replication_slots = 3
创建用于复制的用户并授权:
CREATE ROLE replica LOGIN PASSWORD 'replica_password';
GRANT REPLICATION SLAVE ON DATABASE postgres TO replica;
- 配置从数据库(Slave):
编辑PostgreSQL配置文件recovery.conf
,通常位于/var/lib/pgsql/13/data/
目录下,指定主数据库信息和恢复选项:
primary_conninfo = 'host=master_ip port=5432 user=replica password=replica_password sslmode=prefer sslcompression=1'
primary_slot_name = 'replica_slot'
recovery_target_timeline = 'latest'
- 启动从数据库并启动复制:
在从数据库上,重新启动PostgreSQL服务以加载恢复配置:
sudo systemctl restart postgresql-13
然后在从数据库执行以下SQL命令来启动流复制:
START_REPLICATION SLOT 'replica_slot' PASSWORD 'replica_password' FROM 'start_location';
其中start_location
是主数据库上的起始日志位置,可以通过以下命令获取:
SELECT * FROM pg_create_physical_replication_slot('replica_slot');
以上步骤可能需要根据实际环境进行调整,包括防火墙设置、权限管理等。确保主从数据库的网络互通,并根据实际情况调整配置文件中的参数。
评论已关闭