背景

canal-admin设计上是为canal提供整体配置管理、节点运维等面向运维的功能,提供相对友好的WebUI操作界面,方便更多用户快速和安全的操作

参考:

https://github.com/alibaba/canal/wiki/Canal-Admin-Guide

准备

首先确保你先完成了 canal-admin 的基本部署,请参考: 安装部署说明

设计理念

canal-admin的核心模型主要有:

  • instance,对应canal-server里的instance,一个最小的订阅mysql的队列
  • server,对应canal-server,一个server里可以包含多个instance
  • 集群,对应一组canal-server,组合在一起面向高可用HA的运维
简单解释:
  • instance因为是最原始的业务订阅诉求,它会和 server/集群 这两个面向资源服务属性的进行关联,比如instance A绑定到server A上或者集群 A上,
  • 有了任务和资源的绑定关系后,对应的资源服务就会接收到这个任务配置,在对应的资源上动态加载instance,并提供服务
    • 动态加载的过程,有点类似于之前的autoScan机制,只不过基于canal-admin之后可就以变为远程的web操作,而不需要在机器上运维配置文件
  • 将server抽象成资源之后,原本canal-server运行所需要的canal.properties/instance.properties配置文件就需要在web ui上进行统一运维,每个server只需要以最基本的启动配置 (比如知道一下canal-admin的manager地址,以及访问配置的账号、密码即可)

理解了这一层基本概念之后,就开始WebUI的操作介绍.

集群运维

创建集群

集群变更

配置项:
  • 修改集群/删除集群,属于基本的集群信息维护和删除
  • 主配置,主要是指集群对应的 canal.properties 配置,设计上一个集群的所有server会共享一份全局canal.properties配置 (如果有个性化的配置需求,可以创建多个集群)
  • 查看server,主要是指查看挂载在这个集群下的所有server列表

Server 运维

新建 Server

配置项:

  • 所属集群,可以选择为单机 或者 集群。一般单机Server的模式主要用于一次性的任务或者测试任务
  • Server 名称,唯一即可,方便自己记忆
  • Server Ip,机器ip
  • admin 端口,canal 1.1.4 版本新增的能力,会 在canal-server 上提供远程管理操作,默认值 11110
  • tcp 端口,canal 提供netty数据订阅服务的端口
  • metric 端口, promethues 的 exporter监控数据端口 (未来会对接监控)
Server 变更

配置项:

  • 配置,主要是维护单机模式的canal.properties配置,注意:挂载到集群模式的server,不允许单独编辑server的canal.properties配置,需要保持集群配置统一
  • 修改/删除,主要是维护server的基本属性,比如名字和ip、port
  • 启动/停止,主要是提供动态启停server的能力,比如集群内这个机器打算下线了,可以先通过停止释放instance的运行,集群中的其他机器通过HA就会开始接管任务
  • 日志,查看server的根日志,主要是canal/canal.log的最后100行日志
  • 详情,主要提供查询在当前这个server上运行的instance列表,以server维度方便快速做instance的启动、停止操作. 比如针对集群模式,如果server之间任务运行负载不均衡,可以通过对高负载Server执行部分Instance的停止操作来达到均衡的目的

Instance 运维

创建 Instance

instance配置比较简单,主要关注:

  • 资源关联,比如挂载到具体的单机 或 集群
  • instance.properties 配置维护,可以载入默认模板进行修改
Instance 变更

配置项:

  • 修改,主要就是维护instance.properties配置,做了修改之后会触发对应单机或集群server上的instance做动态reload
  • 删除,相当于直接执行instance stop,并执行配置删除
  • 启动/停止,对instance进行状态变更,做了修改会触发对应单机或集群server上的instance做启动/停止操作
  • 日志,主要针对instance运行状态时,获取对应instance的最后100行日志,比如example/example.log

系统运维

主要是涉及canal-admin的元数据配置,配置都在二进制包解压之后的conf目录下

-rwxr-xr-x  1 agapple  staff   403B  8 31 15:43 application.yml
-rwxr-xr-x  1 agapple  staff   5.0K  8 31 14:56 canal-template.properties
-rwxr-xr-x  1 agapple  staff   3.8K  8 30 22:14 canal_manager.sql
-rwxr-xr-x  1 agapple  staff   2.0K  8 31 14:56 instance-template.properties
-rwxr-xr-x  1 agapple  staff   1.5K  8 30 22:14 logback.xml
  • application.yml,springboot默认依赖的配置,比如链接数据库的账号密码,链接canal-server admin管理的账号密码
  • logback.xml,日志配置
  • canal-template.properties,canal配置的默认模板,针对canal-server开启自动注册时,会选择这个默认模板
  • instance-template.properties,instance配置的默认模板
作者:Jeebiz  创建时间:2023-05-29 09:58
最后编辑:Jeebiz  更新时间:2024-07-10 22:56