简单记一次linux系统启动项目时报: 设备上没有空间

本文解决了一个常见的Java项目启动错误,详细分析了由磁盘空间不足引发的logback配置问题,并提供了检查及释放空间的具体步骤。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

状况

java项目,启动时报错(其他项目应该是一样的类型)
java.lang.IllegalStateException: Logback configuration error detected: 
ERROR in ch.qos.logback.core.rolling.RollingFileAppender[FILE] -
 Could not close output stream for OutputStreamAppender. java.io.IOException: 设备上没有空间

原因

  • 服务器中的物理存储空间不足,注意:不是运行空间。
  • 再次验证使用命令 df -h 查看是否是物理存储空间,查看结果如下:
[root@k8s-node2 log]# df -h
文件系统                 容量  已用  可用 已用% 挂载点
/dev/mapper/centos-root   50G   50G  120K  100% /
devtmpfs                 3.8G     0  3.8G    0% /dev
tmpfs                    3.8G     0  3.8G    0% /dev/shm
tmpfs                    3.8G   34M  3.8G    1% /run
tmpfs                    3.8G     0  3.8G    0% /sys/fs/cgroup
/dev/sda1               1014M  147M  868M   15% /boot
/dev/mapper/centos-home  873G  680M  872G    1% /home
tmpfs                    771M     0  771M    0% /run/user/0

解决

1.进入根目录,执行命令来查看是哪个文件夹的空间不足

[root@k8s-node2 jar]# cd /
[root@k8s-node2 /]# du -h --max-depth=1
115M	./boot
0	./dev
647M	./home
du: 无法访问"./proc/14475/task/14475/fd/4": 没有那个文件或目录
du: 无法访问"./proc/14475/task/14475/fdinfo/4": 没有那个文件或目录
du: 无法访问"./proc/14475/fd/3": 没有那个文件或目录
du: 无法访问"./proc/14475/fdinfo/3": 没有那个文件或目录
0	./proc
26M	./run
0	./sys
35M	./etc
195M	./root
25G	./var
29M	./tmp
1.3G	./usr
0	./media
0	./mnt
24G	./opt
0	./srv
51G	.
可以看到占用资源最大的文件夹在var和opt中,我们可以先进入var查看
  1. 执行跟上一步相同的策略来查看哪些占用较大
[root@k8s-node2 var]# du -h --max-depth=1
0	./tmp
1.2G	./lib
23G	./log
0	./adm
66M	./cache
8.0K	./db
0	./empty
0	./games
0	./gopher
0	./local
0	./nis
0	./opt
0	./preserve
16K	./spool
0	./yp
0	./kerberos
1.1G	./crash
25G	.
可以发现在文件夹log中的文件占用最大,进入log文件夹中执行命令    ll   可以查看哪些文件或者文件夹占用最大
  1. 删除一些占用较大的资源
  2. 再次执行 fd -h可以发现资源得到释放
### 解决IntelliJ IDEA启动项目时报`java.lang.OutOfMemoryError: GC overhead limit exceeded`错误 当遇到`java.lang.OutOfMemoryError: GC overhead limit exceeded`错误时,表明垃圾回收器花费过多时间尝试释放内存但仍无法完成清理工作。这通常意味着应用程序消耗了大量堆空间,并且剩余可用资源不足以支持其继续运行。 #### 调整IDEA JVM参数配置 为了缓解此问题,在IntelliJ IDEA中可以通过调整虚拟机选项来增加分配给项目的最大堆大小和其他相关设置: 1. 打开编辑自定义VM选项对话框: - Windows/Linux:点击 `Help | Edit Custom VM Options...` - macOS:点击 `IntelliJ IDEA | Preferences | Appearance & Behavior | System Settings | Memory Settings` 2. 修改文件中的参数以适应更大的内存需求。例如,可以将初始和最大堆尺寸设得更大一些[^1]: ```properties -Xms1024m # 设置最小堆大小为1GB -Xmx4096m # 设置最大堆大小为4GB -XX:ReservedCodeCacheSize=512m # 增加代码缓存预留量至512MB ``` 3. 如果仍然存在问题,则考虑进一步优化构建过程或减少不必要的依赖项加载,从而降低整体内存占用。 #### 配置Maven/Gradle构建工具的内存限制 对于基于Maven或Gradle管理依赖关系的应用程序来说,还需要确保这些构建工具有足够的内存来进行操作。可以在相应的配置文件里指定更高的内存限额: ##### Maven: 修改`.mvn/jvm.config` 文件 (如果不存在则创建),并加入以下内容[^4]: ```bash -Xms512m -Xmx2048m -XX:MaxPermSize=512M -XX:+CMSClassUnloadingEnabled ``` ##### Gradle: 编辑`gradle.properties` 文件, 添加如下属性: ```properties org.gradle.jvmargs=-Dfile.encoding=UTF-8 ``` 以上措施有助于提高开发环境下的性能表现以及解决问题的可能性。然而需要注意的是,具体数值应根据实际硬件条件和个人偏好适当调整。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值