首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

谁说Postgresql 没有靠谱的高可用

接上期(如果你刚开始看的话,那估计可能会丈二和尚,建议还是从1 开始看) 上期说到了见证服务器,见证服务器的功能到底有什么用,其实如同各种高可用中(这里说的是完备的高可用)大部分都是三台,因为怕什么,...怕脑裂,因为高可用要面对的问题是很多的,尤其网络的问题,如果因为网络的原因造成服务器本身没有问题,但在网络断开的某个时间段造成了,主从切换,则就会造成双主的尴尬现象。...所以在数据中心或比较关键的业务中,使用的数据库服务器的高可用也是要妥妥当当的。wintness不是一个成熟的备用节点,也没有集成到复制中,但是在决定哪个网络段占多数时,它有效地代表了“投票”。...首先我们要搭建一台和前边两台没有任何关系的postgresql 的数据库。...到这里上一期的问题,还差一个没有回答,到底IP 怎么能切换?

1.9K20
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    谁说postgresql 没有靠谱的高可用(3)

    -f /etc/repmgr.conf 就可以完成postgresql 高可用,主库失败,自动切换到从库的部署。...从库的日志中,可以看到1 分钟后,无法连接到postgresql 的主库服务,程序已经开始了切库的服务 ? 从下图也可以看出切主后的结果,主已经变到了从库,从库已经被提升为主库了。 ?...但需要注意的 1 如果原主,已经掉线很长时间,两个库的日志之间已经无法进行追日志的情况,那就无法使用这个命令,而是用其他的方法。...2 如果原主本身数据受损,或者无法启动那这个命令也是没有办法帮助你的, 这个命令的大致的使用点,1 主库意外关机后的从新加入集群(主库能用但和从库有一定的数据不一致了) 所以PG 的集群高可用还是挺有意思的...,尤其适用repmgr 一体化的方案,还是比较利于维护和模型修复的。

    2.6K40

    谁说postgresql 没有靠谱的高可用(2)

    SSH 协议 4 检测当前的archive 文件 5 检测主从之间的数据差距,通过wallog 来判断 6 检测没有问题,关闭主节点,如果还有没有checkpoint的,就等待checkpoint 7...将变为主库,这个过程其实和MHA 没有什么区别 1 在关闭 primary 前的和关闭后的图 ?...2 关闭primary 的图 ? 3 切换成功,从库已经可以进行写操作 ? 好了到目前为止,POSTGRESQL 的高可用,手动,自动 都是可以的,没有任何问题。...2 切换的过程如果不成功怎么办,什么可能的因素会导致切换失败 3 多节点,如果切换,其他的节点是否可以连接到新的主上,并继续工作 4 跨数据中心的怎么来进行高可用的规划。...,不是逻辑复制,所以也没有那么简单。

    1.4K20

    谁说postgresql 没有靠谱的高可用(6)

    的系统表我们看看有什么,如果你说我看不到,或者里面啥都没有,你一定是没有通过 repmgr 这个账号登录repmgr库 events表中包含了相关的在这个节点,所有关于repmgr 相关的事件的记录,...目前repmgr 最高的版本已经不是 4.4 ,而是 5.0 ,5.0 的版本兼容所有目前正式版的postgresql ,同时一个集群中的各个节点的repmgr 的版本应该是一致的,不能存在不同版本的混用的做法...部分版本支持的postgresql 列表 3 repmgr 包可以不用二进制方式安装吗 可以,可以下载2象限的yum 源,可以直接 rpm 包安装,如果在yum 安装时出现问题,请检查下面的依赖包装没有装...postgresql,conf 的设置有一些要求 本身没有,但针对于复制来说,还是需要在重复一下 1 是否有足够的 replication_slots 2 wal_level 设置的是否对 3 host_standby...其实postgresql 的高可用方法有很多,这六期仅仅是说了其中一种,高可用可以有很多的变化,即使是repmgr 也可以搭配其他的多种中间件来进行高可用的使用。 学无止境,适合就好。

    2.3K20

    谁说 PostgreSQL 没有靠谱的高可用(1)

    最近问postgresql 那个高可用靠谱的人越来越多,其实我也试过几种postgresql 的高可用方案,而最近听到的声音是 PostgreSQL 没有靠谱的高可用方案。...所以就有了这篇文字 —————————————————————————————— 今天说的是另一种PG的高可用方案,这种方案的好的地方 1 大厂支持 2 配置简单靠谱,没有众多依赖包安装后,还出问题让你有想自杀的意愿...这个高可用的方案已经在生产上使用了有一段时间,目前没有出过问题,之前写过,但是在这一段时间的使用中也发现了一些问题,所以准备详细的对这个高可用方案来详细的说说,也避免某些挑刺的说 PG 没有靠谱的高可用这样的笑话...,conf 文件中的 listen 地址改为本机的地址 (这些工作其实也是做 primary standby 的工作,和高可用本身是没有关系的,知识 repmgr 帮助你做了这件事) 启动服务器,正常,...想说 POSTGRESQL 没有靠谱高可用方式的,打脸不 下面就开始手动切换 repmgr -f /etc/repmgr.conf standby switchover -U repmgr --verbose

    3.6K41

    【python】tkinter组件,from Tkinter import * 与 import Tkinter 的区别

    PyQt 组件在窗体上的定位 pack函数 tkinter常见事件类型 常见事件类型 事件属性 基本使用方法 from Tkinter import * 与 import Tkinter 的区别...前言 tkinter可以用于 Python 的 GUI 编程,提供了一些常用的组件,如按钮、标签、文本框等,方便用户进行界面设计和交互。可以通过导入 tkinter 模块来使用这些组件。...import * 与 import Tkinter 的区别 1、如果是from Tkinter import * 那么你是导入Tkinter下的所有函数、等等(注意:如果package或者module...,可以省略掉Tkinter即可 进一步解释:__all__属于module的属性,它是一个全局变量 在Python中一切都是对象,全局变量则是module的属性,类变量则的类的属性,实例变量则是对象的属性...") 3、总结 from xxxx import * a、如果没有__all__,则是module中所有的属性 b、如果有__all__,则为__all__中的元素(注意:__all__可以为tuple

    3.2K20

    没有后台可用的 app 快速搭建动态ios审核开关的方法

    最近发现苹果的机审有所改变,希望大家不要欺骗 App Store Review Team,如果侥幸上架成功请在一个月后在更成马甲包,否则价格昂贵的公司开发者账号就会马上被封,但是近来的 Uber 审核事件...,以及发生在我个人身上的 审核团队不对我的长篇详细辩解作正面回答,且无限期推迟我的 App 审核的事情发生后,我彻底对这个团队没有了尊重,作为能力有限的个人开发者,我会选择通过一定的技术手段来欺骗审核团队...,项目已经上线,但是无法发布给用户(审核开关还是打开的状态,用户得不到审核不允许通过的功能) 这里介绍一个为没有后台可用的 app 快速搭建动态审核开关的方法: 新建一个 public 的 GitHub...Repo,仓库里面有没有东西都无所谓,重点在于你可以通过新建、删除仓库的方式,来远程控制一个开关:即这个仓库的地址(比如 www.github.com/yourName/repoName)是否可以访问...;如果 GitHub 可以访问,但是你的仓库不能访问,说明你已经在审核通过之后删掉了这个仓库,则用户手里的 app 可以解锁那些特定的功能(www.github.com 目前没有被墙,但是 www.gist.github.com

    1.5K10

    没有了可用Task slot,Flink新增任务会怎样?

    没有了可用Task slot,新增任务会怎样?...如下图所示,一个普通Flink1.7的Local环境,正在运行一个并行度为4的任务,现有Task slot全部被使用,因此Available Task Slots为零: ?...如下图,新提交的任务,状态是SCHEDULED(红框所示),执行的主机也没有分配(绿框所示): ?...看来要想任务顺利执行,首先要保证slot数量够用,目前机器内存是够用的,那么就把slot数量调大些吧; 注意 由于修改的配置文件要重启Flink才能生效,在生产环境请慎用!...修改配置 根据官方文档的指导,应该修改conf目录下的flink-conf.yaml文件中taskmanager.numberOfTaskSlots的值,如下图红框所示,文档地址:https://ci.apache.org

    2.3K20

    全局安装 npm 包报错没有权限

    问题 在全局安装 npm 包的时候,比如 npm i npm-check -g,可能会报错,提示没有权限 Error: EACCES: permission denied, access '/usr...命令,看到我们现在登陆的用户是 anna,不是 root,于是没有权限也是符合预期的,需要把 node_module 的所有者换成 anna(这里只是一个例子,以自己尝试的名字为准) 3.换下目录所有者...(注意换下用户名 anna) sudo chown -R anna: /usr/local/lib/node_modules chown 命令是将指定文件的拥有者改为指定的用户或组 参数 -R 处理指定目录以及其子目录下的所有文件...npm 包。...参考 这个方法参考了 stackoverflow 上的这个问题,感兴趣的同学可以看看~ stackoverflow.com/questions/4… 以上是本文的全部内容,欢迎点赞和评论~

    1.9K00
    领券