[开源重构]Search(Elasticsearch/OpenSearch) Sync Tool

[开源重构]Elasticsearch/OpenSearch Sync Tool

背景

  • 因为要做集群灾备,需要在主备两个集群之间持续性地同步数据,调查过多个方案:
    • CCR(Cross-cluster replication) 官方工具,可惜需要收费,无奈放弃 😦
    • esm 如官方文档说所,最大的特点 . 可惜也发现不少问题:
      • 同步后发现数据不全,一般需要采用多次执行的方式来补全数据;
      • 调查后发现,其采用的是获取源数据后,使用多个 goroutine 将数据通过bulk写入目标index, 会造成目标index重复写入很多相同数据的问题;
      • 更改源码,加入 --sync 功能,通过 scroll 同时查询源和目标index,比较其内容的方式,实现增量更新(Add/Update/Del), 目前该 PR/84 已经合并到esm中。
      • 目前 esm 的作者已经不再维护,因此后来发现的一些bug也很难改善及合并。
      • 从 issue 和 源码来看, esm 不支持 OpenSearch, esm作者以后也不会再更改

更改

  • 对源码进行了更改,对同步(Sync)功能进行了加强,从而满足我在两个集群之间"近"实时同步的需求。
    • 增加 --stamp 参数,如果 index 中有表示最后更新时间的字段,可以进一步减少查询的数据量(本质是利用esm中的 --query 方式,单独提取出来更易于控制)
    • 增加对 OpenSearch 的支持
    • 对已有代码进行了较大的重构,更改了一些bug
    • 编写通用的集群同步脚本 search_sync.sh, 可以按需同步集群中的index,也可以对每月自动生成的 index 进行处理.
    • 为了方便测试,使用 docker-compose 来设置不同版本,不同类型的 源/目标 集群.

注意

  • 目前主要的更改集中在 --sync 上,其他功能测试的不多,有可能会出现问题.

源码位置

相关推荐
尽兴-3 分钟前
Elasticsearch 8.14.3 安装部署实战:Windows/Linux + Kibana + 常用插件
linux·windows·elasticsearch·kinana·es 浏览器插件
柯儿的天空12 分钟前
2026年AI技术突破与产业落地全景:从GPT-5到多模态智能体的新纪元
人工智能·gpt·microsoft·开源·aigc·ai编程·ai写作
老星*32 分钟前
AFFiNE:开源知识管理平台完全指南:Notion+Miro替代方案的完整教程
开源·notion
老星*36 分钟前
Ghost:开源专业博客平台,打造内容变现的创作圣地
开源·内容运营
世岩清上1 小时前
从静态陈列到数据活化:策展逻辑的升维与重构
重构·博物馆·展厅·数字展陈·数据活化·纪念馆
老星*1 小时前
Cal.com:开源日程预约管理平台,打造智能化的预约管理体验
开源
阳光普照世界和平1 小时前
借力大模型,重构研发效能:全流程提效实战指南
大数据·人工智能·重构
大数据AI人工智能培训专家培训讲师叶梓1 小时前
Fast-WAM:重构 WAMs 的效率与性能平衡
人工智能·重构·大模型·具身智能·人工智能讲师·大模型讲师·大模型培训
研究点啥好呢1 小时前
3月24日GitHub热门项目推荐|让AI无所不能
人工智能·python·开源·github
威联通安全存储1 小时前
深度观察:跨越“存起来”的误区,智造时代如何重构工业数据底座?
大数据·人工智能·python·重构