【Postgresql】postgresql9.3.9版本基于流复制方式双机热备方案
admin
2023-05-21 08:22:40
0

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

  1. 安装pgsql数据库
    安装过程可参考我上一篇博客:https://blog.51cto.com/13632960/2117902
    两台机器都需要安装完成,我在做热备的时候,Master数据库开启,Slave关闭。
  2. 创建流复制用户
    Master端进入数据库并执行:
    CREATE USER repuser replication PASSWORD 'repuser'; 
  3. 配置Master端的访问文件pg_hba.conf 
    vim /usr/local/pgsql/data/pg_hba.conf
     在最后添加:host replication repuser 10.0.2.69/16 md5
     #md5为连接方式 你们也可以选择其他的
  4. 配置Master端配置文件 postgresql.conf
    在修改之前先创建一个文件夹用于归档文件存放:mkdir /usr/local/pgsql/data/archive
    vim /usr/local/pgsql/data/postgresql.conf
    修改下列项:
    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也可以选择关闭,归档是定时恢复用的,流复制不是必须的
  5. 主库备份——Master端
    开启文件备份:
    /usr/local/pgsql/bin/psql 
    psql (9.3.9)
    Type "help" for help.
    postgres=# select pg_start_backup('backup_1');
  6. 打包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;
  7. Slave端解压并修改相关配置文件
    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
  8. 备机需要配置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'
  9. 启动Slave库
    正常启动备库,有异常可以看log
    /usr/local/pgsql/bin/pg_ctl start -D /usr/local/pgsql/data >>logfile 2>&1
  10. 查看主库及从库启动状态
    Master:
    【Postgresql】postgresql9.3.9版本基于流复制方式双机热备方案
    Slave:
    【Postgresql】postgresql9.3.9版本基于流复制方式双机热备方案
  11. 至此postgresql流复制热备方案部署完成,可以通过navicat或者命令行进行数据插入或者建表测试功能可用性。

相关内容

热门资讯

出走10年的妻子“回心转意”?... 近日,张家川县公安局恭门派出所辖区居民丁某前往派出所报案,称可能遭遇电信诈骗。经民警初步了解得知,受...
江苏税务局再回应偷拍女生裙底男... 大皖新闻讯 “研究生校内偷拍女生裙底”事件仍在发酵中。5月18日,国家税务总局江苏省税务局负责招录工...
不妨多给大学开放一些适应时间 澎湃特约评论员 胡栖安5月16日,武汉大学校园开放后的首个周末,不少游客前来参观。视觉中国 图刚刚过...
“娜塔莎”娃娃爆火 被批暴力擦... “娜塔莎”娃娃爆火 被批暴力擦边  【“娜塔莎”娃娃爆火 被批暴力擦边】一款名叫“娜塔莎”的解压玩具...
黄三、李四是谁?多部门回应拆迁... 澎湃新闻记者 陈绪厚拆迁公告中产权人的姓名为“黄三”、“李四”,广州市荔湾区政府国有土地上房屋征收办...
专注大模型的定制软件开发公司解... 专注大模型,定制开发如何避坑?这家公司提供了不一样的思路 当AI的浪潮席卷而来,几乎每一家企业都在思...
外交部回应特朗普涉台表态 新华社北京5月18日电(记者冯歆然、董雪)就美国总统特朗普涉台表态,外交部发言人郭嘉昆18日在例行记...
特朗普访华后高市早苗与其通话,... 澎湃新闻记者 杨文钦 朱郑勇5月18日,外交部发言人郭嘉昆主持例行记者会。迪拜中阿卫视记者提问,在特...
谷歌前CEO毕业典礼谈AI惹争... 来源:环球网 【环球网科技综合报道】5月18日消息,据据 NBC News 报道,前谷歌CEO埃里...
【图片故事】从“打工妹”到隐形... 来源:滚动播报 (来源:工人日报) 近日,在广东鼎泰高科技术股份有限公司总部实验室,王馨(右二)与研...