es索引同步

通过向索引中添加文章信息最终实现了课 程的搜索,我们发现文章信息是先保存在关系数据库中,而后再写入索引,这个过程是将关系数据中的数据同步到elasticsearch索引中的过程,可以简单成为索引同步。

通常项目中使用elasticsearch需要完成索引同步,索引同步的方法很多:

1、针对实时性非常高的场景需要满足数据的及时同步,可以同步调用,或使用Canal去实现。

1)同步调用即在向MySQL写数据后远程调用搜索服务的接口写入索引,此方法简单但是耦合代码太高。

2)可以使用一个中间的软件canal解决耦合性的问题,但存在学习与维护成本。

canal主要用途是基于 MySQL 数据库增量日志解析,并能提供增量数据订阅和消费,实现将MySQL的数据同步到消息队列、Elasticsearch、其它数据库等,应用场景十分丰富。

2、当索引同步的实时性要求不高时可用的技术比较多,比如:MQ、Logstash、任务调度等。

MQ:向mysql写数据的时候向mq写入消息,搜索服务监听MQ,收到消息后写入索引。使用MQ的优势是代码解耦,但是需要处理消息可靠性的问题有一定的技术成本,做到消息可靠性需要做到生产者投递成功、消息持久化以及消费者消费成功三个方面,另外还要做好消息幂等性问题。

Logstash: 开源实时日志分析平台 ELK包括Elasticsearch、Kibana、Logstash,Logstash负责收集、解析和转换日志信息,可以实现MySQL与Elasticsearch之间的数据同步。也可以实现解耦合并且是官方推荐,但需要增加学习与维护成本。

任务调度:向mysql写数据的时候记录修改记录,开启一个定时任务根据修改记录将数据同步到Elasticsearch。

因为我这个是个人博客系统,所以对数据同步的实时性要求不高,因此使用任务调度实现索引同步。

为了避免重复索引已经存在且未更新的数据,可以使用增量同步策略,仅同步新增和更新的数据,同时删除已经被标记删除的数据。

java 复制代码
@Component
@Slf4j
public class AddArticleIndexJob {

    @Resource
    private ArticleService articleService;

    @Resource
    private IndexService indexService;


    @Value("${elasticsearch.article.index}")
    private String indexName;

    private Date lastSyncTime = new Date(0); // 初始化为1970年1月1日

    /**
     * 每隔10分钟同步一次
     */
    @Scheduled(cron = "0 0/10 * * * ?")
    public void exec() {
        Date currentSyncTime = new Date(); // 当前同步的时间
        try {
            List<Article> articles = articleService.findByUpdatedAtAfter(lastSyncTime);
            for (Article article: articles) {
                if (article.getDelFlag() == 1) {
                    Boolean success = indexService.deleteArticleIndex(indexName, String.valueOf(article.getId()));
                    if (success) {
                        log.info("删除索引成功");
                    }
                }else {
                    Boolean success = indexService.addArticleIndex(indexName, String.valueOf(article.getId()), article);
                    if (success) {
                        log.info("新增文章索引成功");
                    }
                }
            }
            lastSyncTime = currentSyncTime;
        }catch (Exception e) {
            log.error("索引失效,请检查");
        }
    }
}
相关推荐
PS1232327 分钟前
城市安全建设中的风环境监测解决方案
大数据·人工智能
学习中的阿陈11 分钟前
flume安装
大数据·flume
路边草随风14 分钟前
java 实现 flink cdc 读 mysql binlog 按表写入kafka不同topic
java·大数据·mysql·flink
007php00715 分钟前
Elasticsearch经典面试题案例分析
redis·elasticsearch·搜索引擎·面试·职场和发展·全文检索·jenkins
safestar201220 分钟前
Elasticsearch与SelectDB的正面对决:日志分析场景的架构深度调优与选型指南
大数据·elasticsearch·架构
老蒋新思维1 小时前
创客匠人峰会复盘:AI 时代知识变现,从流量思维到共识驱动的系统重构
大数据·人工智能·tcp/ip·重构·创始人ip·创客匠人·知识变现
东哥说-MES|从入门到精通9 小时前
GenAI-生成式人工智能在工业制造中的应用
大数据·人工智能·智能制造·数字化·数字化转型·mes
万岳软件开发小城9 小时前
教育APP/小程序开发标准版图:课程、题库、直播、学习一站式梳理
大数据·php·uniapp·在线教育系统源码·教育app开发·教育软件开发
STLearner11 小时前
AI论文速读 | U-Cast:学习高维时间序列预测的层次结构
大数据·论文阅读·人工智能·深度学习·学习·机器学习·数据挖掘
数字化顾问11 小时前
(65页PPT)大型集团物料主数据管理系统建设规划方案(附下载方式)
大数据·运维·人工智能