Linux服务器磁盘空间占满问题

下面我们一起来看一篇关于Linux服务器磁盘占满问题解决(/dev/sda3 满了),希望碰到此类问题的人能带来帮助。
 

今天下班某电商技术部leader发现个问题,说他们服务器硬盘满了。把日志文件都删掉了,可硬盘空间依旧满。于是df -h查看了下各个挂载点的状况(如下图)。

/dev/sda3 满了

/dev/sda3占用了100%,那么我们du -s -h ./*看下目录的占用情况(如下图)。

 

 

 在工作中,我们也许会遇到这样的问题,发现某个磁盘空间快满了,于是,找到一些无用的大文件将其删除后,发现磁盘空间还是没有释放掉,这是什么原因呢?如何解决呢?下面来重现一下整个过程:

查看磁盘空间情况


 [@74.114 var]# df -h
Filesystem            Size  Used Avail Use% Mounted on
/dev/xvda2            9.7G  284M  8.9G   4% /
/dev/xvda1            251M   13M  226M   6% /boot
none                  1.1G     0  1.1G   0% /dev/shm
/dev/xvda10            97G   60G   33G  65% /home
/dev/xvda3            3.9G  2.7G  1.1G  72% /usr
/dev/xvda5            3.9G  3.6G   77M  98% /var

var分区快满了,找到大文件,并删除

[@74.114 var]# cd /var
[@74.114 var]# du –sh *
3.3G    account
111M    cache
53M     log
0       mail
156K    run
344K    spool

[@74.114 var]# rm –rf account/*

df –h 看一下,却依然是/var 为98%,一点都没释放。


[@74.114 var]# df -h
Filesystem            Size  Used Avail Use% Mounted on
/dev/xvda2            9.7G  284M  8.9G   4% /
/dev/xvda1            251M   13M  226M   6% /boot
none                  1.1G     0  1.1G   0% /dev/shm
/dev/xvda10            97G   60G   33G  65% /home
/dev/xvda3            3.9G  2.7G  1.1G  72% /usr
/dev/xvda5            3.9G  3.6G   77M  98% /var

但du –sh * 却显示没有大文件了


[@74.114  ~]# cd /var && du –sh *
120K    account
111M    cache
53M     log
0       mail
156K    run
344K    spool

猜想1:应该是删除的内容依然被进程占用,内存没释放,所以用lsof |grep – I deleted 看了一下,发现如下:


[@74.114 account]# lsof |grep -i deleted
listserve  4833           blty    0u      CHR      136,2                    4 /dev/pts/2 (deleted)
listserve  4833           blty    1u      CHR      136,2                    4 /dev/pts/2 (deleted)
listserve  4833           blty    2u      CHR      136,2                    4 /dev/pts/2 (deleted)
Billing_P 16989           blty    0u      CHR      136,0                    2 /dev/pts/0 (deleted)
Billing_P 16989           blty    1u      CHR      136,0                    2 /dev/pts/0 (deleted)
Billing_P 16989           blty    2u      CHR      136,0                    2 /dev/pts/0 (deleted)
Billing_P 16990           blty    0u      CHR      136,0                    2 /dev/pts/0 (deleted)
Billing_P 16990           blty    1u      CHR      136,0                    2 /dev/pts/0 (deleted)
Billing_P 16990           blty    2u      CHR      136,0                    2 /dev/pts/0 (deleted)

发现时billing程序占用没释放,所以联系项目经理将Billing_P停掉,重启,依然没有释放任何空间。无果
猜想2:删除的文件是accout目录下的pacct文件,应该是由psacct产生和管理,重启这个程序后是否会OK呢?解决


[@74.114 account]# /etc/init.d/psacct restart

最后看一下磁盘空间,磁盘空间释放鸟~~


[@74.114 var]# df -h
Filesystem            Size  Used Avail Use% Mounted on
/dev/xvda2            9.7G  284M  8.9G   4% /
/dev/xvda1            251M   13M  226M   6% /boot
none                  1.1G     0  1.1G   0% /dev/shm
/dev/xvda10            97G   60G   33G  65% /home
/dev/xvda3            3.9G  2.7G  1.1G  72% /usr
/dev/xvda5            3.9G  100M   3.6M  4% /var

 小建议:

以后处理相关问题时,如果发现du 和df 大小不一致的情况,可以通过lsof 查看,也许可以找到一些出现问题的原因,如果还是找不到问题,在允许的情况下不妨试一下重启服务,也许问题就迎刃而解了。
重启服务得不到解决的情况下,可以通过卸载磁盘分区来试着解决。
在决定删除某些文件前,最好确定好这个文件被哪些服务使用,先停掉这些服务再删除,这样就很少出现空间释放不了的情况了

 

linux磁盘挂载点目录占用情况(图)

挂载点下的目录之和远小于4.5G,那么是什么占用了硬盘呢?

以下为该问题的解答:

在apache/tomcat服务在运行状态下,清空了运行服务的日志,从而导致了/dev/sda3 满了的问题。一般情况下,大多数服务(包括脚本)在运行时,是不能删除当前正在写入的日志文件的。

原理分析:

1. 当前access.log日志正在被apache进程占用。
2. 通过rm命令删除access.log,实际只删除了文件名(该日志文件应用记数不为0,因此空间不会被释放)。
3. 通过rm命令删除了access.log后,apache依然写日志到access.log中,当开启apache进程时,已经通过access.log定位到该文件的inode了,就是说再写日志是不通过access.log,因此即使删除了access.log,apache依然写日志到access.log所在的inode节点,所以导致硬盘空间增加。
4. 因为删除了access.log,所以我们就找不到该文件了,du也查不到,就会出现硬盘满了但看不到究竟是哪些文件占用的。

(写的不甚详细,不明白的大家再google下。)

解决方法:

重启该日志文件的相关服务或程序,如:为apache日志文件则重启apache(如下图,重启后才硬盘空间占用正常)。

磁盘占用恢复正常(图)

转载于:https://www.cnblogs.com/cindy-cindy/p/6796684.html

Linux环境下,处理磁盘空间已满,导致数据库无法正常使用的处理方法: 第一步:查看磁盘空间使用情况 df -f 第二步:找到日志文件,并清理 1) 进入跟目录 cd / 2)查找日志文件(区分大小写) find -name *.Log; find -name *.log; find -name *.000; 第三步:进入到相应的目录,并删除日志文件 如: cd ./home1/data/db2inst2/NODE0000/SQL00001/SQLOGDIR/; rm -f *.LOG; 或者 rm -f *.log; 或者 rm -f *.000; linux下DB2管理命令 1:进入实例 su - db2inst2 2:查看某个库的表空间 db2pd -tablespaces -db mcmxfb 3:查看这个模式下所有活动库的表空间 db2pd -tablespaces -alldbs option and active database; 4: 系统重启后,对数据库的重启,首先要进入到实例下,再执行重启数据库的命令。系统会重启这个实例下的各个数据库 db2start; (注意,同的实例,要分别进入各个实例,再重启); root用户下,重启系统的方法: 重启命令: 1、reboot 2、shutdown -r now 立刻重启(root用户使用) 3、shutdown -r 10 过10分钟自动重启(root用户使用) 4、shutdown -r 20:35 在时间为20:35时候重启(root用户使用) 关机命令: 1、halt 立刻关机 2、poweroff 立刻关机 3、shutdown -h now 立刻关机(root用户使用) 4、shutdown -h 10 10分钟后自动关机 Linux环境下,磁盘空间已满,导致db2数据库无法正常使用。这里解决的,主要是日志文件和环境文件占用磁盘空间太多所引起问题
<think>嗯,用户问的是关于Linux服务器空间满的问题。首先,我需要确认他们可能是在服务器运维中遇到了存储空间足的情况,需要排查原因并找到解决办法。用户可能没有详细说明具体症状,但通常空间满会导致应用无法写入日志、数据库崩溃或者系统服务异常。 接下来,我应该先回想常见的导致磁盘空间足的原因。比如日志文件过大,尤其是像/var/log目录下的日志,可能因为某些服务配置当,没有日志轮转,导致日志文件无限增长。另外,用户的家目录也可能有大量文件,比如开发人员可能上传了大文件或者生成了临时数据。 然后,需要考虑是否有大文件或大量小文件占用空间。使用du和find命令可以快速定位大文件。比如du -sh /*可以查看根目录下各文件夹的大小,或者find命令查找超过一定大小的文件。 还有可能是一些进程占用了已删除的文件,导致空间未释放。比如某个服务打开了一个大日志文件,即使删除了文件,只要进程重启,磁盘空间会被释放。这时候需要检查已删除但未释放的文件,使用lsof | grep deleted来查找,并重启相关进程。 另外,像Docker这样的容器技术,如果配置当,可能会产生大量的镜像、容器或卷,占用大量空间。需要检查/var/lib/docker目录的大小,并清理无用的资源。 还有可能是临时文件堆积,比如/tmp目录下的临时文件没有自动清理,或者应用程序生成的缓存文件过多。需要检查这些目录,并设置定时清理任务。 此外,LVM分区的情况,可能需要扩展逻辑卷或物理卷,但这通常是在有未分配空间的情况下进行的。如果已经用尽所有空间,可能需要添加新硬盘或者清理现有数据。 用户可能需要一步步的指导,如何通过命令检查磁盘使用情况,如何定位大文件,如何处理已删除但未释放的空间,如何清理日志或临时文件,以及如何预防未来的空间问题。需要给出具体的命令示例,比如df -h,du -sh /*,lsof命令的使用,logrotate配置等。 还要注意权限问题,有些目录可能需要root权限才能查看或删除文件,所以要提醒用户使用sudo或者切换到root用户操作。同时,删除文件前要确认文件是否重要,避免误删系统文件或关键数据。 最后,可能需要建议用户设置监控和报警,比如使用cron定时检查磁盘使用率,或者使用工具如Nagios、Prometheus来监控磁盘空间,及时发现并处理问题。另外,合理配置日志轮转策略,定期清理旧日志,避免再次出现空间满的情况。</think>当 Linux 服务器磁盘空间占满时,系统可能无法正常运行(如无法写入日志、服务崩溃等)。以下是完整的排查和解决方法: --- ### **一、快速确认磁盘使用情况** #### 1. 查看整体磁盘占用 ```bash df -h # 查看所有挂载点的使用情况 ``` - **重点关注**:`/`(根目录)、`/home`、`/var` 等高使用率的挂载点。 #### 2. 定位大文件/目录 ```bash # 查看根目录下各文件夹大小(按需调整路径) du -sh /* 2>/dev/null | sort -h # 查找大于 1GB 的文件(按需调整大小) find / -type f -size +1G 2>/dev/null | xargs ls -lh ``` --- ### **二、常见原因及处理** #### 1. **日志文件过大** - **典型路径**:`/var/log/` - **排查**: ```bash du -sh /var/log/* # 查看日志目录大小 journalctl --disk-usage # 检查 systemd 日志大小 ``` - **清理方法**: ```bash # 手动清理旧日志(谨慎操作!) sudo rm /var/log/syslog.* # 删除轮转日志 sudo truncate -s 0 /var/log/syslog # 清空当前日志 # 配置 logrotate(自动管理日志) sudo vim /etc/logrotate.d/your_app # 调整轮转策略 ``` #### 2. **临时文件堆积** - **典型路径**: - `/tmp/` - 应用程序缓存(如 Docker:`/var/lib/docker/containers/`) - **清理方法**: ```bash sudo rm -rf /tmp/* # 清理临时文件 docker system prune -a # 清理 Docker 无用资源 ``` #### 3. **未释放的已删除文件** - **现象**:文件被删除但进程仍占用空间(如日志文件被 `rm` 但服务未重启)。 - **排查**: ```bash lsof +L1 # 查看已删除但未释放的文件 ``` - **处理**: ```bash sudo systemctl restart your_service # 重启相关服务释放空间 ``` #### 4. **用户文件占用** - **典型路径**:`/home/username/`、`/opt/` - **清理方法**: ```bash # 检查用户目录 sudo du -sh /home/* | sort -h # 删除大文件(如 core dump 文件) find /home -name "core.*" -delete ``` --- ### **三、高级排查工具** #### 1. 图形化分析工具 ```bash # 安装 ncdu(交互式磁盘分析工具) sudo apt install ncdu # Debian/Ubuntu sudo yum install ncdu # CentOS/RHEL ncdu / # 扫描根目录 ``` - **操作**:按方向键导航,`d` 删除文件,`?` 查看帮助。 #### 2. 检查隐藏的稀疏文件 ```bash # 查找看似小但实际占用大的稀疏文件 find / -type f -printf "%s\t%p\n" | sort -n | tail -10 ``` --- ### **四、预防措施** 1. **设置磁盘监控**: ```bash # 添加 cron 任务(每天检查) echo "0 0 * * * df -h >> /var/log/disk_usage.log" | sudo tee -a /etc/crontab ``` 2. **限制日志增长**: ```bash # 修改 journald 配置(限制日志大小) sudo vim /etc/systemd/journald.conf # 修改:SystemMaxUse=500M sudo systemctl restart systemd-journald ``` 3. **使用 LVM 扩展磁盘**(需物理空间支持): ```bash sudo lvextend -L +10G /dev/mapper/your-lv # 扩展逻辑卷 sudo resize2fs /dev/mapper/your-lv # 调整文件系统 ``` --- ### **五、注意事项** - **谨慎删除文件**:避免误删系统关键文件(如 `/lib`、`/bin`)。 - **备份优先**:清理前建议备份重要数据。 - **根因分析**:若频繁出现空间足,需排查是否有程序异常写入(如死循环日志)。 通过以上步骤,可快速定位并释放磁盘空间,确保服务器稳定运行。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值