在本章中,我们希望将我们的注意力集中在写可扩展,多主,同步,对称和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. Happy

    1.delighted 2.over the moon                   Alex is over the moon with promotion. 3.really pleased ...

  2. [转]漫谈数据中心CLOS网络架构

    http://djt.qq.com/article/view/238 1.数据中心网络架构挑战 随着技术的发展,数据中心的规模越来越大,一个数据中心的服务器容量从几年前的几千台服务器发展到今天的几万甚 ...

  3. mysql从只有一个备份文件(多个数据库的备份)中恢复数据到指定数据库

    mysql -uroot -p 要恢复的数据库的名字 --one-database<备份文件

  4. Oracle数值处理函数 (绝对值、取整...)

    1.绝对值:abs()    select abs(-2) value from dual; 2.取整函数(大):ceil()    select ceil(-2.001) value from du ...

  5. 原生js实现跑马灯抽奖效果

    目前好多的微信活动都有一些抽奖活动,其中就有跑马灯. <!DOCTYPE html> <html> <head> <title>跑马灯效果</ti ...

  6. php的异步处理

    在PHP Web程序中,发送手机短信.电子邮件.转换视频格式.记录日志.数据挖掘采集等,都是比较耗时的操作. 为了增强用户体验,需要将这些操作转为异步执行 PHP Web程序中的短耗时异步处理   前 ...

  7. HTML5 测验记录

    结果:11/20 您的回答: 1.HTML5 之前的 HTML 版本是? 您的回答:HTML 4 正确答案:HTML 4.01 2.HTML5 的正确 doctype 是? 您的回答:<!DOC ...

  8. Python 虚拟环境Virtualenv

    本人也是Python爱好者,众所周知,Python扩展多,每次为了测试,安装各种各样的扩展,这样导致本地的Python环境非常混乱,就有人想到搞个隔离环境  和 本地环境没有关系,随时可以删除这个隔离 ...

  9. td的cellIndex属性被style.display改变

    IE7下面td的cellIndex属性,居然会随着style.display='none'的设置而改变,真是太恶心了

  10. 在使用EFCodeFirst中出现类型“System.Data.Objects.ObjectContext”在未被引用的程序集中定义的解决方案

    我安装了EF4.1版本,并在一个项目中映射一个数据库并生成了EF的MODEL实体层 测试:在Default.aspx页面上加了个GridView控件,后台进行绑定 using System; usin ...