Ubuntu PostgreSql主从切换
主机:192.168.100.70
从机:192.168.100.71
通用配置(即主从都要配置)
修改/etc/postgresql/10/main/pg_hba.conf
host all all 192.168.100.xx/32 trust #允许xx服务器连接到本机 host replication guoxm 192.168.100.xx/32 md5 #运行guoxm用户在xx上复制本机数据
例如:70服务器是主服务器,那么xx就是从服务器
修改/etc/postgresql/10/main/postgresql.conf
listen_addresses = ‘*’ #监听所有ip wal_level = hot_standby #热备模式 max_wal_senders = 1 #最多有1个流复制连接 wal_sender_timeout = 60s #主机发送流超时时间 max_standby_streaming_delay = 30s # 数据流备份的最大延迟时间 wal_receiver_status_interval = 10s # 多久向主报告一次从的状态,当然从每次数据复制都会向主报告状态,这里只是设置最长的间隔时间 hot_standby_feedback = on #错误反馈 max_connections = 100 #最大连接时间,如果要支持主从切换那么就配置成一样
切换到postgres用户
sudo su - postgres
这个时间就已经进入到PostgreSQL的home目录(/var/lib/postgresql)下了
创建recovery.conf.upgrade升级文件
touch recovery.conf.upgrade
然后编辑recovery.conf.upgrade
vi recovery.conf.upgrade
编辑如下内容
standby_mode = on primary_conninfo = 'host=192.168.100.71 port=5432 user=guoxm password=guoxm' recovery_target_timeline = 'latest' trigger_file = '/var/lib/postgresql/10/main/postlog/trigger.kenyou'
注意:host配置的是主服务器的ip和端口以及用户名密码
保存并退出
创建recovery.conf.downgrade降级文件
standby_mode = on primary_conninfo = 'host=192.168.100.71 port=5432 user=guoxm password=guoxm' recovery_target_timeline = 'latest'
其实就是比升级文件少了一个trigger_file配置项而已
注意:host配置的是主服务器的ip和端口以及用户名密码
保存并退出
因为/var/lib/postgresql/10/main/文件夹下并没有postlog所以要手动创建postlog文件夹
mkdir 10/main/postlog
以上是主从服务器都要配置的部分
从库切换成主库:
注意,从库升级为主库需要手动创建trigger.kenyou文件(主库切从库不用创建)
touch 10/main/lostlog/trigger.kenyou
然后,将recovery.conf.upgrade文件copy到10/main文件夹中,并改名为recovery.conf
cp recovery.conf.upgrade 10/main/recovery.conf
退出到原用户
exit
重启数据库服务
sudo service postgresql restart
然后查看日志,检查服务是否起来了
tail –f /var/log/postgresql/postgresql-10-main.log
主库切换成从库
前面步骤和从库切换成主库差不多,区别就是不用创建trigger.kenyou文件
只需要将recovery.conf.upgrade文件copy到10/main文件夹中,并改名为recovery.conf
然后,将recovery.conf.downgrade文件copy到10/main文件夹中,并改名为recovery.conf
cp recovery.conf.downgrade 10/main/recovery.conf
退出到原用户
exit
重启数据库服务
sudo service postgresql restart
然后查看日志,检查服务是否起来了
tail –f /var/log/postgresql/postgresql-10-main.log
编写升级降级脚本
vi switch.sh
编辑如下内容
#!/bin/bash
downgrade() {
echo "[$(date "+%Y-%m-%d %H:%M:%S")] Database role downgradeing..."
echo 'guoxm' | sudo -S cp recovery.conf.downgrade 10/main/recovery.conf
restartPostgreSqlServer $@
echo "[$(date "+%Y-%m-%d %H:%M:%S")] Database role downgrade success"
}
upgrade() {
echo "[$(date "+%Y-%m-%d %H:%M:%S")] Database role upgradeing..."
echo 'guoxm' | sudo -S cp recovery.conf.upgrade 10/main/recovery.conf
echo 'guoxm' | sudo -S touch 10/main/postlog/trigger.kenyou
restartPostgreSqlServer $@
echo "[$(date "+%Y-%m-%d %H:%M:%S")] Database role upgrade success"
}
setOwner() {
echo "[$(date "+%Y-%m-%d %H:%M:%S")] File recovery.conf owner changeing..."
echo 'guoxm' | sudo -S chown -R postgres:postgres 10/main/recovery.conf
echo "[$(date "+%Y-%m-%d %H:%M:%S")] File recovery.conf owner change success"
}
restartPostgreSqlServer() {
setOwner $@
echo "[$(date "+%Y-%m-%d %H:%M:%S")] Database server restart..."
echo 'guoxm' | sudo -S service postgresql restart
echo "[$(date "+%Y-%m-%d %H:%M:%S")] Database server restart success"
}
if [ "$1" != "" ]; then
obj=$1
shift
else
echo 'Using parameters: downgrade | upgrade'
fi
case $obj in
downgrade)
downgrade $@
;;
upgrade)
upgrade $@
;;
esac
保存并退出
然后赋予可执行权限
sudo chmod u+x switch.sh
这样就可以通过脚本切换主从角色了
Ubuntu PostgreSql主从切换的更多相关文章
- PostgreSQL手动主从切换
主从切换操作: 1>主库宕机或者测试主备切换情况下停掉主库:systemctl stop postgres 从库会报日志错误信息:[root@db02 /]# cd /var/postgresq ...
- PostgreSQL高可用集群方案收集/主从切换/一主多从(待实践)
对于业内来说,基本都在围绕主从切换的高可用方案: http://www.10tiao.com/html/175/201509/210974337/1.html https://www.jianshu. ...
- Mycat读写分离、主从切换、分库分表的操作记录
系统开发中,数据库是非常重要的一个点.除了程序的本身的优化,如:SQL语句优化.代码优化,数据库的处理本身优化也是非常重要的.主从.热备.分表分库等都是系统发展迟早会遇到的技术问题问题.Mycat是一 ...
- postgresql主从配置
master:10.0.1.114 slaver:10.0.1.116 一.yum安装https://blog.csdn.net/weixin_41048363/article/details/803 ...
- postgresql主从同步配置
前言 不久前,公司的一台物理机器硬件坏了,导致运行在其上的虚拟机都挂了.很不凑巧的是,我负责的那台虚拟机的系统盘坏了(ps:感觉老天在玩我),导致里面的数据永远的离我而去(ps:当时我的内心是崩溃的) ...
- mycat(读写分离、负载均衡、主从切换)
博主本人平和谦逊,热爱学习,读者阅读过程中发现错误的地方,请帮忙指出,感激不尽 1.环境准备 1.1新增两台虚拟机 mycat01:192.168.247.81 mycat02:192.168.247 ...
- Redis集群(九):Redis Sharding集群Redis节点主从切换后客户端自动重新连接
上文介绍了Redis Sharding集群的使用,点击阅读 本文介绍当某个Redis节点的Master节点发生问题,发生主从切换时,Jedis怎样自动重连新的Master节点 一.步骤如下: 1.配 ...
- redis主从配置及主从切换
环境描述: 主redis:192.168.10.1 6379从redis:192.168.10.2 6380 一.主从配置 1.将主从redis配置文件redis.conf中的aemonize no ...
- mysql主从切换
mysql 主从切换 主停,从做主步骤如下: 1 确认从服务器已经完成所有同步操作:stop slave io_thread show processlist 直到看到状态都为:xxx has rea ...
随机推荐
- valueof这个万能方法,将string转换为int或者int转换为string都可以
private static String testString = "111"; int stringInt = Integer.valueOf(testString); Str ...
- PPAPI插件与浏览器的通信
PPAPI的插件,原本是能够使用JS与浏览器交互的,https://code.google.com/p/ppapi/wiki/InterfacingWithJavaScript.这里还提供了一个JS与 ...
- IP协议解读(三)
今天我们来介绍网络层中的ICMP协议 ICMP报文格式 图一: 从图片上我们能够分析出.前三位的字段都是固定的.8位类型字段,8位代码字段.16位校验和字段.其它字段因ICMP报文类型不同而不同.8位 ...
- QTP自带订票实现循环执行,參数化和将异常提示信息输出
做这个样例主要是为了积累一些较基础的知识,以便日后可參考学习 这个样例是一个订票的C/Sclient程序 一.业务需求: 1.实现异常和正常数据登录窗体,系统对数据进行校验 2.登录成功后.进行订票业 ...
- Linux就该这么学 20181008(第十三章BIND)
参考链接https://www.linuxprobe.com Bind提供域名解析服务 DNS Domin Name Server 域名解析服务 功能模式 .正向解析,将域名解析为IP地址 .反向解析 ...
- Jmeter执行多条Mysql语句报错
花了很长时间找原因,Jmeter一直返回的是MySql语法错误,就写了两条很简单的删除语句,并且在MySql里可以正常执行 包括换了jdbc驱动包,更改不同的Query Type等 后来发现两条语句拆 ...
- Google浏览器vim命令
使用鼠标久了,手腕.肩膀依旧疼痛.偶尔逛知乎,看到有人推荐chrome浏览器的vimium插件(火狐浏览器是vimperator),安装了使用了几天,真不愧是浏览器神器,好用到想哭,而且非常容易上手. ...
- Maven 学习笔记(二)
前面一文——Maven 学习笔记(一)中已经提到了 pom 的大部分配置,Maven 本质上是一个插件框架,它的核心并不执行任何具体的构建任务,所有这些任务都交给创建来完成,每一个任务都会对应一个插件 ...
- Ubuntu14.04下初步使用MongoDB
不多说,直接上干货! Ubuntu14.04下Mongodb(在线安装方式|apt-get)安装部署步骤(图文详解)(博主推荐) shell命令模式 输入mongo进入shell命令模式,默认连接的数 ...
- Windows平台下如何使用node.js显示系统盘符
本文地址: http://www.cnblogs.com/blackmanba/articles/windows-nodejs-show-system-letter.html或者http://fork ...