当前位置: 首页>>代码示例>>Java>>正文


Java CanalException类代码示例

本文整理汇总了Java中com.alibaba.otter.canal.common.CanalException的典型用法代码示例。如果您正苦于以下问题:Java CanalException类的具体用法?Java CanalException怎么用?Java CanalException使用的例子?那么, 这里精选的类代码示例或许可以为您提供帮助。


CanalException类属于com.alibaba.otter.canal.common包,在下文中一共展示了CanalException类的8个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的Java代码示例。

示例1: initMetaManager

import com.alibaba.otter.canal.common.CanalException; //导入依赖的package包/类
protected void initMetaManager() {
    logger.info("init metaManager begin...");
    MetaMode mode = parameters.getMetaMode();
    if (mode.isMemory()) {
        metaManager = new MemoryMetaManager();
    } else if (mode.isZookeeper()) {
        metaManager = new ZooKeeperMetaManager();
        ((ZooKeeperMetaManager) metaManager).setZkClientx(getZkclientx());
    } else if (mode.isMixed()) {
        // metaManager = new MixedMetaManager();
        metaManager = new PeriodMixedMetaManager();// 换用优化过的mixed, at
                                                   // 2012-09-11
        // 设置内嵌的zk metaManager
        ZooKeeperMetaManager zooKeeperMetaManager = new ZooKeeperMetaManager();
        zooKeeperMetaManager.setZkClientx(getZkclientx());
        ((PeriodMixedMetaManager) metaManager).setZooKeeperMetaManager(zooKeeperMetaManager);
    } else {
        throw new CanalException("unsupport MetaMode for " + mode);
    }

    logger.info("init metaManager end! \n\t load CanalMetaManager:{} ", metaManager.getClass().getName());
}
 
开发者ID:alibaba,项目名称:canal,代码行数:23,代码来源:CanalInstanceWithManager.java

示例2: createFrom

import com.alibaba.otter.canal.common.CanalException; //导入依赖的package包/类
public static AuthenticationInfo createFrom(DatasourceInfo datasourceInfo) {
    AuthenticationInfo authenticationInfo = new AuthenticationInfo();
    try {
        BeanUtils.copyProperties(authenticationInfo, datasourceInfo);
    } catch (Exception e) {
        throw new CanalException(e);
    }
    return authenticationInfo;
}
 
开发者ID:luoyaogui,项目名称:otter-G,代码行数:10,代码来源:AuthenticationInfoUtils.java

示例3: findCanal

import com.alibaba.otter.canal.common.CanalException; //导入依赖的package包/类
/**
 * 根据对应的destinantion查询Canal信息
 */
public Canal findCanal(String destination) {
    FindCanalEvent event = new FindCanalEvent();
    event.setDestination(destination);
    try {
        Object obj = delegate.callManager(event);
        if (obj != null && obj instanceof Canal) {
            return (Canal) obj;
        } else {
            throw new CanalException("No Such Canal by [" + destination + "]");
        }
    } catch (Exception e) {
        throw new CanalException("call_manager_error", e);
    }
}
 
开发者ID:luoyaogui,项目名称:otter-G,代码行数:18,代码来源:CanalConfigClient.java

示例4: findFilter

import com.alibaba.otter.canal.common.CanalException; //导入依赖的package包/类
/**
 * 根据对应的destinantion查询filter信息
 */
public String findFilter(String destination) {
    FindFilterEvent event = new FindFilterEvent();
    event.setDestination(destination);
    try {
        Object obj = delegate.callManager(event);
        if (obj != null && obj instanceof String) {
            return (String) obj;
        } else {
            throw new CanalException("No Such Canal by [" + destination + "]");
        }
    } catch (Exception e) {
        throw new CanalException("call_manager_error", e);
    }
}
 
开发者ID:luoyaogui,项目名称:otter-G,代码行数:18,代码来源:CanalConfigClient.java

示例5: initEventStore

import com.alibaba.otter.canal.common.CanalException; //导入依赖的package包/类
protected void initEventStore() {
    logger.info("init eventStore begin...");
    StorageMode mode = parameters.getStorageMode();
    if (mode.isMemory()) {
        MemoryEventStoreWithBuffer memoryEventStore = new MemoryEventStoreWithBuffer();
        memoryEventStore.setBufferSize(parameters.getMemoryStorageBufferSize());
        memoryEventStore.setBufferMemUnit(parameters.getMemoryStorageBufferMemUnit());
        memoryEventStore.setBatchMode(BatchMode.valueOf(parameters.getStorageBatchMode().name()));
        memoryEventStore.setDdlIsolation(parameters.getDdlIsolation());
        eventStore = memoryEventStore;
    } else if (mode.isFile()) {
        // 后续版本支持
        throw new CanalException("unsupport MetaMode for " + mode);
    } else if (mode.isMixed()) {
        // 后续版本支持
        throw new CanalException("unsupport MetaMode for " + mode);
    } else {
        throw new CanalException("unsupport MetaMode for " + mode);
    }

    if (eventStore instanceof AbstractCanalStoreScavenge) {
        StorageScavengeMode scavengeMode = parameters.getStorageScavengeMode();
        AbstractCanalStoreScavenge eventScavengeStore = (AbstractCanalStoreScavenge) eventStore;
        eventScavengeStore.setDestination(destination);
        eventScavengeStore.setCanalMetaManager(metaManager);
        eventScavengeStore.setOnAck(scavengeMode.isOnAck());
        eventScavengeStore.setOnFull(scavengeMode.isOnFull());
        eventScavengeStore.setOnSchedule(scavengeMode.isOnSchedule());
        if (scavengeMode.isOnSchedule()) {
            eventScavengeStore.setScavengeSchedule(parameters.getScavengeSchdule());
        }
    }
    logger.info("init eventStore end! \n\t load CanalEventStore:{}", eventStore.getClass().getName());
}
 
开发者ID:alibaba,项目名称:canal,代码行数:35,代码来源:CanalInstanceWithManager.java

示例6: initEventParser

import com.alibaba.otter.canal.common.CanalException; //导入依赖的package包/类
protected void initEventParser() {
    logger.info("init eventParser begin...");
    SourcingType type = parameters.getSourcingType();

    List<List<DataSourcing>> groupDbAddresses = parameters.getGroupDbAddresses();
    if (!CollectionUtils.isEmpty(groupDbAddresses)) {
        int size = groupDbAddresses.get(0).size();// 取第一个分组的数量,主备分组的数量必须一致
        List<CanalEventParser> eventParsers = new ArrayList<CanalEventParser>();
        for (int i = 0; i < size; i++) {
            List<InetSocketAddress> dbAddress = new ArrayList<InetSocketAddress>();
            SourcingType lastType = null;
            for (List<DataSourcing> groupDbAddress : groupDbAddresses) {
                if (lastType != null && !lastType.equals(groupDbAddress.get(i).getType())) {
                    throw new CanalException(String.format("master/slave Sourcing type is unmatch. %s vs %s",
                        lastType,
                        groupDbAddress.get(i).getType()));
                }

                lastType = groupDbAddress.get(i).getType();
                dbAddress.add(groupDbAddress.get(i).getDbAddress());
            }

            // 初始化其中的一个分组parser
            eventParsers.add(doInitEventParser(lastType, dbAddress));
        }

        if (eventParsers.size() > 1) { // 如果存在分组,构造分组的parser
            GroupEventParser groupEventParser = new GroupEventParser();
            groupEventParser.setEventParsers(eventParsers);
            this.eventParser = groupEventParser;
        } else {
            this.eventParser = eventParsers.get(0);
        }
    } else {
        // 创建一个空数据库地址的parser,可能使用了tddl指定地址,启动的时候才会从tddl获取地址
        this.eventParser = doInitEventParser(type, new ArrayList<InetSocketAddress>());
    }

    logger.info("init eventParser end! \n\t load CanalEventParser:{}", eventParser.getClass().getName());
}
 
开发者ID:alibaba,项目名称:canal,代码行数:41,代码来源:CanalInstanceWithManager.java

示例7: initHaController

import com.alibaba.otter.canal.common.CanalException; //导入依赖的package包/类
protected CanalHAController initHaController() {
    logger.info("init haController begin...");
    HAMode haMode = parameters.getHaMode();
    CanalHAController haController = null;
    if (haMode.isHeartBeat()) {
        haController = new HeartBeatHAController();
        ((HeartBeatHAController) haController).setDetectingRetryTimes(parameters.getDetectingRetryTimes());
        ((HeartBeatHAController) haController).setSwitchEnable(parameters.getHeartbeatHaEnable());
    } else {
        throw new CanalException("unsupport HAMode for " + haMode);
    }
    logger.info("init haController end! \n\t load CanalHAController:{}", haController.getClass().getName());

    return haController;
}
 
开发者ID:alibaba,项目名称:canal,代码行数:16,代码来源:CanalInstanceWithManager.java

示例8: initLogPositionManager

import com.alibaba.otter.canal.common.CanalException; //导入依赖的package包/类
protected CanalLogPositionManager initLogPositionManager() {
    logger.info("init logPositionPersistManager begin...");
    IndexMode indexMode = parameters.getIndexMode();
    CanalLogPositionManager logPositionManager;
    if (indexMode.isMemory()) {
        logPositionManager = new MemoryLogPositionManager();
    } else if (indexMode.isZookeeper()) {
        logPositionManager = new ZooKeeperLogPositionManager(getZkclientx());
    } else if (indexMode.isMixed()) {
        MemoryLogPositionManager memoryLogPositionManager = new MemoryLogPositionManager();
        ZooKeeperLogPositionManager zooKeeperLogPositionManager = new ZooKeeperLogPositionManager(getZkclientx());
        logPositionManager = new PeriodMixedLogPositionManager(memoryLogPositionManager,
            zooKeeperLogPositionManager,
            1000L);
    } else if (indexMode.isMeta()) {
        logPositionManager = new MetaLogPositionManager(metaManager);
    } else if (indexMode.isMemoryMetaFailback()) {
        MemoryLogPositionManager primary = new MemoryLogPositionManager();
        MetaLogPositionManager secondary = new MetaLogPositionManager(metaManager);

        logPositionManager = new FailbackLogPositionManager(primary, secondary);
    } else {
        throw new CanalException("unsupport indexMode for " + indexMode);
    }

    logger.info("init logPositionManager end! \n\t load CanalLogPositionManager:{}", logPositionManager.getClass()
        .getName());

    return logPositionManager;
}
 
开发者ID:alibaba,项目名称:canal,代码行数:31,代码来源:CanalInstanceWithManager.java


注:本文中的com.alibaba.otter.canal.common.CanalException类示例由纯净天空整理自Github/MSDocs等开源代码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。