网络
虚拟私有云 VPC
弹性公网IP EIP
弹性负载均衡 ELB
NAT网关 NAT
云专线 DC
虚拟专用网络 VPN
云连接 CC
VPC终端节点 VPCEP
企业路由器 ER
企业交换机 ESW
全球加速 GA
企业连接 EC
云原生应用网络 ANC
安全与合规
安全技术与应用
Web应用防火墙 WAF
企业主机安全 HSS
云防火墙 CFW
安全云脑 SecMaster
DDoS防护 AAD
数据加密服务 DEW
数据库安全服务 DBSS
云堡垒机 CBH
数据安全中心 DSC
云证书管理服务 CCM
威胁检测服务 MTD
态势感知 SA
认证测试中心 CTC
边缘安全 EdgeSec
应用中间件
微服务引擎 CSE
分布式消息服务Kafka版
分布式消息服务RabbitMQ版
分布式消息服务RocketMQ版
API网关 APIG
分布式缓存服务 DCS
多活高可用服务 MAS
事件网格 EG
管理与监管
统一身份认证服务 IAM
消息通知服务 SMN
云监控服务 CES
应用运维管理 AOM
应用性能管理 APM
云日志服务 LTS
云审计服务 CTS
标签管理服务 TMS
配置审计 Config
应用身份管理服务 OneAccess
资源访问管理 RAM
组织 Organizations
资源编排服务 RFS
优化顾问 OA
IAM 身份中心
云运维中心 COC
资源治理中心 RGC
解决方案
高性能计算 HPC
SAP
混合云灾备
开天工业工作台 MIW
Haydn解决方案工厂
数字化诊断治理专家服务
云生态
云商店
合作伙伴中心
华为云开发者学堂
华为云慧通差旅
开发与运维
软件开发生产线 CodeArts
需求管理 CodeArts Req
流水线 CodeArts Pipeline
代码检查 CodeArts Check
编译构建 CodeArts Build
部署 CodeArts Deploy
测试计划 CodeArts TestPlan
制品仓库 CodeArts Artifact
移动应用测试 MobileAPPTest
CodeArts IDE Online
开源镜像站 Mirrors
性能测试 CodeArts PerfTest
应用管理与运维平台 ServiceStage
云应用引擎 CAE
开源治理服务 CodeArts Governance
华为云Astro轻应用
CodeArts IDE
Astro工作流 AstroFlow
代码托管 CodeArts Repo
漏洞管理服务 CodeArts Inspector
联接 CodeArtsLink
软件建模 CodeArts Modeling
Astro企业应用 AstroPro
CodeArts盘古助手
华为云Astro大屏应用
计算
弹性云服务器 ECS
Flexus云服务
裸金属服务器 BMS
云手机服务器 CPH
专属主机 DeH
弹性伸缩 AS
镜像服务 IMS
函数工作流 FunctionGraph
云耀云服务器(旧版)
VR云渲游平台 CVR
Huawei Cloud EulerOS
云化数据中心 CloudDC
网络
虚拟私有云 VPC
弹性公网IP EIP
弹性负载均衡 ELB
NAT网关 NAT
云专线 DC
虚拟专用网络 VPN
云连接 CC
VPC终端节点 VPCEP
企业路由器 ER
企业交换机 ESW
全球加速 GA
企业连接 EC
云原生应用网络 ANC
CDN与智能边缘
内容分发网络 CDN
智能边缘云 IEC
智能边缘平台 IEF
CloudPond云服务
安全与合规
安全技术与应用
Web应用防火墙 WAF
企业主机安全 HSS
云防火墙 CFW
安全云脑 SecMaster
DDoS防护 AAD
数据加密服务 DEW
数据库安全服务 DBSS
云堡垒机 CBH
数据安全中心 DSC
云证书管理服务 CCM
威胁检测服务 MTD
态势感知 SA
认证测试中心 CTC
边缘安全 EdgeSec
大数据
MapReduce服务 MRS
数据湖探索 DLI
表格存储服务 CloudTable
可信智能计算服务 TICS
推荐系统 RES
云搜索服务 CSS
数据可视化 DLV
数据接入服务 DIS
数据仓库服务 GaussDB(DWS)
数据治理中心 DataArts Studio
湖仓构建 LakeFormation
智能数据洞察 DataArts Insight
应用中间件
微服务引擎 CSE
分布式消息服务Kafka版
分布式消息服务RabbitMQ版
分布式消息服务RocketMQ版
API网关 APIG
分布式缓存服务 DCS
多活高可用服务 MAS
事件网格 EG
开天aPaaS
应用平台 AppStage
开天企业工作台 MSSE
开天集成工作台 MSSI
API中心 API Hub
云消息服务 KooMessage
交换数据空间 EDS
云地图服务 KooMap
云手机服务 KooPhone
组织成员账号 OrgID
云空间服务 KooDrive
管理与监管
统一身份认证服务 IAM
消息通知服务 SMN
云监控服务 CES
应用运维管理 AOM
应用性能管理 APM
云日志服务 LTS
云审计服务 CTS
标签管理服务 TMS
配置审计 Config
应用身份管理服务 OneAccess
资源访问管理 RAM
组织 Organizations
资源编排服务 RFS
优化顾问 OA
IAM 身份中心
云运维中心 COC
资源治理中心 RGC
区块链
区块链服务 BCS
数字资产链 DAC
华为云区块链引擎服务 HBS
解决方案
高性能计算 HPC
SAP
混合云灾备
开天工业工作台 MIW
Haydn解决方案工厂
数字化诊断治理专家服务
价格
成本优化最佳实践
专属云商业逻辑
云生态
云商店
合作伙伴中心
华为云开发者学堂
华为云慧通差旅
其他
管理控制台
消息中心
产品价格详情
系统权限
客户关联华为云合作伙伴须知
公共问题
宽限期保留期
奖励推广计划
活动
云服务信任体系能力说明
开发与运维
软件开发生产线 CodeArts
需求管理 CodeArts Req
流水线 CodeArts Pipeline
代码检查 CodeArts Check
编译构建 CodeArts Build
部署 CodeArts Deploy
测试计划 CodeArts TestPlan
制品仓库 CodeArts Artifact
移动应用测试 MobileAPPTest
CodeArts IDE Online
开源镜像站 Mirrors
性能测试 CodeArts PerfTest
应用管理与运维平台 ServiceStage
云应用引擎 CAE
开源治理服务 CodeArts Governance
华为云Astro轻应用
CodeArts IDE
Astro工作流 AstroFlow
代码托管 CodeArts Repo
漏洞管理服务 CodeArts Inspector
联接 CodeArtsLink
软件建模 CodeArts Modeling
Astro企业应用 AstroPro
CodeArts盘古助手
华为云Astro大屏应用
存储
对象存储服务 OBS
云硬盘 EVS
云备份 CBR
高性能弹性文件服务 SFS Turbo
弹性文件服务 SFS
存储容灾服务 SDRS
云硬盘备份 VBS
云服务器备份 CSBS
数据快递服务 DES
云存储网关 CSG
专属分布式存储服务 DSS
数据工坊 DWR
地图数据 MapDS
键值存储服务 KVS
容器
云容器引擎 CCE
云容器实例 CCI
容器镜像服务 SWR
云原生服务中心 OSC
应用服务网格 ASM
华为云UCS
数据库
云数据库 RDS
数据复制服务 DRS
文档数据库服务 DDS
分布式数据库中间件 DDM
云数据库 GaussDB
云数据库 GeminiDB
数据管理服务 DAS
数据库和应用迁移 UGO
云数据库 TaurusDB
人工智能
AI开发平台ModelArts
华为HiLens
图引擎服务 GES
图像识别 Image
文字识别 OCR
自然语言处理 NLP
内容审核 Moderation
图像搜索 ImageSearch
医疗智能体 EIHealth
企业级AI应用开发专业套件 ModelArts Pro
人脸识别服务 FRS
对话机器人服务 CBS
语音交互服务 SIS
人证核身服务 IVS
视频智能分析服务 VIAS
城市智能体
自动驾驶云服务 Octopus
盘古大模型 PanguLargeModels
IoT物联网
设备接入 IoTDA
全球SIM联接 GSL
IoT数据分析 IoTA
路网数字化服务 DRIS
IoT边缘 IoTEdge
设备发放 IoTDP
企业应用
域名注册服务 Domains
云解析服务 DNS
企业门户 EWP
ICP备案
商标注册
华为云WeLink
华为云会议 Meeting
隐私保护通话 PrivateNumber
语音通话 VoiceCall
消息&短信 MSGSMS
云管理网络
SD-WAN 云服务
边缘数据中心管理 EDCM
云桌面 Workspace
应用与数据集成平台 ROMA Connect
ROMA资产中心 ROMA Exchange
API全生命周期管理 ROMA API
政企自服务管理 ESM
视频
实时音视频 SparkRTC
视频直播 Live
视频点播 VOD
媒体处理 MPC
视频接入服务 VIS
数字内容生产线 MetaStudio
迁移
主机迁移服务 SMS
对象存储迁移服务 OMS
云数据迁移 CDM
迁移中心 MGC
专属云
专属计算集群 DCC
开发者工具
SDK开发指南
API签名指南
DevStar
华为云命令行工具服务 KooCLI
Huawei Cloud Toolkit
CodeArts API
云化转型
云架构中心
云采用框架
用户服务
账号中心
费用中心
成本中心
资源中心
企业管理
工单管理
客户运营能力
国际站常见问题
支持计划
专业服务
合作伙伴支持计划
我的凭证
华为云公共事业服务云平台
工业软件
工业数字模型驱动引擎
硬件开发工具链平台云服务
工业数据转换引擎云服务
文档首页/ 数据复制服务 DRS/ 最佳实践/ 实时同步/ GaussDB集中式版数据同步到Kafka

GaussDB集中式版数据同步到Kafka

更新时间:2025-01-24 GMT+08:00
分享

场景描述

本实践通过创建DRS同步任务,实现将源数据库GaussDB集中式版的增量数据同步到目标端Kafka。

前提条件

  • 拥有华为云实名认证账号。
  • 账户余额大于等于0元。
  • 已登录数据复制服务控制台。

服务列表

  • 虚拟私有云 VPC
  • 云数据库GaussDB集中式版
  • 分布式消息服务Kafka
  • 数据复制服务 DRS

GaussDB主备数据库架构说明

图1 GaussDB主备逻辑架构图

GaussDB集中式版主要包含了OM、CM和DN等模块,主备版因为无CN,因此是业务应用直接下发任务给DN, DN处理完成后再将结果返回给业务应用。

主备版适用于数据量较小,且长期来看数据不会大幅度增长,但是对数据的可靠性,以及业务的可用性有一定诉求的场景。

DRS同步网络示意图

本示例中,DRS源数据库为华为云GaussDB集中式版,目标端为分布式消息服务Kafka,通过VPC网络,将源数据库的增量数据同步到目标端,部署架构可参考如下图示:

图2 GaussDB集中式版到Kafka同VPC场景

使用说明

  • 本实践的资源规划仅作为演示,实际业务场景资源以用户实际需求为准。
  • 本实践端到端的数据为测试数据,仅供参考;更多关于DRS使用相关内容请单击这里了解。

资源规划

表1 资源规划

类别

子类

规划

备注

VPC

VPC名称

vpc-DRStest

自定义,易理解可识别。

子网网段

10.0.0.0/24

子网选择时建议预留足够网络资源

所属Region

华南-广州

选择和自己业务区最近的Region,减少网络时延。

子网名称

subnet-drs01

自定义,易理解可识别。

GaussDB(源库)

实例名

drs-gaussdb-src-1

自定义,易理解可识别。

数据库版本

GaussDB 8.1.0

-

实例类型

主备版

参考GaussDB数据库类型说明,选择适合自己业务的库类型。

存储

超高IO

GaussDB支持“超高IO”存储类型,最大吞吐量为350MB/S。

规格

通用型

4 vCPUs | 16 GB

根据自己业务承载选择规格。

Kafka(目标端)

Kafka实例名

kafka-drs

自定义,易理解可识别。

版本

2.3.0

-

可用区

可用区三

可选择1个或者3个及以上可用区。实际业务场景推荐选择创建在不同的可用区,提升业务可靠性。

规格

c6.2u4g.cluster

-

代理个数

3

-

存储空间

高I/O,200GB

存储空间主要用于存储消息(包含副本,Kafka默认使用3副本),除了存储消息外还需要预留部分空间用于存储日志和元数据。

DRS同步任务

同步任务名

DRS-GaussDBToKafka

自定义。

源数据库引擎

GaussDB集中式版

-

目标数据库引擎

Kafka

本示例中目标数据库为Kafka

网络类型

VPC网络

创建任务的时候选择“VPN、专线网络”

操作流程

创建DRS任务,并且将GaussDB集中式版数据增量同步到Kafka的主要任务流程如图所示。

创建VPC

创建VPC,为创建GaussDB实例准备网络资源。

  1. 登录华为云控制台
  2. 单击管理控制台左上角的,选择区域。
  3. 单击左侧的服务列表图标,选择网络 > 虚拟私有云 VPC

    进入虚拟私有云信息页面。

  4. 单击“创建虚拟私有云”购买VPC。

  5. 单击“立即创建”。
  6. 返回VPC列表,查看创建VPC是否创建完成。

    当VPC列表的VPC状态为“可用”时,表示VPC创建完成。

创建安全组

创安全组,为创建GaussDB实例准备安全组。

  1. 登录华为云控制台
  2. 单击管理控制台左上角的,选择区域。
  3. 单击左侧的服务列表图标,选择网络 > 虚拟私有云 VPC

    进入虚拟私有云信息页面。

  4. 选择“访问控制 > 安全组”。
  5. 单击“创建安全组”。
  6. 填写安全组名称等信息。

  7. 单击“确定”。

创建GaussDB主备实例

本章节介绍创建GaussDB主备实例,作为同步任务目标库。

  1. 登录华为云控制台
  2. 单击管理控制台左上角的,选择区域。
  3. 单击左侧的服务列表图标,选择数据库 > 云数据库 GaussDB
  4. 单击“购买数据库实例”。
  5. 配置实例名称和实例基本信息。

  6. 选择实例规格。

    本示例中为测试实例,选择较小的测试规格,实际可选规格以界面为准。

  7. 选择实例所属的VPC和安全组(创建VPC创建安全组),配置数据库端口。

  8. 配置实例密码等信息。

  9. 单击“立即购买”,确认信息并提交。
  10. 返回实例列表。

    当实例运行状态为“正常”时,表示实例创建完成。

GaussDB实例构造数据

  1. 登录华为云控制台
  2. 单击管理控制台左上角的,选择区域。
  3. 单击左侧的服务列表图标,选择数据库 > 云数据库 GaussDB
  4. 选择GaussDB实例,单击实例后的“更多 > 登录”。
  5. 在弹出的对话框中输入密码后,单击“测试连接”检查。
  6. 连接成功后单击“登录”,登录GaussDB实例。
  7. 单击“新建数据库”,创建db_test测试库。

  8. 在db_test库中执行如下语句,创建对应的测试表schema_test.table1。

    create table schema_test.table1(c1 int primary key,c2 varchar(10),c3 TIMESTAMP(6));

创建Kafka实例

本章节介绍创建Kafka实例。

  1. 登录华为云控制台
  2. 单击管理控制台左上角的,选择区域。
  3. 单击左侧的服务列表图标,选择应用中间件 > 分布式消息服务Kafka版
  4. 单击“购买Kafka实例”。
  5. 选择实例区域和可用区。

  6. 配置实例名称和实例规格等信息。

  7. 选择存储空间和容量阈值策略。

  8. 选择实例所属的VPC和安全组(创建VPC创建安全组)。

  9. 配置实例密码。

  10. 单击“立即购买”,确认信息无误后单击“提交”。
  11. 返回实例列表。

    当Kafka实例运行状态为“运行中”时,表示实例创建完成。

创建Kafka的Topic

  1. 在“Kafka专享版”页面,单击Kafka实例的名称。
  2. 选择“Topic管理”页签,单击“创建Topic”。
  3. 在弹出的“创建Topic”的对话框中,填写Topic名称和配置信息,单击“确定”,完成创建Topic。

创建DRS同步任务

  1. 登录华为云控制台
  2. 单击管理控制台左上角的,选择区域。
  3. 单击左侧的服务列表图标,选择数据库 > 数据复制服务 DRS
  4. 选择左侧“实时同步管理”,单击“创建同步任务”。
  5. 填写同步任务参数:

    1. 配置同步任务名称。

    2. 选择需要同步任务的源库、目标数据库以及网络信息。

      这里的源库选择创建GaussDB主备实例中创建的GaussDB实例。

      图3 同步实例信息

    3. 选择规格类型和可用区。

  6. 单击“开始创建”。

    同步实例创建中,大约需要5-10分钟。

  7. 配置源库信息和目标库数据库密码。

    1. 配置源库信息。
    2. 单击“测试连接”。

      当界面显示“测试成功”时表示连接成功。

    3. 选择目标库所在VPC和子网,填写Kafka的IP地址和端口。
    4. 单击“测试连接”。

      当界面显示“测试成功”时表示连接成功。

  8. 单击“下一步”。
  9. 选择同步信息、策略、消息格式和对象等,投递到Kafka的消息格式。

    本次选择如下。

    表2 同步设置

    类别

    设置

    同步Topic策略

    集中投递到一个Topic,Topic名称“testTopic”。

    不同Topica策略,对应选择的Kafka partition策略也不同,详细的说明可参考同步Topic和Partition策略说明

    同步到Kafka partition策略

    全部投递到同Partition 0。

    不同Topica策略,对应选择的Kafka partition策略也不同,详细的说明可参考同步Topic和Partition策略说明

    投递到Kafka的数据格式

    可选择JSON格式,可参考Kafka消息格式

    同步对象

    同步对象选择db_test库下的schema_test.table1。

  10. 单击“下一步”,等待预检查结果。
  11. 当所有检查都是“通过”时,单击"下一步”。
  12. 确认同步任务信息正确后,单击“启动任务”。

    返回DRS实时同步管理,查看同步任务状态。

    启动中状态一般需要几分钟,请耐心等待。

    当状态变更为“增量同步”,表示同步任务已启动。

    说明:
    • 当前示例中GaussDB主备到Kafka选择单增量同步,任务启动后为增量同步状态。
    • 如果创建的任务为全量+增量同步,任务启动后先进入全量同步,全量数据同步完成后进入增量同步状态。
    • 增量同步会持续性同步增量数据,不会自动结束。

确认同步任务执行结果

由于本次实践为增量同步模式,DRS任务会将源库的产生的增量数据持续同步至目标库中,直到手动任务结束。下面我们通过在源库GaussDB中插入数据,查看Kafka的接收到的数据来验证同步结果。

  1. 登录华为云控制台
  2. 单击管理控制台左上角的,选择区域。
  3. 单击左侧的服务列表图标,选择数据库 > 云数据库 GaussDB”。
  4. 单击GaussDB实例后的“更多 > 登录”。
  5. 在弹出的对话框中,输入实例密码,单击“测试连接”检查。
  6. 连接成功后单击“登录”,登录GaussDB实例。
  7. 在DRS同步对象的db_test.schema_test.table1表中,执行如下语句,插入数据。

    insert into schema_test.table1 values(1,'testKafka',current_timestamp(6)); 
    update schema_test.table1 set c2 ='G2K' where c1 =1;
    delete schema_test.table1 where  c1 =1;

  8. 通过Kafka客户端查看接收到JSON格式数据。

     ./kafka-console-consumer.sh --bootstrap-server ip:port --topic  testTopic   --from-beginning

  9. 结束同步任务。

    根据业务情况,确认数据已全部同步至目标库,可以结束当前任务。
    1. 单击“操作”列的“结束”。
    2. 仔细阅读提示后,单击“是”,结束任务。

同步Topic和Partition策略说明

表3 Topic和Partition策略说明

Topic策略

对应可选的Partition策略

说明

集中投递到一个Topic

对于源库业务量不大的场景,建议选择集中投递到一个Topic。

按库名.schema.表名的hash值投递到不同Partition

适用于单表的查询场景,可以提高单表读写性能,推荐使用此选项。

全部投递到Partition 0

适用于有事务要求的场景,写入性能比较差,如果没有强事务要求,不推荐使用此选项。

按表的主键值hash值投递到不同的Partition

适用于一个表一个Topic的场景,避免该表都写到同一个分区,消费者可以并行从各分区获取数据。

按库名.schema的hash值投递到不同Partition

适用于一个database一个topic的场景,避免多个schema下的数据都写到一个分区,消费者可以并行从各分区获取数据。

按表的非主键列值的hash值投递到不同的Partition

适用于一个表一个Topic的场景,避免该表都写到同一个分区,用户可以按照非主键列值的hash值自定义message key,消费者可以并行从各分区获取数据。

按库名-schema-表名自动生成Topic名字

如果每张表数据量都非常大,建议选择自动生成Topic名字,按库名-schema-表名确定一个Topic。

全部投递到Partition 0

适用于有事务要求的场景,写入性能比较差,如果没有强事务要求,不推荐使用此选项。

按表的主键值hash值投递到不同的Partition

适用于一个表一个Topic的场景,避免该表都写到同一个分区,消费者可以并行从各分区获取数据。

按表的非主键列值的hash值投递到不同的Partition

适用于一个表一个Topic的场景,避免该表都写到同一个分区,用户可以按照非主键列值的hash值自定义message key,消费者可以并行从各分区获取数据。

按库名自动生成Topic名字

对于源库数据量量不大的场景,可以选择一个database自动生成Topic名字,按库名确定一个Topic。

按库名.schema.表名的hash值投递到不同Partition

适用于单表的查询场景,可以提高单表读写性能,推荐使用此选项。

全部投递到Partition 0

适用于有事务要求的场景,写入性能比较差,如果没有强事务要求,不推荐使用此选项。

按库名.schema的hash值投递到不同Partition

适用于一个database一个topic的场景,避免多个schema下的数据写到一个分区,消费者可以并行从各分区获取数据。

按库名-schema自动生成Topic名字

如果每个schema数据量都非常大,建议选择按库名-schema自动生成Topic名字,按库名-schema确定一个Topic。

按库名.schema.表名的hash值投递到不同Partition

适用于单表的查询场景,可以提高单表读写性能,推荐使用此选项。

全部投递到Partition 0

适用于有事务要求的场景,写入性能比较差,如果没有强事务要求,不推荐使用此选项。

提示

您即将访问非华为云网站,请注意账号财产安全

文档反馈

文档反馈

意见反馈

0/500

标记内容

同时提交标记内容