canal 定制化zk节点名称报错
当多个项目应用同一个zk cluster的时候,为了各个项目在zk中的目录更加易于分辨,我们可能会对其进行定制化
eg:
/zookeeper
/kafka
/cluster
/canal
/otter
正常情况下我们应该通过改变canal.peoperties中的配置
zkServers = localhost:2181/canal
来指定,但我在部署的过程中,遇到如下的error
2019-04-06 22:12:12.184 [main] INFO com.alibaba.otter.canal.deployer.CanalStater - ## start the canal server.
2019-04-06 22:12:12.359 [main] ERROR com.alibaba.otter.canal.deployer.CanalLauncher - ## Something goes wrong when starting up the canal Server:
java.lang.IllegalArgumentException: Path length must be > 0
at org.apache.zookeeper.common.PathUtils.validatePath(PathUtils.java:48) ~[zookeeper-3.4.5.jar:3.4.5-1392090]
at org.apache.zookeeper.common.PathUtils.validatePath(PathUtils.java:35) ~[zookeeper-3.4.5.jar:3.4.5-1392090]
at org.apache.zookeeper.ZooKeeper.create(ZooKeeper.java:766) ~[zookeeper-3.4.5.jar:3.4.5-1392090]
at org.I0Itec.zkclient.ZkConnection.create(ZkConnection.java:100) ~[zkclient-0.10.jar:na]
at org.I0Itec.zkclient.ZkClient$3.call(ZkClient.java:531) ~[zkclient-0.10.jar:na]
at org.I0Itec.zkclient.ZkClient$3.call(ZkClient.java:528) ~[zkclient-0.10.jar:na]
at org.I0Itec.zkclient.ZkClient.retryUntilConnected(ZkClient.java:991) ~[zkclient-0.10.jar:na]
at org.I0Itec.zkclient.ZkClient.create(ZkClient.java:528) ~[zkclient-0.10.jar:na]
at org.I0Itec.zkclient.ZkClient.createPersistent(ZkClient.java:294) ~[zkclient-0.10.jar:na]
at org.I0Itec.zkclient.ZkClient.createPersistent(ZkClient.java:304) ~[zkclient-0.10.jar:na]
at org.I0Itec.zkclient.ZkClient.createPersistent(ZkClient.java:304) ~[zkclient-0.10.jar:na]
通过查找相关资料,发现是由于zk没有帮我们自动创建节点导致的,所以可以通过认为添加节点解决这个问题
- 登录到zk主机并找到zk的bin目录
- 输入命令./zkCli.sh
- 创建节点 create /canal id({id} (id({id}这个参数必须有,否则创建节点会失败,但值可以任意)
- 重启服务
在部署Canal时遇到错误,由于Zookeeper路径长度限制,导致启动失败。错误信息显示Path length must be > 0。经调查,问题在于Zookeeper未自动创建/canal节点。解决方案是手动登录到Zookeeper服务器,使用zkCli.sh创建节点create /canal id,其中id参数不可省略。完成节点创建后,重新启动服务,问题得到解决。
3872

被折叠的 条评论
为什么被折叠?



