Postgresq9.6主从部署

Postgresq9.6主从部署

实验环境


名称


IP


系统


Master


172.17.10.190


Centos 6.5


Slave


172.17.10.189


Centos 6.5

1.yun安装

rpm -ivh https://download.postgresql.org/pub/repos/yum/9.6/redhat/rhel-6-x86_64/pgdg-centos96-9.6-3.noarch.rpm
yum install postgresql96.x86_64 postgresql96-server.x86_64 -y

2.主从配置

2.1 主数据库配置

启动master

/etc/init.d/postgresql-9.6 initdb
/etc/init.d/postgresql-9.6 start
su - postgres
psql

授权

create role repl login replication encrypted password ‘51idc.com‘;

编辑hba文件

/var/lib/pgsql/9.6/data/pg_hba.conf

新增

host    replication     repl            172.17.10.0/24         md5
host    all            repl            172.17.10.0/24         trust

编辑配置文件

/var/lib/pgsql/9.6/data/postgresql.conf

listen_addresses = 172.17.10.190
wal_level = hot_standby  #热备模式
max_wal_senders= 6 #可以设置最多几个流复制链接,差不多有几个从,就设置多少
wal_keep_segments = 10240  #重要配置 
wal_send_timeout = 60s 
max_connections = 512 #从库的 max_connections要大于主库
archive_mode = on #允许归档 
archive_command = ‘cp %p /url/path%f‘   #根据实际情况设置

2.2 从数据库配置

su - postgres

如果开始为启动数据库可忽略下一步

rm -rf /var/lib/pgsql/9.6/data/*  #开始没有启动从数据库,这一步可以省略 
pg_basebackup -h 172.17.10.190 -U repl -D /var/lib/pgsql/9.6/data -X stream -P
cp /usr/pgsql-9.6/share/recovery.conf.sample /var/lib/pgsql/9.6/data/recovery.conf

修改配置文件recovery.conf

standby_mode = on
primary_conninfo = ‘host=172.17.10.190 port=5432 user=repl password=51idc.com‘
trigger_file = ‘/var/lib/pgsql/9.6/data/trigger.kenyon‘    #主从切换时后的触发文件
recovery_target_timeline = ‘latest‘

配置postgresql.conf文件

listen_addresses = 172.17.10.189
wal_level = hot_standby 
max_connections = 1000 #一般从的最大链接要大于主的。 
hot_standby = on #说明这台机器不仅仅用于数据归档,也用于查询 
max_standby_streaming_delay = 30s 
wal_receiver_status_interval = 10s #多久向主报告一次从的状态。 
hot_standby_feedback = on #如果有错误的数据复制,是否向主进行范例

检测

select client_addr,sync_state from pg_stat_replication;

查看主从状态

select * from pg_stat_replication;

脚本监控主从

#!/bin/bash
# mail  [email protected]
data=`date +%Y-%M-%d" "%H:%m`
netstat -lntup|grep 5432 && ps -ef|grep postmaster
if [ $? -eq 0 ];then
for IP in 172.17.10.188 172.17.10.189
do
/usr/bin/psql -h 172.17.10.190 -p 5432 -U repl -d postgres --command "select * from pg_stat_replication"|grep $IP
if [ "$?" != "0" ];then
echo
 "postgresql master-slave status is error! please login check!"|mail -r 
"[email protected]" -s "postgresql master-slave status is error" 
[email protected] && echo "$data postgresql postgresql master-slave status is error!">>/var/log/postgresql-error.log
fi
done
else
echo
 "postgresql master-slave status is error! please login check!"|mail -r 
"[email protected]" -s "postgresql master-slave status is error" 
[email protected] && echo "$data postgresql postgresql master-slave status is error!">>/var/log/postgresql-error.log
fi

2.3主从切换

主库查看进程为sender

备库

停止主库

查看slave的日志

创建触发文件,切换主

touch trigger.kenyon

查看slave的日志,面前已经切换为主

使用pg_controldata

备机状态为: in archive recovery

主库状态为:in production

时间: 2024-10-16 15:34:46

Postgresq9.6主从部署的相关文章

一键完成MySQL主从部署.

环境声明: 主从服务器位于 192.168.0.0/24 网段 master-->IP:192.168.0.88 master-->IP:192.168.0.89 在Master---主数据库的脚本  master-IP: 192.168.0.88 #!/bin/sh # Function: This is used for mysql-master role # made by zhigang.wang # contact: [email protected] MYUSER=root MYP

基于centos6的mysql5.7.13主从部署(二)

基于centos6的mysql5.7.13主从部署(二) 一.部署主mysql说明:mysql1是主机,mysql2是备机. 创建库 [[email protected] ~]# mysql -uroot -p123456 mysql> create database shiyan; mysql> exit Bye 将mysql库拷贝到shiyan库中 [[email protected] ~]# mysqldump -uroot -p123456 mysql > 234.sql [[e

puppet实现主从部署各种软件实战参考模型

puppet实现主从部署各种软件实战参考模型 ? 实验要求: ? ? 1.我将准备三个节点 node2 , node3 , node4 2.我们想让节点node3部署ntp,nginx ;节点node4部署ntp,memcached ? PS:这三个节点必须要能相互解析,并且时间要同步, 还要相互之间通信无需输入密码 ? ? 上面条件准备好以后,接下就是安装 puppet的服务端/客户端节点(master/agent) 我这里用的是puppet-2.7版本 ? ? 节点node2 (master

基于centos6的mysql5.7.13主从部署(一)

基于centos6的mysql5.7.13主从部署(一) 一.实验环境: 两台主机安装Centos6.7 32位操作系统: 两台Linux安装同一版本的MySQL,这里使用mysql5.7.13: mysql1的IP:192.168.100.129 mysql2的IP:192.168.100.128 二.部署过程: 说明: 关于mysql的详细安装过程,可以参考博客:http://wutengfei.blog.51cto.com/10942117/1931482,这里简单写下linux6版本安装

基于centos6的mysql5.7.13主从部署(三)

基于centos6的mysql5.7.13主从部署(三) 主从测试 登入(主)mysql1 [[email protected] ~]# mysql -uroot -p123456 mysql> unlock tables;  #解锁,对应上一章节的表的锁死 mysql> use shiyan; mysql> show tables; 删除其中一个表: mysql> drop table engine_cost; 登入(从)mysql2 [[email protected] ~]#

centos7上Rabbit集群主从部署

1.软件环境 操作系统:centos 7.2 X64 Erlang:18.3 Rabbit:3.5.1 节点IP:node1 192.168.1.21 Node 2 192.168.1.22 Node1为主,node2为从 2.安装部署 以下安装均使用root权限安装. 在两个节点服务器上安装: 安装依赖包 yum install gcc gcc-c++ ncurses-developenssl-devel -y 1)   安装Erlang 下载地址: wget http://distfiles

mariadb主从部署

MariaDB主从服务器优点简介 辅组实现备份Replication 高可用:在主服务器出现异常情况,修改指定配置可以直接顶替主服务器. 异地容灾 Scale out:分摊负载(是否启用!) 一.部署文档 1.确保在主服务器和从服务器上安装的MariaDB版本一致. 2.在主服务器上为从服务器设置一个连接账户 MariaDB [(none)]> GRANT REPLICATION SLAVE, SUPER, RELOAD ON *.* TO ''@'' IDENTIFIED BY '. 主服务器

postgresql 11.6部署主从部署(归档模式)

环境:OS:CentOs 7Postgres-11.6 1.安装步骤1.1    环境部署数据库部署节点    ip    角色Host01    192.168.1.130    主Host02    192.168.1.131    从 1.2  配置等效连接因为我们需要将主库的归档日志通过scp免密传输到备库等效连接配置可以参考https://www.cnblogs.com/hxlasky/p/12204180.html 1.3  主库安装1.3.1 安装介质准备下载地址: https:/

solr主从部署

最近项目中用到了solr,现在有时间来整理下solr的使用 1.3台solr服务器,采用主从复制的策略实现索引文件的同步,主从就是设置集群中一台server为主,另外为从服务器,从服务器定时从主服务器中同步数据