在本章中,我们希望将我们的注意力集中在写可扩展,多主,同步,对称和PostgreSQL的称为Postgres-XC(PostgreSQL eXtensible Cluster)的透明复制方案。该项目的目标是为终端用户提供透明的复制解决方案,通过水平扩展到多台服务器,这允许更高水平的负载。

在运行Postgres-XC的服务器阵列中,您可以连接到集群中的任何节点。该系统将完全确保您能够准确的获得和每个节点上数据的相同的视图。这是非常重要的,因为它解决了一些客户端的问题。没有必要为只写到一个节点上的应用程序添加逻辑。您可以简单轻松地平衡您的负载;在一个事务提交之后,数据总是在所有的节点上了即时可见。

当考虑Postgres-XC时,要记住的最重要的事情是,它不是附加到PostgreSQL的,它是代码分配出来的。因此,它不使用普通的PostgreSQL版本号,代码库通常会滞后官方的PostgreSQL代码树。

本章将为您提供 有关Postgres-XC相关的信息。我们将在本章包括如下主题:

• Postgres-XC 架构

• 安装 Postgres-XC

• 配置一个集群

• 优化存储

• 性能管理

• 添加和删除节点

12.1 理解 Postgres-XC 架构architecture

在我们深入探索Postgres-XC的安装和最终的配置之前,我们必须深入地看看这个神奇的软件的基础架构:

一般情况下,一个 Postgres-XC 系统有如下必要的组件组成:

• 数据节点

• 全局事务管理(GTM)

• 协调节点

• 全局事务管理代理

让我们来看看每个组件的目的。

12.1.1数据节点(Data nodes)

数据节点是系统的实际存储骨干。它将持有集群内部数据的全部或者一部分。它被连接到Postgres-XC的基础设施并处理本地的SQL执行。

12.1.2全局事务管理(GTM)

GTM将为集群提供一个一致的数据视图。一个一致的数据视图是必须的,因为,否则的话,在一个对应用程序来说是一个完全透明的环境中,负载均衡将是不可能的。

一致的视图是通过集群范围的快照提供的。除此之外,GMT将创建全局事务ID(GXID)。这些GXIDs是必不可少的,因为事务必须在集群范围内被协调。

除了这个核心功能,GTM也将处理全局的东西,例如序列,等等。

12.1.3协调节点(Coordinators)

协调节点是一个为应用程序提供切入点服务的软件。一个应用程序将连接到其中一个协调节点。它将复制SQL分析,全局执行计划的创建,和全局SQL的执行。

12.1.4全局事务管理代理(GTM Proxy)

GTM Proxy 可以用于提高性能。鉴于Postgres-XC的架构,每个事务不得不给GTM发送一个请求。在许多情况下,这可能会导致延迟,以及随后的性能问题。GTM Proxy 将介入并收集发送到GTM的请求到请求块,并将它们一起发送出去。

这里的一个优点是,连接可以被缓存,以避免由于一直打开和关闭来接引起的大量的开销。

[您还记得我们关于光速的介绍的?这是这一切发生的地方;来来回回发送请求可能一起延迟问题,因此,开销必须尽可能多的降低,以确保保持高性能。]

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

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

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

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

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

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

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

  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. P1970 花匠

    状态定义是dp中非常重要的,可以直接影响到效率,如此题,第一种思路是: #include <bits/stdc++.h> using namespace std; const int ma ...

  2. this super 解释

    关于 this super 什么时候有,他们指向谁? 书上说: this 指向自己,super指向父亲的对象,个人觉得是错误的. 我认为 this 是一个指向自己对象的句柄,而super只是一个类句柄 ...

  3. XMLHttpRequest函数

    function createXmlHttpRequest(){ if(window.ActiveXObject){ return new ActiveXObject("Microsoft. ...

  4. JS面相对象

    一.理解对象: //第一种:基于Object对象 var person = new Object(); person.name = 'My Name'; person.age = ; person.g ...

  5. Python学习笔记——1——基础知识

    1.1.变量和算法 python语言很类似人类语言,变量不需要定义类型.比如: 整型 字符串类型 数组 Java int a=12 String s="test" String[] ...

  6. 变长数组列表ArrayList

    简介:此数据结构定义为一个ArrayList结构体类型,维护了一个内部堆数组.通过realloc函数实现了数组容量自动扩充,每次扩充到原来的2倍. 通过函数指针实现了使用者根据自己的需求按条件按查找目 ...

  7. PHP--yii中findOne转换成数组

    $res = News::findOne($new_id)->toArray(); yii框架的多表联查:controller层: //news 与 news_theme 是多对一的关系$inf ...

  8. 软件工程概论---max单元测试

    题目:一个单元测试,查找list[]中的最大值 编写一个程序对Largest函数进行测试,列举所有测试用例. 思路:首先确保数组不为空,和数组长度不为0,否则输入错误.根据老师所给的函数写一个主函数, ...

  9. oracle 表查询一

    通过scott用户下的表来演示如何使用select语句,接下来对emp.dept.salgrade表结构进行解说. emp 雇员表字段名称   数据类型       是否为空   备注-------- ...

  10. PMP--案例解答要点

    没有相关的管理流程或方针: 没有进行良好的策划: 资源不足(人.资金.设备和工具): 缺少培训,不具备相关的知识和技能要求: 项目干系人识别不充分,干系人没有充分的介入: 缺少配置管理.变更控制和版本 ...