| | |
| | | import java.util.*;
|
| | |
|
| | | /**
|
| | | * DML 数据拉取、解析
|
| | | * @author wuqiong 2022/4/11
|
| | | * @description
|
| | | */
|
| | | public class DmlMessageTransponderContainer extends AbstractCanalTransponderContainer {
|
| | |
|
| | |
| | |
|
| | | }
|
| | |
|
| | | public void disconnect(){
|
| | | // 关闭连接
|
| | | connector.disconnect();
|
| | | }
|
| | |
|
| | |
|
| | | public void doStart() {
|
| | | Message message = null;
|
| | |
| | | "thread interrupt , current connector host: {} , port: {} ",
|
| | | endpointInstance.getHost(), endpointInstance.getPort());
|
| | | Thread.currentThread().interrupt();
|
| | | disconnect();
|
| | | } else {
|
| | | sleep(endpointInstance.getAcquireInterval());
|
| | | }
|
| | |
| | | sleep(endpointInstance.getAcquireInterval());
|
| | | return;
|
| | | }
|
| | | try {
|
| | | entries.forEach(e -> consumer(e));
|
| | | } catch (Exception e) {
|
| | | e.printStackTrace();
|
| | | logger.error("[MessageTransponderContainer_doStart] CanalEntry.Entry consumer error ", e);
|
| | | // connector.rollback(message.getId()); // 目前先不处理失败, 无需回滚数据
|
| | | // return;
|
| | | for (CanalEntry.Entry entry : entries) {
|
| | | try {
|
| | | consumer(entry);
|
| | | } catch (Exception e) {
|
| | | e.printStackTrace();
|
| | | logger.error("[MessageTransponderContainer_doStart] CanalEntry.Entry consumer error ", e);
|
| | | // connector.rollback(message.getId()); // 目前先不处理失败, 无需回滚数据
|
| | | // return;
|
| | | }
|
| | | }
|
| | | connector.ack(message.getId()); // 提交确认
|
| | | }
|