系统环境:centos6.5
数据库版本: postgres9.3.9
虚拟机2台:
Master:10.0.2.160
Slave:10.0.2.69
数据存储位置:/usr/local/pgsql/data/

安装pgsql数据库

安装过程可参考我上一篇博客:https://blog.51cto.com/13632960/2117902两台机器都需要安装完成,我在做热备的时候,Master数据库开启,Slave关闭。创建流复制用户

Master端进入数据库并执行:CREATE USER repuser replication PASSWORD 'repuser'; 配置Master端的访问文件pg_hba.conf 

vim /usr/local/pgsql/data/pg_hba.conf 在最后添加:host replication repuser 10.0.2.69/16 md5 #md5为连接方式 你们也可以选择其他的配置Master端配置文件 postgresql.conf
在修改之前先创建一个文件夹用于归档文件存放:mkdir /usr/local/pgsql/data/archive
vim /usr/local/pgsql/data/postgresql.conf
修改下列项:

max_wal_senders = 1 wal_level = hot_standbyarchive_mode = on archive_command = 'cp %p /usr/local/pgsql/data/archive/%f''hot_standby = onwal_keep_segments = 64

注释: max_wal_senders是Slave库的节点数,有多少个slave库就设多少,      wal_level是write ahead log参数值,设置流复制务必将此值更新成hot_standby     wal_keep_segments默认值是16,是PG_XLOG下的日志文件数相关参数     archive也可以选择关闭,归档是定时恢复用的,流复制不是必须的主库备份——Master端
开启文件备份:

/usr/local/pgsql/bin/psql psql (9.3.9)Type "help" for help.postgres=# select pg_start_backup('backup_1');打包Master端/usr/local/pgsql/data/目录,并发送到Slave服务器上,排除pg_xlog目录内容!!!!!

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;Slave端解压并修改相关配置文件

cd /usr/local/pgsqltar -zxvf data.tar.gzcd /usr/local/pgsql/datamkdir pg_xlog vim /usr/local/pgsql/data/postgresql.conf修改:hot_standby = on备机需要配置recovery.conf文件,将share目录中的recovery.conf.sample拷贝并改名。

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'启动Slave库

正常启动备库,有异常可以看log/usr/local/pgsql/bin/pg_ctl start -D /usr/local/pgsql/data >>logfile 2>&1查看主库及从库启动状态
Master:

Slave:
至此postgresql流复制热备方案部署完成,可以通过navicat或者命令行进行数据插入或者建表测试功能可用性。