canal和ES同步失败维护步骤

ES同步失败维护步骤:

  1. 登录到ES服务器:xx.xx.xx.xx。

  2. 停止 Canal 和 Canal-Adapter 服务:

    复制代码
    cd /root/canal/bin
    ./stop.sh
    
    cd /root/canal-adapter/bin
    ./stop.sh
  3. 确定一下是哪个表修改了主键的值,例如 tbl_sparking,使用 Logstash 手动同步数据:

    shell 复制代码
    cd /root/canal-adapter/elk
    sudo /usr/share/logstash/bin/logstash -f 2-tbl_video_device_info.conf
    #如果遇上内存不足的可以执行
    export LS_JAVA_OPTS="-Xms5g -Xmx5g"
    #如果想要重新同步,不建议
    #查看所有索引
    GET /_cat/indices?v
    #单独删除es索引数据
    DELETE /tbl_video_device_info
  4. 同步完成后,启动 Canal 服务,查看日志以确保启动成功:

    复制代码
    cd /root/canal/bin
    ./startup.sh
    tail -f /root/canal/logs/example/example.log

    如果出现错误,需要先停止 Canal,然后删除 /root/canal/conf/example 下的 meta.dat 文件,再启动 Canal。

  5. Canal 服务正常后,再启动 Canal-Adapter 服务,并查看日志:

    复制代码
    cd /root/canal-adapter/bin
    ./startup.sh
    tail -f /root/canal-adapter/logs/adapter/adapter.log
  6. 此时数据仍不完整,需要使用 Logstash 手动同步全部数据:

    复制代码
    cd /root/canal-adapter/elk
    sudo /usr/share/logstash/bin/logstash -f 1-tbl_ps_device_info.conf 
    sudo /usr/share/logstash/bin/logstash -f 2-tbl_video_device_info.conf 
    sudo /usr/share/logstash/bin/logstash -f 3-tbl_ps_order_in.conf 
    sudo /usr/share/logstash/bin/logstash -f 4-tbl_ps_order_out.conf
    sudo /usr/share/logstash/bin/logstash -f 5-tbl_user_info.conf 
    sudo /usr/share/logstash/bin/logstash -f 6-tbl_order_in_pay_log.conf 
    sudo /usr/share/logstash/bin/logstash -f 7-tbl_order_out_pay_log.conf
    sudo /usr/share/logstash/bin/logstash -f 8-tbl_sparking.conf 
    sudo /usr/share/logstash/bin/logstash -f 9-tbl_account_payment_log.conf 
    sudo /usr/share/logstash/bin/logstash -f 10-tbl_parking_manager.conf 
    sudo /usr/share/logstash/bin/logstash -f 11-tbl_bat_txn.conf
    sudo /usr/share/logstash/bin/logstash -f 12-tbl_bat_pay_txn.conf 
    sudo /usr/share/logstash/bin/logstash -f 13-tbl_bse_info_mchnt.conf
    sudo /usr/share/logstash/bin/logstash -f 14-tbl_online_carinfo.conf
    sudo /usr/share/logstash/bin/logstash -f 15-tbl_trans_order.conf

确保 Canal 和 Canal-Adapter 服务正常运行,并手动同步数据以确保数据完整性。

最后启动监控:

复制代码
   cd /root/canal-adapter/logs/adapter/
   nohup ./monitor.sh &

分页增加:

复制代码
FROM tbl_ps_order_out AS a"
    lowercase_column_names => false
    jdbc_paging_enabled => true
    jdbc_page_size => 10000  # 增加分页大小,以减少总页数
    last_run_metadata_path => "/root/logstash_last_run_metadata"
    clean_run => false
  }

如果更改了ID

也可以通过直接logstash全量同步,这样新的数据就会增加上去,但是原来的还在,需要通过es直接删除之前id的数据,前提是需要知道原来的id是多少。如果不删除,那么就造成了脏数据。

yaml 复制代码
GET tbl_ps_order_out/_search
{
  "query": {
    "match_all": {}
  }
}


DELETE /tbl_trans_order

DELETE /tbl_ps_order_out/_doc/555555555555555555555555555555

但是始终需要停canal-adapter 停canal,起canal,起canal-adapter

相关推荐
贫民窟的勇敢爷们17 小时前
SpringBoot整合AOP切面编程实战,实现日志统一记录+接口权限校验
java·spring boot·spring
Mahir0817 小时前
Redis 与 MySQL 数据同步:一致性保证的完整解决方案
数据库·redis·mysql·缓存·面试·数据一致性
2301_7693406717 小时前
如何在 Vuetify 中可靠捕获 Chip 关闭事件(包括键盘触发).txt
jvm·数据库·python
AC赳赳老秦17 小时前
供应链专员提效:OpenClaw自动跟踪物流信息、更新库存数据,异常自动提醒
java·大数据·服务器·数据库·人工智能·自动化·openclaw
迈巴赫车主17 小时前
Java基础:list、set、map一遍过
java·开发语言
灵犀学长18 小时前
基于 Spring ThreadPoolTaskScheduler + CronTrigger 实现的动态定时任务调度系统
java·数据库·spring
北秋,18 小时前
PostgreSQL(Postgres)数据库基础用法 + 数字型 + 字符型 完整联合注入实战
数据库·postgresql·开源
m0_5967490919 小时前
JavaScript中手动实现一个new操作符的底层逻辑
jvm·数据库·python
多加点辣也没关系19 小时前
Redis 的安装(详细教程)
数据库·redis·缓存
好家伙VCC19 小时前
【无标题】
java