Kafka常见问题之 java.io.IOException: Disk error when trying to write to log

文章目录

  • [Kafka常见问题之 java.io.IOException: Disk error when trying to write to log](#Kafka常见问题之 java.io.IOException: Disk error when trying to write to log)
  • [1. 问题概述](#1. 问题概述)
  • [2. 问题排查方向](#2. 问题排查方向)
    • (1)磁盘空间不足
    • [(2)磁盘 I/O 故障](#(2)磁盘 I/O 故障)
    • [(3)Kafka 日志文件损坏](#(3)Kafka 日志文件损坏)
    • [(4)Kafka 进程权限不足](#(4)Kafka 进程权限不足)
    • [(5)Kafka 配置错误](#(5)Kafka 配置错误)
  • [3. 案例分析](#3. 案例分析)
    • [案例 1:磁盘满导致 Kafka 崩溃](#案例 1:磁盘满导致 Kafka 崩溃)
    • [案例 2:磁盘 I/O 过载导致 Kafka 失败](#案例 2:磁盘 I/O 过载导致 Kafka 失败)
    • [案例 3:Kafka 无法写入日志](#案例 3:Kafka 无法写入日志)

Kafka常见问题之 java.io.IOException: Disk error when trying to write to log

1. 问题概述

在 Kafka Broker 运行时,可能会遇到以下错误:

java.io.IOException: Disk error when trying to write to log
	at org.apache.kafka.common.errors.KafkaStorageException

这个错误表明 Kafka 在 写入日志文件 时遇到了 磁盘错误 ,通常出现在 Kafka Broker 端

2. 问题排查方向

(1)磁盘空间不足

Kafka 需要足够的磁盘空间存储日志,如果磁盘已满,Kafka 无法写入日志,会报此错误。

如何检查磁盘空间?

sh 复制代码
df -h

示例输出:

Filesystem      Size  Used Avail Use% Mounted on
/dev/sda1       50G   50G   0G   100% /

这里 磁盘已满(100%),Kafka 无法写入。

解决方案
方法 1:清理 Kafka 过期日志

sh 复制代码
kafka-configs.sh --alter --zookeeper localhost:2181 --entity-type topics --entity-name my-topic --add-config retention.ms=3600000

这会将 my-topic 的日志保留时间缩短到 1 小时

方法 2:删除过期日志

sh 复制代码
rm -rf /var/lib/kafka-logs/*

方法 3:扩容磁盘

如果空间不足,考虑 增加磁盘更改 Kafka 日志目录

properties 复制代码
log.dirs=/new/path/to/kafka/logs

然后重启 Kafka:

sh 复制代码
bin/kafka-server-stop.sh
bin/kafka-server-start.sh -daemon config/server.properties

(2)磁盘 I/O 故障

如果磁盘发生硬件故障或 Kafka 进程 无权限 访问磁盘,也会导致此错误。

如何检查磁盘 I/O 状态?

sh 复制代码
iostat -x 1 10

如果 %iowait 非常高,说明磁盘 I/O 过载,Kafka 可能因为磁盘压力导致失败。

解决方案

  • 更换磁盘检查磁盘 SMART 状态

    sh 复制代码
    smartctl -a /dev/sdX
  • 检查 Kafka 日志路径 是否可写:

    sh 复制代码
    ls -ld /var/lib/kafka-logs
    chown -R kafka:kafka /var/lib/kafka-logs
    chmod -R 755 /var/lib/kafka-logs

(3)Kafka 日志文件损坏

如果 Kafka 日志文件损坏 ,Broker 可能无法写入,导致 IOException

如何检查日志文件?

sh 复制代码
ls -lh /var/lib/kafka-logs

如果 Kafka 日志 异常大损坏(corrupt),需要修复。

解决方案

  • 手动删除损坏日志

    sh 复制代码
    rm -rf /var/lib/kafka-logs/*
  • 启用 unclean leader election,防止副本同步异常

    properties 复制代码
    unclean.leader.election.enable=true
  • 强制格式化 Kafka 存储

    sh 复制代码
    bin/kafka-storage.sh format -t <cluster-id> -c config/kraft/server.properties

    ** 注意**:此操作会删除所有 Kafka 数据,仅在不可恢复时使用。

(4)Kafka 进程权限不足

如果 Kafka 没有足够权限 写入日志目录,也会触发 IOException

如何检查 Kafka 进程用户?

sh 复制代码
ps -ef | grep kafka

示例输出:

kafka     12345  1  0 10:00 ?        00:00:00 /usr/bin/java -jar kafka.jar

如果 Kafka 进程是 kafka 用户运行,确保它有写入权限:

sh 复制代码
ls -ld /var/lib/kafka-logs

示例输出:

drwxr-xr-x  2 root root 4096 Jan 30 10:00 /var/lib/kafka-logs

如果 Kafka 无法写入,执行:

sh 复制代码
chown -R kafka:kafka /var/lib/kafka-logs
chmod -R 755 /var/lib/kafka-logs

然后重启 Kafka:

sh 复制代码
systemctl restart kafka

(5)Kafka 配置错误

如果 Kafka 配置了 错误的 log.dirs 路径 ,可能会导致 Disk error

检查 Kafka 日志路径

查看 server.properties

properties 复制代码
log.dirs=/var/lib/kafka-logs

确保这个目录 存在且可写

sh 复制代码
mkdir -p /var/lib/kafka-logs
chown -R kafka:kafka /var/lib/kafka-logs
chmod -R 755 /var/lib/kafka-logs

3. 案例分析

案例 1:磁盘满导致 Kafka 崩溃

现象

  • server.log 出现 Disk error when trying to write to log
  • df -h 显示磁盘已满

解决方案

  1. 清理过期日志:

    sh 复制代码
    rm -rf /var/lib/kafka-logs/*
  2. 限制 Kafka 日志大小:

    sh 复制代码
    retention.bytes=1073741824  # 1GB
    retention.ms=86400000  # 1天

案例 2:磁盘 I/O 过载导致 Kafka 失败

现象

  • Kafka 频繁崩溃,iostat 显示 %iowait 过高

解决方案

  1. 更换 SSD,提高磁盘吞吐量。

  2. 限制 Kafka 负载:

    properties 复制代码
    num.partitions=3
    log.segment.bytes=536870912  # 512MB
    log.flush.interval.messages=10000

案例 3:Kafka 无法写入日志

现象

  • server.log 显示 Permission denied

解决方案

  1. 修复 Kafka 目录权限:

    sh 复制代码
    chown -R kafka:kafka /var/lib/kafka-logs
    chmod -R 755 /var/lib/kafka-logs
相关推荐
hamster20212 分钟前
力扣【1049. 最后一块石头的重量 II】Java题解(背包问题)
java·算法·leetcode
Cikiss1 小时前
「全网最细 + 实战源码案例」设计模式——桥接模式
java·后端·设计模式·桥接模式
字节全栈_PVK1 小时前
Jenkins 的安装(详细教程)_jenkins安装
运维·jenkins
Dr_Si2 小时前
CF 761A.Dasha and Stairs(Java实现)
java·开发语言
你爱写程序吗(新H)2 小时前
基于微信小程序的停车场管理系统设计 停车场微信小程序的设计与实现 (源码+文档)
java·spring boot·微信小程序·小程序
讓丄帝愛伱2 小时前
Java 泛型<? extends Object>
java·开发语言·python
百度网站快速收录2 小时前
深度解析:网站快速收录与服务器性能的关系
运维·服务器·百度快速收录·网站快速收录
Dr_Si2 小时前
CF 764B.Timofey and cubes(Java实现)
java·算法·排序算法
laimaxgg2 小时前
Linux 非阻塞IO
linux·运维·服务器·网络协议
纪元A梦2 小时前
Java设计模式:行为型模式→观察者模式
java·观察者模式·设计模式