# canal_mysql_elasticsearch_sync **Repository Path**: starcwang/canal_mysql_elasticsearch_sync ## Basic Information - **Project Name**: canal_mysql_elasticsearch_sync - **Description**: 基于canal的mysql和elasticsearch实时同步方案,支持增量同步和全量同步 - **Primary Language**: Java - **License**: Apache-2.0 - **Default Branch**: master - **Homepage**: None - **GVP Project**: No ## Statistics - **Stars**: 568 - **Forks**: 203 - **Created**: 2017-10-27 - **Last Updated**: 2025-04-03 ## Categories & Tags **Categories**: search-engine **Tags**: None ## README # canal_mysql_elasticsearch_sync 支持请star✨ # 交流Q群:733688083 **canal于v1.1.2版本后,已支持自动同步到Elasticsearch。赞canal** 基于 *canal* 的 *Mysql* 与 *Elasticsearch* 实时同步的 *javaweb* 服务。 canal是阿里巴巴mysql数据库binlog的增量订阅&消费组件。 ## 工作原理 ### 全量 暴露Http接口(接口定义见[wiki](https://github.com/starcwang/canal_mysql_elasticsearch_sync/wiki/HttpApi)),待调用后开启后台线程,通过主键分批同步指定数据库中数据到Elasticsearch > 读取数据库会加**读锁** > 主键必须为数字类型 #### 过程 1. 首先会根据所给的数据库主键字段,拿到最大的主键数字max_id; 2. 设*pk*=min_id(默认是数据库中的主键最小值); 2. 加读锁🔐,从数据库中取出*pk* —— *pk*+*stepSize* 大小的数据(默认500)的数据; 3. 插入到Elasticsearch中; 4. 释放读锁🔐,pk累加*stepSize*,循环3.操作,直到*pk*>*max_id* ### 增量 循环监听canal通过binlog同步过来的event事件,区别增删改进行与之对应的Elasticsearch的操作。 > 目前只解析了 insert、update、delete,其它数据库操作会被忽略 ## 默认相关字段映射
Mysql字段类型 | Elasticsearch类型 |
char | {"type": "text", "fields": {"keyword": {"type": "keyword", "ignore_above": 256}} |
text | {"type": "text", "fields": {"keyword": {"type": "keyword", "ignore_above": 256}} |
blob | {"type": "text", "fields": {"keyword": {"type": "keyword", "ignore_above": 256}} |
int | {"type": "long"} |
date | {"type": "date"} |
time | {"type": "date"} |
float | {"type": "float"} |
double | {"type": "float"} |
decimal | {"type": "float"} |
其它 | {"type": "text", "fields": {"keyword": {"type": "keyword", "ignore_above": 256}} |