• 欢迎访问蜷缩的蜗牛博客 蜷缩的蜗牛
  • 微信搜索: 蜷缩的蜗牛 | 联系站长 kbsonlong@qq.com
  • 如果您觉得本站非常有看点,那么赶紧使用Ctrl+D 收藏吧

【转载】postgres主从流复制

Linux 蜷缩的蜗牛 1年前 (2017-07-27) 7次浏览 已收录 0个评论

postgres 主从流复制

postgres 在 9.0 之后引入了主从的流复制机制,所谓流复制,就是从库通过 tcp 流从主库中同步相应的数据。postgres 的主从看过一个视频,大概效率为 3w 多事务 qps。

postgres 的主从主称之为 primary,从称为 stand_by。主从配置需要注意的一个是主从的 postgres 的版本,环境,等最好都需要一致,否则可能产生奇奇怪怪的问题。

postgres 的主配置

主是 10.12.12.10 这台机器

首先需要配置一个账号进行主从同步。

修改 pg_hba.conf,增加 replica 用户,进行同步。

host    replication     replica     10.12.12.12/32                 md5

这样,就设置了 replica 这个用户可以从 10.12.12.12 对应的网段进行流复制请求。

给 postgres 设置密码,登录和备份权限。

postgres# CREATE ROLE replica login replication encrypted password 'replica'

修改 postgresql.conf,注意设置下下面几个地方:

wal_level = hot_standby  # 这个是设置主为 wal 的主机

max_wal_senders = 32 # 这个设置了可以最多有几个流复制连接,差不多有几个从,就设置几个
wal_keep_segments = 256 # 设置流复制保留的最多的 xlog 数目
wal_sender_timeout = 60s # 设置流复制主机发送数据的超时时间

max_connections = 100 # 这个设置要注意下,从库的 max_connections 必须要大于主库的

重启主

pg_ctl restart

postgres 的从配置

从是 10.12.12.12 这台机器

创建的目录为 /data/pgsql/data2

pg_basebackup -F p --progress -D /data/pgsql/data2 -h 10.12.12.10 -p 5432 -U replica --password

这里使用了 pg_basebackup 这个命令,/data/pgsql/data2 这个目录是空的

成功之后,就可以看到这个目录中现有的文件都是一样的了。

进入到/data/pgsql/data2 目录,复制 recovery.conf,这个文件可以从 pg 的安装目录的 share 文件夹中获取,比如

cp /usr/local/postgres94/share/recovery.conf.sample /data/pgsql/data2/recovery.conf

修改 recovery.conf,只要修改几个地方就行了

standby_mode = on  # 这个说明这台机器为从库
primary_conninfo = 'host=10.12.12.10 port=5432 user=replica password=replica'  # 这个说明这台机器对应主库的信息

recovery_target_timeline = 'latest' # 这个说明这个流复制同步到最新的数据

postgresql.conf 中也有几个地方要进行修改

max_connections = 1000 # 一般查多于写的应用从库的最大连接数要比较大

hot_standby = on  # 说明这台机器不仅仅是用于数据归档,也用于数据查询
max_standby_streaming_delay = 30s # 数据流备份的最大延迟时间
wal_receiver_status_interval = 1s  # 多久向主报告一次从的状态,当然从每次数据复制都会向主报告状态,这里只是设置最长的间隔时间
hot_standby_feedback = on # 如果有错误的数据复制,是否向主进行反馈

好了,现在启动从库

确认主库和从库都配置好了

查看进程,主库所在的机器中会看到 sender 进程

8467 postgres  20   0  255m 2396 1492 S  0.0  0.1   0:00.66 postgres: wal sender process replica 

从库所在的机器中会看到 receiver 进程

8466 postgres  20   0  298m 1968 1096 S  0.0  0.1   0:06.88 postgres: wal receiver process   streaming 3/CF118C18

查看复制状态

主库中执行:

 postgres=# select * from pg_stat_replication;
-[ RECORD 1 ]----+------------------------------
pid              | 8467       # sender 的进程
usesysid         | 44673      # 复制的用户 id
usename          | replica    # 复制的用户用户名
application_name | walreceiver  
client_addr      | 10.12.12.12 # 复制的客户端地址
client_hostname  |
client_port      | 55804  # 复制的客户端端口
backend_start    | 2015-05-12 07:31:16.972157+08  # 这个主从搭建的时间
backend_xmin     |
state            | streaming  # 同步状态 startup: 连接中、catchup: 同步中、streaming: 同步
sent_location    | 3/CF123560 # Master 传送 WAL 的位置
write_location   | 3/CF123560 # Slave 接收 WAL 的位置
flush_location   | 3/CF123560 # Slave 同步到磁盘的 WAL 位置
replay_location  | 3/CF123560 # Slave 同步到数据库的 WAL 位置
sync_priority    | 0  #同步 Replication 的优先度
                      0: 异步、1~?: 同步(数字越小优先度越高)
sync_state       | async  # 有三个值,async: 异步、sync: 同步、potential: 虽然现在是异步模式,但是有可能升级到同步模式

同步复制

看到上面的 sync_state 的状态有同步和异步的区别。

我们之前的概念都是异步备份,就是一个事务完成了之后,直接返回程序,然后纪录日志,由复制进程重放日志进行数据复制。同步备份的概念,就是一个事务只有当完成了数据复制之后,才返回到程序中。当然同步的性能一定会比异步的性能差一个量级。


蜷缩的蜗牛 , 版权所有丨如未注明 , 均为原创丨 转载请注明【转载】postgres 主从流复制
喜欢 (0)
[]
分享 (0)

您必须 登录 才能发表评论!