解决zookeeper报错:java.net.BindException: 地址已在使用,是因为端口被占用。显示Starting zookeeper ... STARTED,jps没有QuorumPeerMain进程。
问题截图:
看似Starting zookeeper ... STARTED,实则集群并没有启动起来。从jps没有QuorumPeerMain进程就能够看出来。
data:image/s3,"s3://crabby-images/cabe6/cabe624029b8b08bc926ff30af3f0bff087648f3" alt=""
data:image/s3,"s3://crabby-images/86abb/86abb6ef3cbba2e5bbe76340c036daaa872ca12b" alt=""
[main:NIOServerCnxnFactory@89] - 绑定到端口 0.0.0.0/0.0.0.0:2181 2023-11-09 21:05:49,443 [myid:2] - ERROR [main:QuorumPeerMain@89] - 发生意外异常,异常退出 java.net.BindException: 地址已在使用
这里我们通过打开zookeeper.out文件可以看到"2181"端口被占用。
解决方法:
第一步:拿到进程号
data:image/s3,"s3://crabby-images/0b994/0b994403506675b86247a10543a9c29587523e77" alt=""
python
sudo netstat -nltp | grep 2181
第二步:杀掉该进程
python
sudo kill -9 4988
不同人的号码不一样,请大家执行第一步。
第三步:重启zookeeper
data:image/s3,"s3://crabby-images/17ca3/17ca304b4d8150a53031306afecb198f9f64b794" alt=""
data:image/s3,"s3://crabby-images/c5a7b/c5a7b7d0368a4d2d0a7e634f2d88d92303f96be3" alt=""
效果展示:
QuorumPeerMain终于出现了。成功!
data:image/s3,"s3://crabby-images/3686a/3686a2fb0c090d20710d5c4cbb1063b02e274309" alt=""