12.7 处理故障转移和删除节点

在本节中,我们将看看故障切换如何处理。我们还将看看如何使用安全可靠的方法添加节点到Postgres-XC设置以及如何从Postgres-XC设置删除节点。

12.7.1 处理节点故障转移

如果您在Postgres-XC中执行一个查询,它可能会诶分派到集群内许多不同的节点。例如,在高度分区表执行一个顺序扫描将涉及到许多不同的节点。现在的问题是:如果一个或者一些数据节点停机会发生什么?

答案很简单:Postgres-XC将无法利用发生故障的节点执行请求。这会导致一个读取和写入的问题。尝试从故障节点获取的查询将返回一个表示连接不可用的错误。

因为您作为一个用户,这意味着如果您正在运行Postgres—XC,您一定要为您的系统拿出一个合适的故障转移以及高可用性(HA)策略。我们建议创建所有节点的副本以确保,在primary数据节点出现故障时,控制器总是可以到达一个可替代的节点。Linux HA 是一个使各节点故障安全和实现快速故障转移的不错的选择。

目前,仅仅靠Postgres-XC来创建一个HA策略是不可能的。

12.7.2 更换节点

在一段时间以后,您可能要删除一个节点。要做到这一点,您只需从您的psql脚本简单地调用DROP NODE

test=# \h DROP NODE

Command: DROP NODE

Description: drop a cluster node

Syntax:

DROP NODE nodename

如果您要执行这样的操作,您要确保您是一个超级用户。普通用户 是不允许从集群中删除节点的。

当您删除一个节点时,确保对您来说它没有对您有用的数据。删除一个节点仅仅是Postgres-XC内部元数据的变化,所以,那个操作会很快,数据也会被从您的数据视图中删除。

一个问题是:您怎么能真正找出数据的位置?Postgres-XC 有一组系统表,它允许您检索有关节点的信息,数据分布等等。下面的例子显示了如何创建一个表以及我们如何才能弄明白它在哪里:

test=# CREATE TABLE t_location (id int4)

DISTRIBUTE BY REPLICATION;

CREATE TABLE

test=# SELECT node_name, pcrelid, relname

FROM pgxc_class AS a, pgxc_node AS b,

pg_class AS c

WHERE a.pcrelid = c.oid

AND b.oid = ANY (a.nodeoids);

node_name | pcrelid | relname

-----------+---------+------------

node2 | 16406 | t_location

node3 | 16406 | t_location

node4 | 16406 | t_location

(3 rows)

在我们的例子中,该表已经被复制到所有节点了。

当删除节点时,有一件麻烦的事情您要记住:如果您删除一个名称,使用相同的名称和连接参数重新创建它,它将会是不一样的东西。当创建一个新的节点,它会得到一个新的对象ID。在PostgreSQL中,一个名称和一个对象ID是不相关的。这意味着,如果您意外删除了一个节点,并使用相同的名称重新创建它,您将仍然面临问题。当然,您总是可以神奇地通过手动调整系统表来解决它,但是,这不是您应该做的。

因此,我们强烈建议,当从生产系统删除节点时,必须谨慎。

12.7.3 运行 GTM standby

在出现故障的情况下,数据节点不是唯一能够导致停机的因素。全局事务管理也应该故障安全,以确保在发生灾难的情况下,没有任何事情会出错。如果事务管理器丢失,就不能使用您的Postgres-XC集群了。

要确保GTM不会出现单点故障,您可以使用一个GTM standby。配置一个GTM standby 并不难做到。所有您需要做的是在一个备用节点上创建一个GTM配置文件并在gtm.conf设置一些参数。

startup = STANDBY

active_host = 'somehost.somedomain.com'

active_port = '6666'

synchronous_backup = off

首先,我们要设置启动参数为STANDBY。这会告诉GTM作为以slave解决。然后,我们要告诉 standby在哪里可以找到主要的生产GTM。我们可以通过添加一个主机名和端口来实现。

最后,我们可以决定GTM应该同步复制或者异步复制。

要启动standby,我们再次可以使用gtm_ctl。这一次,我们使用 –Z  gtm_standby 来标记节点为standby。

12.8 总结

在本章中,我们讲解了Postgres-XC,一个能够水平分区和查询分布的分布式版本的PostgreSQL。该Postgres-XC项目的目标是提供一个能够透明地向外写入扩展的数据库解决方案。它提供了一个一致性的数据视图,并提供了各种选项来在集群内部分发数据。

知道Postgres-XC不仅仅是一个简单地附加到PostgreSQL,而是一个完全兼容的代码分支是很重要的。

下一章将包括PL/Proxy,一个分片PostgreSQL数据库系统的工具。我们将学习如何分发数据到各个节点和碎片数据到处理大规模的设置。

PostgreSQL Replication之第十二章 与Postgres-XC一起工作(7)的更多相关文章

  1. PostgreSQL Replication之第十二章 与Postgres-XC一起工作(4)

    12.4 性能优化 Postgres-XC不是一个奇特的PostgreSQL版本,而是一个真正的分布式系统.这意味这,您不能只存储数据,希望事情超出服务器之外的快速,高效.如果您想优化速度,思考数据是 ...

  2. PostgreSQL Replication之第十二章 与Postgres-XC一起工作(3)

    12.3 配置一个简单的集群 在本章中,我们要建立一个由三个数据节点组成的集群.一个协调节点,以及管理集群的全局事务管理节点.对于每个组件,我们必须创建一个目录: hs@vm:~/data$ ls - ...

  3. PostgreSQL Replication之第十二章 与Postgres-XC一起工作(1)

    在本章中,我们希望将我们的注意力集中在写可扩展,多主,同步,对称和PostgreSQL的称为Postgres-XC(PostgreSQL eXtensible Cluster)的透明复制方案.该项目的 ...

  4. PostgreSQL Replication之第十二章 与Postgres-XC一起工作(5)

    12.5 创建表和发送查询 介绍了Postgres-XC以及其底层的思想之后,是时候创建我们的第一个表,看看集群将如何表现.下面的例子演示了一个简单的表.将使用id列的哈希键来分布它: test=# ...

  5. PostgreSQL Replication之第十二章 与Postgres-XC一起工作(2)

    12.2安装 Postgres-XC 可以从 http://postgres-xc.sourceforge.net/下载Postgres-XC.对于本书,我们使用1.0.3版本的Postgres-XC ...

  6. PostgreSQL Replication之第十二章 与Postgres-XC一起工作(6)

    12.6 添加节点 Postgres-XC允许您在那个过程中的任何一个时间点添加新的服务器到计划中.所有您需要做的是按照我们之前演示的设置一个节点,并在 控制器上调用CREATE NODE.然后,该系 ...

  7. PostgreSQL Replication之第十四章 扩展与BDR

    在这一章中,将向您介绍一个全新的技术,成为BDR.双向复制(BDR),在PostgreSQL的世界里,它绝对是一颗冉冉升起的新星.在不久的将来,许多新的东西将会被看到,并且人们可以期待一个蓬勃发展的项 ...

  8. PostgreSQL Replication之第十五章 与Walbouncer 一起工作

    与Walbouncer 一起工作 在本书的最后一章,将引导您通向2014年发布的一个工具,称为walbouncer.本书中的大多数技巧说明了如何复制整个数据库实例,如何分片,等等.在最后一章,是关于w ...

  9. PRML读书会第十二章 Continuous Latent Variables(PCA,Principal Component Analysis,PPCA,核PCA,Autoencoder,非线性流形)

    主讲人 戴玮 (新浪微博: @戴玮_CASIA) Wilbur_中博(1954123) 20:00:49 我今天讲PRML的第十二章,连续隐变量.既然有连续隐变量,一定也有离散隐变量,那么离散隐变量是 ...

随机推荐

  1. css文件内引用外部资源文件的相对路径

    1.default.css文件内容(位于css文件夹下): .ClassName .ClassName .ClassName .page-sidebar .sidebar-search .submit ...

  2. SDP协议中的Continuation State

    在SDP request和SDP response中,最后一部分为Continuation State,结构如下: 它用于一次response不够把所有的Data传回去的情况.这时候需要将respon ...

  3. Qt high DPI

    http://doc.qt.io/qt-5/highdpi.html Qt Support Ability to provide pixmaps or artwork for high resolut ...

  4. Intersection of Two Linked Lists | LeetCode

    利用两个栈,然后分别存储每一个链表. 继而,相继pop相同的节点. 有些细节需要注意,请看最后的返回值是如何处理的. /** * Definition for singly-linked list. ...

  5. js判断input为空校验

    突然发现最近js发现的问题比较多,更发现我怎么快成了前端开发了?不能够啊!我后台怎么不出问题呢?我的后台是太简单了吗?mybatis-dao-service-controller返回给前台...... ...

  6. HTML5新特性总结

    一.HTML5 中的一些有趣的新特性: 用于绘画的 canvas 元素 用于媒介回放的 video 和 audio 元素 对本地离线存储的更好的支持 新的特殊内容元素,比如 article.foote ...

  7. Selenium2学习-034-WebUI自动化实战实例-032-获取页面 body 大小

    获取 body 元素大小的方法,非常简单,直接上码,敬请参阅! /** * Get body size * * @author Aaron.ffp * @version V1.0.0: autoSel ...

  8. C# BeginInvoke

    在用C#编写串口助手时,希望创建线程更新UI,网上有人采用BeginInvoke方法, 这里记录一下使用方法. 参考链接: http://blog.csdn.net/zaijzhgh/article/ ...

  9. Oracle利用external table 查看trace文件

    1. 用下面的语句找到trace文件的路径 select * from v$diag_info where name='Default Trace File'; 2. 创建一个directory用来加 ...

  10. ionic安装时遇到的minimatch错误

    安装提示 npm WARN deprecated minimatch@2.0.10: Please update to minimatch 3.0.2 or higher to avoid a Reg ...