Postgresq9.6主从部署

本文涉及的产品
云原生数据库 PolarDB MySQL 版,通用型 2核4GB 50GB
云原生数据库 PolarDB PostgreSQL 版,标准版 2核4GB 50GB
简介: Postgresq9.6主从部署实验环境名称IP系统Master172.17.10.190Centos 6.5Slave172.17.10.189Centos 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;

wKioL1jT9aOCAZVTAACJLn0Arvk876.png

查看主从状态

select * from pg_stat_replication;

wKiom1jT9oqDxXLKAADvjuYegcw403.png

脚本监控主从

#!/bin/bash
# mail  xuel@51idc.com
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 
"xuel@51idc.com" -s "postgresql master-slave status is error" 
xuel@51idc.com \
&& 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 
"xuel@51idc.com" -s "postgresql master-slave status is error" 
xuel@51idc.com \
&& echo "$data postgresql postgresql master-slave status is error!">>/var/log/postgresql-error.log
fi

2.3主从切换

主库查看进程为sender

wKiom1jUiKTwsu0UAALvaWigL5E515.png

备库

wKioL1jUiRjB8XPAAAJNDLZCTIU269.png

停止主库

wKioL1jUiVGSZNWiAAEmy2IYoj8840.png

查看slave的日志

wKioL1jT-KujDMuiAANHbW6b5yI968.png

创建触发文件,切换主

touch trigger.kenyon

wKiom1jT-Q3RDgNUAAUdPTrS_YI464.png

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

wKiom1jT-UnyC2mnAAIvlmww7-I077.png

使用pg_controldata

wKioL1jT-XXiXGkoAABQpY5XhfM716.png

wKioL1jT-bDAuyz9AANjzAsM3a4422.png

备机状态为: in archive recovery

主库状态为:in production

 


相关实践学习
使用PolarDB和ECS搭建门户网站
本场景主要介绍基于PolarDB和ECS实现搭建门户网站。
阿里云数据库产品家族及特性
阿里云智能数据库产品团队一直致力于不断健全产品体系,提升产品性能,打磨产品功能,从而帮助客户实现更加极致的弹性能力、具备更强的扩展能力、并利用云设施进一步降低企业成本。以云原生+分布式为核心技术抓手,打造以自研的在线事务型(OLTP)数据库Polar DB和在线分析型(OLAP)数据库Analytic DB为代表的新一代企业级云原生数据库产品体系, 结合NoSQL数据库、数据库生态工具、云原生智能化数据库管控平台,为阿里巴巴经济体以及各个行业的企业客户和开发者提供从公共云到混合云再到私有云的完整解决方案,提供基于云基础设施进行数据从处理、到存储、再到计算与分析的一体化解决方案。本节课带你了解阿里云数据库产品家族及特性。
目录
相关文章
|
存储 NoSQL 网络安全
Redis安装(单机、主从、哨兵、集群)
Redis安装(单机、主从、哨兵、集群)
164 1
|
SQL 关系型数据库 MySQL
MySQL集群-主从服务器搭建(一主多从)
MySQL集群-主从服务器搭建(一主多从)
525 0
MySQL集群-主从服务器搭建(一主多从)
|
6月前
|
存储 负载均衡 NoSQL
Redis 高可用篇:你管这叫主从架构数据同步原理?
Redis 高可用篇:你管这叫主从架构数据同步原理?
336 5
|
12月前
|
存储 监控 NoSQL
Redis 高可用:主从复制、哨兵模式、集群模式-2
Redis 高可用:主从复制、哨兵模式、集群模式
160 1
|
12月前
|
缓存 运维 NoSQL
Redis 高可用:主从复制、哨兵模式、集群模式-1
Redis 高可用:主从复制、哨兵模式、集群模式
158 1
|
存储 NoSQL 算法
接近3w详解Docker搭建Redis集群(主从容错、主从扩容、主从缩容)
接近3w详解Docker搭建Redis集群(主从容错、主从扩容、主从缩容)
138 0
|
存储 缓存 运维
【高并发/高可用/哨兵机制/集群模式/高可用与主备切换/主从复制/断点续传】
【高并发/高可用/哨兵机制/集群模式/高可用与主备切换/主从复制/断点续传】
190 0
【高并发/高可用/哨兵机制/集群模式/高可用与主备切换/主从复制/断点续传】
|
存储 缓存 监控
Redis单机、主从、哨兵、集群演进之路
Redis架构演进 1.为什么需要主从 2.为什么需要哨兵 3.有了主从又有了哨兵,为什么有需要分片集群呢?
242 0
|
关系型数据库 MySQL Linux
Mysql主从复制与高可用主备切换搭建完整详细版
Mysql主从复制与高可用主备切换搭建完整详细版
|
存储 负载均衡 NoSQL
Redis 高可用篇:你管这叫主从架构数据同步原理? (上)
本篇主要带大家全方位吃透 Redis 高可用技术解决方案之一主从复制架构。 本篇硬核,建议收藏慢慢品味,我相信读者朋友会有一个质的提升。如有错误还望纠正,谢谢。关注「码哥字节」设置「星标」第一时间接收优质文章,谢谢读者的支持。
292 0
Redis 高可用篇:你管这叫主从架构数据同步原理? (上)