数据同步平台CloudCanal的透明化、可视化运维之道
CloudCanal-万少 查看原文
前言
CloudCanal是一款由ClouGence公司发行的集结构迁移、数据全量迁移/校验/订正、增量实时同步为一体的数据迁移同步平台。产品包含完整的产品化能力,助力企业打破数据孤岛、完成数据互融互通,从而更好的使用数据。CloudCanal社区版为免费版本,我们会持续地对其维护,请大家放心下载使用。如有兴趣使用请参考文章底部相关资料。
数据同步产品的透明化、可视化运维
数据同步产品是企业的基础设施产品,其透明化、可视化程度与产品的运维、使用效率息息相关。
透明化
透明化指产品内部本身对于用户来说不完全是一个黑盒子,产品内部核心构件以产品化的形式向用户透明,使得用户可以介入内部构件的管理,提供更加精细化的产品控制。
?
对于数据同步这类基础设施产品,透明化会显得更为重要。数据同步产品由于用户的数据源、数据负载、数据处理需求、机器环境等差异,用户在实际使用、运维中往往需要有对产品更强的干预能力,从而更好的满足自身的场景需求。在数据同步领域,这类干预诉求主要体现在如下几个方面:
- 源、目标核心组件透明化:用户能够对源端的读取器和对端的写入器有更加精细的控制。例如对于源端可以配置限流、批大小、解析线程数等。
- 内部组件异常透明化:在私有部署的情况下,数据同步产品的数据源、机器等等都是用户添加的。场景本身的复杂性,不可避免的导致一些由于使用、配置不当而产生的异常。内部组件异常透明化,可以使得用户更加准确、及时的发现问题、解决问题。例如数据同步过程中,数据源突然下线,通过透明化的日志即可看到数据源Connection refused异常,这样,可以快速将问题原因锁定在数据源无法访问这点上。
- 运行时信息透明化:丰富的运行时信息能够使得出现问题时,提供更多诊断信息,快速定为问题原因。
可视化运维主要体现在产品功能各个维度的可视化成熟度。更高的可视化程度,会带来更好的易用性和产品体验。
CloudCanal透明化、可视化运维 核心组件透明可视化
CloudCanal核心组件主要包含:
- Console: 管控进程,负责产品化能力
- Sidecar: 机器保姆进程,负责task和console之间信息转发以及task的可用性保障
- Task: 具体迁移、同步任务的执行
- 异步任务工作流:数据同步任务的创建过程比较复杂,CloudCanal通过异步工作流来完成。
- 状态机:状态机主要负责任务状态的切换,主要是结构迁移、全量、增量之间的阶段切换
![数据同步平台CloudCanal的透明化、可视化运维之道](https://img.it610.com/image/info9/f6cf4e3d6fc345e3968065e801856808.jpg)
文章图片
SIDECAR
在机器管理页面可以对Sidecar组件进行控制和检查,包含:
- 生命周期管理
- 远程日志查看
- 详细机器监控(点击圆盘可以进入详细)
![数据同步平台CloudCanal的透明化、可视化运维之道](https://img.it610.com/image/info9/0785763351824fa4979ff1539f31777c.jpg)
文章图片
?
CONSOLE
异步任务工作流 数据同步产品中任务创建是个复杂的流程,往往设计多个子任务。CloudCanal的console内置的异步任务工作流会按顺序执行子任务。针对失败的子任务,我们可以看到具体失败的步骤,以及错误信息,便于运维同学定位问题。
![数据同步平台CloudCanal的透明化、可视化运维之道](https://img.it610.com/image/info9/56ae1f9686d0468c88272b553a1147cd.jpg)
文章图片
![数据同步平台CloudCanal的透明化、可视化运维之道](https://img.it610.com/image/info9/dc60c9a6675f47cb899a5c3c47c1aa7a.jpg)
文章图片
状态机 每个任务都有其关联的状态机,负责任务的阶段流转。状态的流转由条件触发器触发。
![数据同步平台CloudCanal的透明化、可视化运维之道](https://img.it610.com/image/info9/e83f8e953f5f47d8962ce620fcb1a768.jpg)
文章图片
![数据同步平台CloudCanal的透明化、可视化运维之道](https://img.it610.com/image/info9/26c9fb373f1e4870975a3829dd83a2cb.jpg)
文章图片
TASK
任务详情 任务列表页提供了任务的列表信息和基本的生命周期控制能力以及进度查看。
![数据同步平台CloudCanal的透明化、可视化运维之道](https://img.it610.com/image/info9/7138edb47a594b2e95d4fa43660284b9.jpg)
文章图片
任务详情页面提供了任务完整的详情信息,包括:
- 生命周期控制
- 订阅关系查看(库表映射)
- 源端、目标端数据源详细信息
- 各阶段同步细节
- 任务白屏化日志
- 关联的绑定机器信息
- 同步进度、位点细节
![数据同步平台CloudCanal的透明化、可视化运维之道](https://img.it610.com/image/info9/ac76833665664adf99ee660f1a0cea37.jpg)
文章图片
任务内核参数 除任务详情的透明可视化之外,任务内核参数是CloudCanal对于任务精细化控制的重要能力。任务详情中的参数修改支持对任务内核进行更加精细化的控制,以目标端参数配置为例,我们可以控制例如:
- 异常跳过策略
- 并行度
- 约束冲突时的处理策略
- 对端RPS限流
- 大小写策略
![数据同步平台CloudCanal的透明化、可视化运维之道](https://img.it610.com/image/info9/fb127241ed374b769a439eb95ea069da.jpg)
文章图片
内部组件异常透明化
CloudCanal的管控会搜集所有的异常日志,并且可视化的在控制台展示。核心组件的日志均会分类展示,便于用户快速查看日志和定位问题。CloudCanal会完整毫无遗漏的搜集所有运行时的异常,这也使得一些在日志中隐秘的、偶发的问题直接暴露出来。这些信息都会指导CloudCanal后续的研发,确保产品步步为营、高质量地去迭代升级。
![数据同步平台CloudCanal的透明化、可视化运维之道](https://img.it610.com/image/info9/1808777844734b8c9d5d169058b4f83b.jpg)
文章图片
运行时信息透明化
CloudCanal的运行时信息透明化主要体现在如下两个维度:
- 监控
- 日志
![数据同步平台CloudCanal的透明化、可视化运维之道](https://img.it610.com/image/info9/5188a31eb6df4bd1b0a1a992b40c9340.jpg)
文章图片
日志 在CloudCanal平台上提供了核心组件的白屏化日志,并且对日志均按照功能进行了划分。
?
机器日志 在机器管理处,查看机器日志,我们可以查看机器的完整日志、慢通信日志、异常日志等信息。
![数据同步平台CloudCanal的透明化、可视化运维之道](https://img.it610.com/image/info9/a2a3cba6ace64797af5e9a84cd7fa1d4.jpg)
文章图片
任务日志 在任务详情页,用户则可以查看实时的任务日志,确认任务实时运行状态或者确认问题。
![数据同步平台CloudCanal的透明化、可视化运维之道](https://img.it610.com/image/info9/0a7a9683e2224ee3b843774199cdffab.jpg)
文章图片
![数据同步平台CloudCanal的透明化、可视化运维之道](https://img.it610.com/image/info9/e68dc75f9da34d2abcc7573452a8d8a8.jpg)
文章图片
总结 作为面向技术、运维人员的一款数据基础设施产品,在设计之初考虑产品层面的透明化、可视化运维是尤其重要的。这使得产品在后续功能变得越来越复杂和强大时,产品本身依然能够提供高质量的可运维性,同时也确保产品本身能够更好的迭代和发展。
相关资料 CloudCanal社区版免费下载与安装教程:https://www.askcug.com/topic/75
5分钟搞定 MySQL 到 ClickHouse 实时数据同步-CloudCanal 实战:https://www.askcug.com/topic/76
5分钟搞定 MySQL 到 ElasticSearch 迁移同步-CloudCanal实战:https://www.askcug.com/topic/97
5分钟搞定 MySQL 到 TiDB 的数据同步 - CloudCanal实战:https://www.askcug.com/topic/106
加入CloudCanal粉丝群掌握一手消息和获取更多福利,请添加我们小助手微信:suhuayue001
CloudCanal-免费好用的企业级数据同步工具,欢迎品鉴。
了解更多产品可以查看官方网站: http://www.clougence.com
CloudCanal社区:https://www.askcug.com/
推荐阅读
- Docker应用:容器间通信与Mariadb数据库主从复制
- 基于微信小程序带后端ssm接口小区物业管理平台设计
- 使用协程爬取网页,计算网页数据大小
- Java|Java基础——数组
- Python数据分析(一)(Matplotlib使用)
- Jsr303做前端数据校验
- Spark|Spark 数据倾斜及其解决方案
- 数据库设计与优化
- 爬虫数据处理HTML转义字符
- 数据库总结语句