首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Citus:将现有数据库作为citus的工作节点

Citus:将现有数据库作为citus的工作节点
EN

Stack Overflow用户
提问于 2019-03-27 05:21:40
回答 1查看 568关注 0票数 0

我已经在我的一个服务器上有一个数据库,一个web应用程序使用。让我们说D1

我想制作一个新的web应用程序,在另一个服务器上使用新的数据库D2,与D1有一些关系。

我希望创建citus数据服务器,并将D1D2添加为shard表,并添加它们的工作节点作为各自的服务器。

我在citus文档中发现的是,碎片数据库表是在citus服务器上创建的,并自动分发给可用的工作节点。

如何使用现有数据库作为工作节点和具有新的citus服务器的碎片表。

EN

回答 1

Stack Overflow用户

发布于 2019-04-01 10:14:27

问题有点含糊不清,我不太明白有人在问什么。

我们有两个服务器,S1和S2,包含两个数据库,D1和D2。我们希望创建一个包含D1和D2的分布式数据库,我们将有一个第三个服务器S0,我们希望使用它作为一个citus协调器。

使用S1 (D1)和S2 (D2)作为工作人员不是问题。在协调器节点上创建主表。每个碎片都是在工人身上创建的。假设存在名称冲突,碎片表可以与旧表共存。

但是,您不能盲目地使用D1和D2中的现有数据,并期望它们是切碎表。数据需要重新分割。

步骤

  1. 阅读关于如何设置集群、选择分发键、加载数据的citus文档。
  2. 在S1、S2和S0 (协调器)上安装/安装citus扩展
  3. 将S1和S2添加为S0中的工作节点
  4. 决定表的分布。有些表需要在所有节点(引用表)上,有些表是根据某些键进行切分的。
  5. 在协调器节点上创建表,使用create_distributed_table/create_reference_table函数分发它们
  6. 加载数据,这可能是个问题。最简单的方法是将现有数据导出(复制)到外部文件,并从该文件导入(复制)到citus集群。在导入数据时,需要使用协调器节点(S0)。
  7. 在切换之前很好地使用新集群测试应用程序。
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/55370284

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档