zookeeper:Unexpected exception, exiting abnormally ::java.io.EOFException

转载请注明出处:

服务器中断,重启服务器在重启kafka服务时,遇到如下报错:

复制代码
2024-06-05 13:52:56,251 [myid:] - ERROR [main:ZooKeeperServerMain@64] - Unexpected exception, exiting abnormally
java.io.EOFException
   at java.io.DataInputStream.readInt(DataInputStream.java:392)
   at org.apache.jute.BinaryInputArchive.readInt(BinaryInputArchive.java:63)
   at org.apache.zookeeper.server.persistence.FileHeader.deserialize(FileHeader.java:64)
   at org.apache.zookeeper.server.persistence.FileTxnLog$FileTxnIterator.inStreamCreated(FileTxnLog.java:585)
   at org.apache.zookeeper.server.persistence.FileTxnLog$FileTxnIterator.createInputArchive(FileTxnLog.java:604)
   at org.apache.zookeeper.server.persistence.FileTxnLog$FileTxnIterator.goToNextLog(FileTxnLog.java:570)
   at org.apache.zookeeper.server.persistence.FileTxnLog$FileTxnIterator.next(FileTxnLog.java:652)
   at org.apache.zookeeper.server.persistence.FileTxnSnapLog.restore(FileTxnSnapLog.java:158)
   at org.apache.zookeeper.server.ZKDatabase.loadDataBase(ZKDatabase.java:223)
   at org.apache.zookeeper.server.ZooKeeperServer.loadData(ZooKeeperServer.java:283)
   at org.apache.zookeeper.server.ZooKeeperServer.startdata(ZooKeeperServer.java:410)
   at org.apache.zookeeper.server.NIOServerCnxnFactory.startup(NIOServerCnxnFactory.java:118)
   at org.apache.zookeeper.server.ZooKeeperServerMain.runFromConfig(ZooKeeperServerMain.java:119)
   at org.apache.zookeeper.server.ZooKeeperServerMain.initializeAndRun(ZooKeeperServerMain.java:87)
   at org.apache.zookeeper.server.ZooKeeperServerMain.main(ZooKeeperServerMain.java:53)
   at org.apache.zookeeper.server.quorum.QuorumPeerMain.initializeAndRun(QuorumPeerMain.java:116)
   at org.apache.zookeeper.server.quorum.QuorumPeerMain.main(QuorumPeerMain.java:78)
ZooKeeper JMX enabled by default

解决方案

  1. 从备份恢复:如果您有最近的ZooKeeper数据目录的备份,从这个备份恢复将是解决问题最快的方式。确保备份是在ZooKeeper服务器正常运行时的状态。
  2. 手动恢复日志:
    • 如果ZooKeeper服务器仍在运行,请先停止它。
    • 定位包含datadatalog目录的ZooKeeper数据目录。
    • 导航到datalog目录并识别出问题的日志文件(例如,log.0snap.0000000000)。
    • 您可能需要手动编辑或删除这些文件以清除损坏。请谨慎操作,并在进行之前确保您有备份。
  • 清除损坏文件后,重新启动ZooKeeper服务器。
  1. 检查磁盘空间:确保磁盘有足够的空间,不是满的或几乎满的。磁盘空间不足有时可以表现为文件操作期间出现EOFException。
  2. 检查ZooKeeper版本兼容性:如果您最近升级了ZooKeeper,请确保集群中的所有节点都运行的是兼容版本。版本不匹配可能导致序列化/反序列化问题。
  3. 启用调试日志:为了获得更多关于问题的洞察,考虑为ZooKeeper启用调试日志。这可以提供更详细的故障机制信息。在ZooKeeper配置文件(zoo.cfg)中设置日志级别为DEBUG,并查看日志以获取更多线索。

解决方式:

将zookeeper 存放 data和datalog的目录进行重命名之后,再重启kafka,服务得以正常启动。

相关推荐
亿.61 分钟前
【Java安全】RMI基础
java·安全·ctf·rmi
ruan11451416 分钟前
Java Lambda 类型推断详解:filter() 方法与 Predicate<? super T>
java·开发语言·spring·stream
朱杰jjj18 分钟前
解决jenkins的Exec command命令nohup java -jar不启动问题
java·jenkins·jar
上上迁31 分钟前
分布式接口幂等性的演进和最佳实践,含springBoot 实现(Java版本)
java·spring boot·分布式
匚WYHaovous31 分钟前
Java断言的深度解析与实战指南
java
WanderInk44 分钟前
揭秘Java协变返回类型:让你的API少一点强转,多一点优雅
java·后端
paopaokaka_luck1 小时前
基于SpringBoot+Vue的非遗文化传承管理系统(websocket即时通讯、协同过滤算法、支付宝沙盒支付、可分享链接、功能量非常大)
java·数据库·vue.js·spring boot·后端·spring·小程序
iteye_99391 小时前
让 3 个线程串行的几种方式
java·linux
YuTaoShao1 小时前
【LeetCode 热题 100】142. 环形链表 II——快慢指针
java·算法·leetcode·链表
找不到、了2 小时前
分布式理论:CAP、Base理论
java·分布式