标签:postgresql 双机热备 流复制 9.3.9
系统环境:centos6.5
数据库版本: postgres9.3.9
虚拟机2台:
Master:10.0.2.160
Slave:10.0.2.69
数据存储位置:/usr/local/pgsql/data/
安装过程可参考我上一篇博客:http://blog.51cto.com/13632960/2117902
两台机器都需要安装完成,我在做热备的时候,Master数据库开启,Slave关闭。
Master端进入数据库并执行:
CREATE USER repuser?replication PASSWORD ‘repuser‘;?
vim /usr/local/pgsql/data/pg_hba.conf
在最后添加:host replication repuser?10.0.2.69/16 md5
#md5为连接方式 你们也可以选择其他的
max_wal_senders = 1?
wal_level = hot_standby
archive_mode = on?
archive_command = ‘cp %p /usr/local/pgsql/data/archive/%f‘‘
hot_standby = on
wal_keep_segments = 64
注释: max_wal_senders是Slave库的节点数,有多少个slave库就设多少,
? ? ? wal_level是write ahead log参数值,设置流复制务必将此值更新成hot_standby
? ? ?wal_keep_segments默认值是16,是PG_XLOG下的日志文件数相关参数
?? ? archive也可以选择关闭,归档是定时恢复用的,流复制不是必须的
/usr/local/pgsql/bin/psql
psql (9.3.9)
Type "help" for help.
postgres=# select pg_start_backup(‘backup_1‘);
cd /usr/local/pgsql/
tar -czvf? data.tar.gz data--exclude=data/pg_xlog?
Slave端如果已经安装了postgres数据库,数据目录名称一样的话,可以先停掉备机数据库,更改数据目录名称
mv data data.old
远程拷贝至slave端并在备机端解压
scp data.tar.gz postgres@10.0.2.69:/usr/local/pgsql/
拷贝完成后,进入数据库关闭备份:select pg_stop_backup(),current_timestamp;
cd /usr/local/pgsql
tar -zxvf data.tar.gz
cd /usr/local/pgsql/data
mkdir pg_xlog
vim /usr/local/pgsql/data/postgresql.conf
修改:hot_standby = on
cp /usr/local/pgsql/share/recovery.conf.sample /usr/local/pgsql/data/recovery.conf
复制完成后修改如下内容:
?standby_mode = ‘on‘
primary_conninfo =‘host=10.0.2.69??port=5432 user=repuser password=repuser keepalives_idle=60‘
正常启动备库,有异常可以看log
/usr/local/pgsql/bin/pg_ctl start -D /usr/local/pgsql/data >>logfile 2>&1
【Postgresql】postgresql9.3.9版本基于流复制方式双机热备方案
标签:postgresql 双机热备 流复制 9.3.9
原文地址:http://blog.51cto.com/13632960/2117928