自定义zk节点名出错

在部署Canal时遇到错误,由于Zookeeper路径长度限制,导致启动失败。错误信息显示Path length must be > 0。经调查,问题在于Zookeeper未自动创建/canal节点。解决方案是手动登录到Zookeeper服务器,使用zkCli.sh创建节点create /canal id,其中id参数不可省略。完成节点创建后,重新启动服务,问题得到解决。

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没有帮我们自动创建节点导致的,所以可以通过认为添加节点解决这个问题

  1. 登录到zk主机并找到zk的bin目录
  2. 输入命令./zkCli.sh
  3. 创建节点 create /canal id({id} (id({id}这个参数必须有,否则创建节点会失败,但值可以任意)
  4. 重启服务
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值