码迷,mamicode.com
首页 > 数据库 > 详细

pgsql的同步须知

时间:2015-02-25 12:59:49      阅读:151      评论:0      收藏:0      [点我收藏+]

标签:

pgsql的同步模式是根据master上的日志来做的同步,有两种同步方式,参考
http://www.chinaxing.org/articles/Postgres/2012/12/14/2012-12-14-hight-availability-in-postgresql.html

pgsql的日志有一个自动回收的特性,如果某些日志发现不需要了,pgsql会重命名他们,并且用新日志覆盖;这带来一个问题,如果传送给备机的日志还没有全部传好,但是master上已经没有了,就会导致问题,所以,pgsql提供了一个接口,在postgresql.conf里面配置archive_command,这个用于在流复制的时候,pgsql会调用这里配置的命令,官方wiki的例子是cp到自定义的日志目录(你可以自己rsync到备机,如果用rsync,master上的wal_keep_segments也要设大一些,防止在rsync完成之前日志就没了),在备机上修改recovery.conf,里面配置restore_command,这个命令也会被调用

 

关于9.1新增的pg_basebackup命令,德哥建议用rsync,看http://blog.163.com/digoal@126/blog/static/16387704020133277305874

 

archive模式的例子,亲测通过
master的postgresql.conf

wal_level = hot_standby
wal_keep_segments = 32
max_wal_senders = 3

archive_mode = on
#这里之所以mkdir,是自己在配置的时候死活提示没有权限,发现路径不过,自己mkdir以后,就很清楚的知道在哪里了
archive_command = mkdir -p p_archive;cp -i %p pg_archive/%f

 


slave的recovery.conf,暂时随便找个地方放好了

standby_mode = on
primary_conninfo = host=192.168.1.111 user=repuser password=123456
restore_command = cp pg_archive/%f %p
#某个时候会自动调用cleanup清理,默认pg_archivecleanup没有安装,需要apt-get install postgresql-contrib
archive_cleanup_command = pg_archivecleanup pg_archive %r

 

slave上使用pg_basebackup来同步的测试

sudo service postgresql stop;sudo rm -rf /var/lib/postgresql/9.4/main;sudo -u postgres pg_basebackup -h 192.168.1.111 -D /var/lib/postgresql/9.4/main -U repuser -v -P;sudo cp /home/mmc/Desktop/recovery.conf /var/lib/postgresql/9.4/main/;sudo service postgresql start;

 

pgsql的同步须知

标签:

原文地址:http://www.cnblogs.com/ziyouchutuwenwu/p/4299397.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!