百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 编程字典 > 正文

canal同步elasticsearch实战(六)

toyiye 2024-06-27 00:39 17 浏览 0 评论

disruptor初始化类

disruptor的初始化和相关组件使用都是固定的套路:消息体-时间-事件工厂-生产者方法-消费者-启动-关闭。

canal同步elasticsearch实战只是抛砖引玉,为大家提供一种实现思路和架构设计方案,难免有不足之处,请大家谅解。大家可以根据自己的实际情况做一下扩展:

  • 实现数据的串并联及WorkerPool处理,只需要对disruptor.handleEvents进行改造即可

disruptor.handleEventsWith().then().thenHandleEventsWithWorkerPool()

  • 分库分表,比如一个库一个disruptor,一个库的表比较多时可以再对表进行分组使用不同的disruptor处理,这样我们可以有效隔离不同库的数据处理,同时也可以对热点表分配更多的资源,提高其处理效能。
  • disruptor是线程级的,无持久化,没有监控API,没有宕掉后的自动恢复机制,也不能被其他程序访问,因此disruptor的使用成本还是非常高的,大家必须有心理准备。
import com.google.common.util.concurrent.ThreadFactoryBuilder;
import com.google.gson.GsonBuilder;
import com.lmax.disruptor.*;
import com.lmax.disruptor.dsl.Disruptor;
import com.lmax.disruptor.dsl.ProducerType;
import com.mol.elastic.base.AbstractSyncHandler;
import com.mol.elastic.base.HandlerFactory;
import com.mol.elastic.entity.InnerBinlogEntry;
import lombok.Builder;
import lombok.Data;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.beans.factory.DisposableBean;
import org.springframework.beans.factory.InitializingBean;
import org.springframework.stereotype.Component;

import java.util.ArrayList;
import java.util.Collections;
import java.util.List;
import java.util.concurrent.ThreadFactory;

@Component
public class messageEventQueueHelper implements InitializingBean, DisposableBean {

    /**
     * Disruptor 对象
     */
    private Disruptor<MessageEvent> disruptor;
    /**
     * RingBuffer线程安全无锁
     */
    private RingBuffer<MessageEvent> ringBuffer;

    /**
     * initQueue
     */
    private List<MessageModel> initQueue = Collections.synchronizedList(new ArrayList<>());

    /**
     * 初始化
     */
    public void init() {
        ThreadFactory namedThreadFactory = new ThreadFactoryBuilder().setNameFormat("DisruptorThreadPool").build();
        //RingBuffer生产工厂,初始化RingBuffer的时候使用
        EventFactory<MessageEvent> factory = () -> new MessageEvent();
        //单线程模式,获取额外的性能
        disruptor = new Disruptor<>(factory, 1024, namedThreadFactory, ProducerType.SINGLE, new YieldingWaitStrategy());
        disruptor.setDefaultExceptionHandler(new MyHandlerException<>());
        disruptor.handleEventsWith(new MessageHandler());
        ringBuffer = disruptor.start();
        //初始化数据发布,如果某个请求的sequence未被提交将会堵塞后续的发布操作或者其他的producer
        for (MessageModel data : initQueue) {
            ringBuffer.publishEvent((event, sequence, result) -> event.setMessageModel(result), data);
        }
    }

    /**
     * 插入队列消息,支持在对象init前插入队列,则在队列建立时立即发布到队列处理.
     */
    public void publishEvent(MessageModel data) {
        if (ringBuffer == null) {
            initQueue.add(data);
            return;
        }
        ringBuffer.publishEvent((event, sequence, result) -> event.setMessageModel(result), data);
    }

    @Override
    public void destroy() throws Exception {
        disruptor.shutdown();//关闭 disruptor,方法会堵塞,直至所有的事件都得到处理。
    }

    @Override
    public void afterPropertiesSet() throws Exception {
        init();
    }

    /**
     * 消息体,通过JSON数据传输
     */
    @Data
    @Builder
    public class MessageModel {
        private String message;
    }

    /**
     * 创建事件
     */
    @Data
    public class MessageEvent {
        private MessageModel messageModel;
    }

    /**
     * 创建消费者
     */
    public class MessageHandler implements EventHandler<MessageEvent> {

        @Override
        public void onEvent(MessageEvent event, long sequence, boolean endOfBatch) throws Exception {
            //具体消费逻辑
            InnerBinlogEntry innerBinlogEntry = new GsonBuilder().create().fromJson(event.getMessageModel().getMessage(), InnerBinlogEntry.class);
            AbstractSyncHandler handler = HandlerFactory.getHandlerResponsibilityChain();
            handler.handleSync(innerBinlogEntry);
        }
    }

    // 异常处理类
    protected class MyHandlerException<T> implements ExceptionHandler<T> {

        private Logger logger = LoggerFactory.getLogger(MyHandlerException.class);

        @Override
        public void handleEventException(Throwable ex, long sequence, T event) {
            ex.printStackTrace();
            logger.error("process data error sequence ==[{}] event==[{}] ,ex ==[{}]", sequence, event.toString(), ex.getMessage());
        }
        @Override
        public void handleOnStartException(Throwable ex) {
            logger.error("start disruptor error ==[{}]!", ex.getMessage());
        }
        @Override
        public void handleOnShutdownException(Throwable ex) {
            logger.error("shutdown disruptor error ==[{}]!", ex.getMessage());
        }
    }

}

canal同步elasticsearch实战(一)

canal同步elasticsearch实战(二)

canal同步elasticsearch实战(三)

canal同步elasticsearch实战(四)

canal同步elasticsearch实战(五)

相关推荐

为何越来越多的编程语言使用JSON(为什么编程)

JSON是JavascriptObjectNotation的缩写,意思是Javascript对象表示法,是一种易于人类阅读和对编程友好的文本数据传递方法,是JavaScript语言规范定义的一个子...

何时在数据库中使用 JSON(数据库用json格式存储)

在本文中,您将了解何时应考虑将JSON数据类型添加到表中以及何时应避免使用它们。每天?分享?最新?软件?开发?,Devops,敏捷?,测试?以及?项目?管理?最新?,最热门?的?文章?,每天?花?...

MySQL 从零开始:05 数据类型(mysql数据类型有哪些,并举例)

前面的讲解中已经接触到了表的创建,表的创建是对字段的声明,比如:上述语句声明了字段的名称、类型、所占空间、默认值和是否可以为空等信息。其中的int、varchar、char和decimal都...

JSON对象花样进阶(json格式对象)

一、引言在现代Web开发中,JSON(JavaScriptObjectNotation)已经成为数据交换的标准格式。无论是从前端向后端发送数据,还是从后端接收数据,JSON都是不可或缺的一部分。...

深入理解 JSON 和 Form-data(json和formdata提交区别)

在讨论现代网络开发与API设计的语境下,理解客户端和服务器间如何有效且可靠地交换数据变得尤为关键。这里,特别值得关注的是两种主流数据格式:...

JSON 语法(json 语法 priority)

JSON语法是JavaScript语法的子集。JSON语法规则JSON语法是JavaScript对象表示法语法的子集。数据在名称/值对中数据由逗号分隔花括号保存对象方括号保存数组JS...

JSON语法详解(json的语法规则)

JSON语法规则JSON语法是JavaScript对象表示法语法的子集。数据在名称/值对中数据由逗号分隔大括号保存对象中括号保存数组注意:json的key是字符串,且必须是双引号,不能是单引号...

MySQL JSON数据类型操作(mysql的json)

概述mysql自5.7.8版本开始,就支持了json结构的数据存储和查询,这表明了mysql也在不断的学习和增加nosql数据库的有点。但mysql毕竟是关系型数据库,在处理json这种非结构化的数据...

JSON的数据模式(json数据格式示例)

像XML模式一样,JSON数据格式也有Schema,这是一个基于JSON格式的规范。JSON模式也以JSON格式编写。它用于验证JSON数据。JSON模式示例以下代码显示了基本的JSON模式。{"...

前端学习——JSON格式详解(后端json格式)

JSON(JavaScriptObjectNotation)是一种轻量级的数据交换格式。易于人阅读和编写。同时也易于机器解析和生成。它基于JavaScriptProgrammingLa...

什么是 JSON:详解 JSON 及其优势(什么叫json)

现在程序员还有谁不知道JSON吗?无论对于前端还是后端,JSON都是一种常见的数据格式。那么JSON到底是什么呢?JSON的定义...

PostgreSQL JSON 类型:处理结构化数据

PostgreSQL提供JSON类型,以存储结构化数据。JSON是一种开放的数据格式,可用于存储各种类型的值。什么是JSON类型?JSON类型表示JSON(JavaScriptO...

JavaScript:JSON、三种包装类(javascript 包)

JOSN:我们希望可以将一个对象在不同的语言中进行传递,以达到通信的目的,最佳方式就是将一个对象转换为字符串的形式JSON(JavaScriptObjectNotation)-JS的对象表示法...

Python数据分析 只要1分钟 教你玩转JSON 全程干货

Json简介:Json,全名JavaScriptObjectNotation,JSON(JavaScriptObjectNotation(记号、标记))是一种轻量级的数据交换格式。它基于J...

比较一下JSON与XML两种数据格式?(json和xml哪个好)

JSON(JavaScriptObjectNotation)和XML(eXtensibleMarkupLanguage)是在日常开发中比较常用的两种数据格式,它们主要的作用就是用来进行数据的传...

取消回复欢迎 发表评论:

请填写验证码