Skip to main content

moregeek program

linux 磁盘空间异常爆满,该怎么查?_linksla智能运维管家的博客-多极客编程

一、背景

在服务器运维过程中,我们时常会遇到这样的情况,收到服务器磁盘空间告警:

Linux 磁盘空间异常爆满,该怎么查?_服务器

登录服务器,通过df -Hl查看

Linux 磁盘空间异常爆满,该怎么查?_根目录_02

和告警信息一致,接着我们就是要找到导致磁盘空间满的目录或文件。

二、如何找到占用空间大的目录或文件?

一种比较笨的方法是,在根目录下,通过du -hs命令,列出各目录所占空间大小

Linux 磁盘空间异常爆满,该怎么查?_根目录_03

之后再用同样的方法继续到对应目录下去找

再相对高效一点的方法是通过du的-d参数,或--max-depth,设置查询的目录深度,目录深度增加,所查询的目录,展示出来会很多,这个时候可以通过grep进行过滤。

du -h -d 2|grep [GT] |sort -nr  
du -h --max-depth=2|grep [GT] |sort -nr

通过这样的方式,可以搜出以G或者T为单位的占用磁盘空间的大目录,并排序

或者可以通过find来查询

find / -type f -size +1G -exec du -h {} \;

从效率上来说,find要比du要更快速、灵活。

通过这两种方法,我们可以快速找到占用磁盘空间的罪魁祸首。

你以为就这么简单?很多时候,你会发现,通过find或du查半天,发现所有加起来的占用空间,和df看到的磁盘空间占用,相差很大,就比如我上面的两张图。

通过df查看,磁盘使用37G,但是在根目录下通过du -hs 查看,总共加起来差不多10G,没有隐藏目录,那空间被谁吃了?

很明显,有空间被已删除文件占用,文件删除了,但是资源没释放。

之前介绍过一个很好用的命令:lsof,我们可以通过以下命令去查看

lsof +L1

Linux 磁盘空间异常爆满,该怎么查?_服务器_04

从结果可以看出,有一个28G左右的大日志文件,删除了,但是空间没释放,这是很常见的一种情况。

对应的解决方法就是,重启tomcat应用,释放空间

三、磁盘空间莫名被吃?

还有一种经常有人问的问题,就是,通过df查看到的磁盘

Linux 磁盘空间异常爆满,该怎么查?_服务器_05

会发现,Used和Avail加起来不够Size,莫名被吃掉一部分

其实这是Linux文件系统的一种安全策略,它默认会为root用户保留5%的磁盘空间,留作紧急情况使用。这样能保证有些关键应用(比如数据库)在硬盘满的时候有点余地,不致于马上就 crash

我们可以通过tune2fs修改预留空间的比例

tune2fs -m 1 /dev/vda1

通过下图可以看到前后对比

Linux 磁盘空间异常爆满,该怎么查?_根目录_06

这样被吃掉的空间,就释放出来了!

©著作权归作者所有:来自51CTO博客作者LinkSLA的原创作品,请联系作者获取转载授权,否则将追究法律责任

rsync远程同步数据备份_挽风三千客的博客-多极客编程

拓扑图:推荐步骤:在centos01服务器安装rsync服务创建同步源名字www,同步源根目录为/www,同步数据验证账户为bob密码为pwd@123,将数据同步到服务器本地/benet目录在centos02配置rsync同步客户机都安做免交互式将远程主机192.168.100.10/www目录同步到本地的/bdqn目录并通过计划任务实现间隔两分钟自动备份一次数据配置实时数据本地同步数据将/www

firewalld防火墙(二)_mb6350fe535a391的博客-多极客编程

拓扑图:推荐步骤:服务器客户端配置IP地址设置网络,安装apache服务启动服务设置主页启动防火墙服务接口添加指定区域,Web服务器启动防火墙服务接口添加指定区域 配置DMZ区域和external区域的Web服务远程管理使用12345端口访问,阻止内网ping通DMZ和external区域的Web服务器,允许内网主机使用https协议访问DMZ和external区域的web服务器,配置端口映射将D

磁盘存储和文件系统_极光_code的博客-多极客编程

一、磁盘结构类型1.设备文件I/O PortsI/O设备地址一切皆文件 open(),read(),write(),close()    设备类型:块设备bolck,存储单位时"块",他的依赖介质时磁盘,比如一个磁盘可以分为很多个块块存储设备通常来讲时随机存放数据的,但它有缓存的机制。字符设备char,存储单位"字符",它的依赖介质是键盘输入数据,作为运维人员应该很熟的一个字符设备就是"/dev/

prometheus监控之tls_清晨的博客-多极客编程

一、说明在basic_auth账号密码的基础上加上tls加密,密码密钥双保险。二、配置1、生成秘钥文件openssl req -new -newkey rsa:2048 -days 3650 -nodes -x509 -keyout prom-test.key -out prom-test.crt -subj \"/C=CN/ST=Beijing/L=Beijing/O=Moelove.info/

[ linux ] 进程间通信之共享内存_小白又菜的博客-多极客编程

在上篇博文我们了解了通过管道完成进程间通信,我们了解匿名管道和命名管道,并且通过编码模拟实现使用了匿名管道和命名管道。我们知道要让进程间完成通信必须让这两个进程首先看到同一份资源,因此给予这个前提,本篇博文我们了解另外一种可以进程间通信的方式 -- 共享内存。1.system V共享内存system V是一套标准,这是系统级别的接口。我们知道进程间通信的前提是:先让不同的进程看到同一份资源!1.1

linux网络虚拟化和docker网络--上_极光_code的博客-多极客编程

Linux网络虚拟化1. Linux网络常见概念与操作1.1 NameSpace 定义​​简单理解namespace​​​​namespace​​是Linux上的网络隔离技术的名称。其实无论是Linux网络中还是其它的网络中,网络隔离的技术是相通的,例如我们二层网络中的VLAN技术一样,在不同的场景下,只是它们的名称不同;​​定义​​Linux系统,处于不同命名空间的网络栈是完全隔离的,彼此之间

exchange 2013 和exchange 2019共存部署和配置_史振宁的博客的博客-多极客编程

背景 Exchange 2013 生命周期将在2023年4月份终结。升级已经势在必行。而升级过程中会存在共存阶段。本篇尽量减少文章篇幅,介绍关键部分和遇到的疑问和问题该如何解决。 共存方案 Exchange2013 需要升级到CU21之后方可和Ex2019共存,从而进一步升级为2019。 环境介绍 主机名 IP 系统版本 角色 demo-dc 172.16.7.54 2012R2

rsync远程同步数据备份_挽风三千客的博客-多极客编程

拓扑图:推荐步骤:在centos01服务器安装rsync服务创建同步源名字www,同步源根目录为/www,同步数据验证账户为bob密码为pwd@123,将数据同步到服务器本地/benet目录在centos02配置rsync同步客户机都安做免交互式将远程主机192.168.100.10/www目录同步到本地的/bdqn目录并通过计划任务实现间隔两分钟自动备份一次数据配置实时数据本地同步数据将/www

firewalld防火墙(二)_mb6350fe535a391的博客-多极客编程

拓扑图:推荐步骤:服务器客户端配置IP地址设置网络,安装apache服务启动服务设置主页启动防火墙服务接口添加指定区域,Web服务器启动防火墙服务接口添加指定区域 配置DMZ区域和external区域的Web服务远程管理使用12345端口访问,阻止内网ping通DMZ和external区域的Web服务器,允许内网主机使用https协议访问DMZ和external区域的web服务器,配置端口映射将D

prometheus监控之tls_清晨的博客-多极客编程

一、说明在basic_auth账号密码的基础上加上tls加密,密码密钥双保险。二、配置1、生成秘钥文件openssl req -new -newkey rsa:2048 -days 3650 -nodes -x509 -keyout prom-test.key -out prom-test.crt -subj \"/C=CN/ST=Beijing/L=Beijing/O=Moelove.info/

html的a标签href属性指定相对路径与绝对路径的用法讲解_kieary的博客-多极客编程

在实际Web开发中,插入图片、包含CSS文件等都需要有路径,如果文件路径的添加错误,就会导致引用失效(无法浏览链接文件,或无法显示插入的图片等)。很多初学者感到困惑,下面我就详细的介绍一下相对路径与绝对路径。HTML相对路径指由这个文件所在的路径引起的跟其它文件(或文件夹)的路径关系。例如:文件1.htm的绝对路径是:d:/www/html/1.htm文件2.htm的绝对路径是:d:/www/ht

[ linux ] 进程间通信之共享内存_小白又菜的博客-多极客编程

在上篇博文我们了解了通过管道完成进程间通信,我们了解匿名管道和命名管道,并且通过编码模拟实现使用了匿名管道和命名管道。我们知道要让进程间完成通信必须让这两个进程首先看到同一份资源,因此给予这个前提,本篇博文我们了解另外一种可以进程间通信的方式 -- 共享内存。1.system V共享内存system V是一套标准,这是系统级别的接口。我们知道进程间通信的前提是:先让不同的进程看到同一份资源!1.1