canal adapter支持Elasticsearch 5.X版本配置

会有一股神秘感。 提交于 2019-12-09 05:53:09

日常踩坑,现在公司使用的ES还是5.3.3版本,但是canal目前只支持6.X以上版本,canal是这么建议的:

canal adapter 的 Elastic Search 版本支持6.x.x以上, 如需其它版本的es可替换依赖重新编译client-adapter.elasticsearch模块

一般人理解似乎只需要改动依赖版本然后打包就O了,但是启动会报错,后面定位是transportAddress的问题,改动如下:

  1. 先将elasticsearch下的pom文件中依赖的elasticsearch相关组件的版本号降至5.X
<dependency>
        <groupId>org.elasticsearch</groupId>
        <artifactId>elasticsearch</artifactId>
        <version>5.3.3</version>
    </dependency>
    <dependency>
        <groupId>org.elasticsearch.client</groupId>
        <artifactId>transport</artifactId>
        <version>5.3.3</version>
    </dependency>
  1. com.alibaba.otter.canal.client.adapter.es.ESAdapter类中
transportClient.addTransportAddress(new TransportAddress(InetAddress.getByName(host.substring(0, i)),
Integer.parseInt(host.substring(i + 1))));

修改成以下:

transportClient.addTransportAddress(new InetSocketTransportAddress(InetAddress.getByName(host.substring(0, i)),
                       Integer.parseInt(host.substring(i + 1))));

即把TransportAddress替换成InetSocketTransportAddress
不要忘记把InetSocketTransportAddress import进来

  1. 重新编译打包
mvn clean install -Dmaven.test.skip -Denv=release
易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!