Linux的dev/vda1文件满了导致MySQL无法写入

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
日志服务 SLS,月写入数据量 50GB 1个月
云数据库 RDS PostgreSQL,高可用系列 2核4GB
简介: 今天查看两个月前上线的小项目,发现运行非常慢,而且增删改查失效了(吓我一大跳),急急忙忙的就开始了我的线上问题排查之路。/dev/vda1是 Linux 系统中的一个设备文件,它表示第一个虚拟磁盘(vda)的第一个分区(1)。在大多数 Linux 发行版中,这是系统根分区的默认位置。如果您要对/dev/vda1进行操作(例如挂载、格式化、备份等),则需要具有足够的权限。一般来说,只有 root 用户或具有 sudo 权限的用户才能进行这些操作。当Linux的/dev/vda1。

 其他系列文章导航

Java基础合集

数据结构与算法合集

设计模式合集

多线程合集

分布式合集

ES合集


文章目录

其他系列文章导航

文章目录

前言

一、dev/vda1文件介绍

二、排查过程

三、总结


前言

今天查看两个月前上线的小项目,发现运行非常慢,而且增删改查失效了(吓我一大跳),急急忙忙的就开始了我的线上问题排查之路。


一、dev/vda1文件介绍

/dev/vda1 是 Linux 系统中的一个设备文件,它表示第一个虚拟磁盘(vda)的第一个分区(1)。在大多数 Linux 发行版中,这是系统根分区的默认位置。

如果您要对 /dev/vda1 进行操作(例如挂载、格式化、备份等),则需要具有足够的权限。一般来说,只有 root 用户或具有 sudo 权限的用户才能进行这些操作。


二、排查过程

1.通过监控我发现了我的 /dev/vda1 挂载的/目录的内存已经满了,我的第一反应就是运行日志太大了,我通过以下命令来确定:

    • 先查看内存使用情况:df -h
    • 进入/dev/vdal的磁盘挂载的目录 /:cd /
    • 查看各个文件占用大小:du -sh *

    2.最后发现 www 文件占 34G ,我天,然后我进入 www 文件,发现了日志文件高达 33G 之多。

    3.我快马加鞭直接清空了两个日志文件,www 文件的占用内存也恢复到了下图所示 7.7G 。

    如图所示:

    image.gif编辑

    4.但是相信你们也发现了,dev/vda1 文件还是 use 100%,我的天啥情况啊这是,然后开始了我漫漫寻找方法之路。

    5.10000年后,终于我发现了,删掉较大的文件或目录后磁盘空间却没有释放出来的原因是因为已删除空间却没有释放的进程

    查询一下查看已删除空间却没有释放的进程 id 然后 kill 掉:

    lsof -n | grep -i delete

    image.gif

    如图所示:

    image.gif编辑

    小彩蛋:杀进程的时候把 nignx 也杀了,哈哈哈哈,又查了一会,笑cry

    到此我的线上排查之路为止,也是第一次遇到,记录一下心得!


    三、总结

    当Linux的/dev/vda1文件满时,会导致MySQL无法写入数据,这是因为MySQL需要足够的磁盘空间来存储数据。当磁盘空间不足时,MySQL无法将新的数据写入磁盘,从而引发了写入错误。

    这个问题的解决方法是释放一些磁盘空间,可以通过以下几种方式来实现:

      1. 清理MySQL的日志文件:MySQL会产生大量的日志文件,其中包括错误日志、查询日志和慢查询日志等。可以查看这些日志文件并删除其中的一些不必要的内容,以释放磁盘空间。
      2. 清理临时文件:在MySQL运行过程中,会产生大量的临时文件。这些临时文件可能会占用大量的磁盘空间,可以定期清理这些文件以释放空间。
      3. 增加磁盘容量:如果经常出现磁盘空间不足的问题,可以考虑增加磁盘容量,以提供更多的存储空间。
      4. 优化数据库:可以对MySQL数据库进行优化,以减少磁盘空间的占用。例如,可以清理不必要的表、索引和数据,优化数据库的结构等。

      总之,当Linux的/dev/vda1文件满时,会导致MySQL无法写入数据。解决这个问题的方法是释放一些磁盘空间,可以通过清理日志文件、清理临时文件、增加磁盘容量和优化数据库等方式来实现。

      相关实践学习
      每个IT人都想学的“Web应用上云经典架构”实战
      本实验从Web应用上云这个最基本的、最普遍的需求出发,帮助IT从业者们通过“阿里云Web应用上云解决方案”,了解一个企业级Web应用上云的常见架构,了解如何构建一个高可用、可扩展的企业级应用架构。
      MySQL数据库入门学习
      本课程通过最流行的开源数据库MySQL带你了解数据库的世界。   相关的阿里云产品:云数据库RDS MySQL 版 阿里云关系型数据库RDS(Relational Database Service)是一种稳定可靠、可弹性伸缩的在线数据库服务,提供容灾、备份、恢复、迁移等方面的全套解决方案,彻底解决数据库运维的烦恼。 了解产品详情: https://www.aliyun.com/product/rds/mysql 
      目录
      相关文章
      |
      2月前
      |
      存储 数据管理 Linux
      区分Linux中.tar文件与.tar.gz文件的不同。
      总之,".tar"文件提供了一种方便的文件整理方式,其归档但不压缩的特点适用于快速打包和解压,而".tar.gz"文件通过额外的压缩步骤,尽管处理时间更长,但可以减小文件尺寸,更适合于需要节约存储空间或进行文件传输的场景。用户在选择时应根据具体需求,考虑两种格式各自的优劣。
      410 13
      |
      3月前
      |
      安全 Linux
      Linux赋予文件000权限的恢复技巧
      以上这些步骤就像是打开一扇锁住的门,步骤看似简单,但是背后却有着严格的逻辑和规则。切记,在任何时候,变更文件权限都要考虑安全性,不要无谓地放宽权限,那样可能
      134 16
      |
      3月前
      |
      存储 Linux 数据处理
      深入剖析Linux中一切即文件的哲学和重定向的机制
      在计算机的奇妙世界中,Linux的这套哲学和机制减少了不同类型资源的处理方式,简化了抽象的概念,并蕴藏着强大的灵活性。就像变戏法一样,轻轻松松地在文件、程序与设备之间转换数据流,标准输入、输出、错误流就在指尖舞动,程序的交互和数据处理因此变得既高效又富有乐趣。
      58 4
      |
      4月前
      |
      Linux
      【Linux】 Linux文件I/O常见操作技巧
      以上就是Linux文件I/O操作的一些技巧,接纳它们,让它们成为你在Linux世界中的得力伙伴,工作会变得轻松许多。不过记住,技巧的运用也需要根据实际情况灵活掌握,毕竟,最适合的才是最好的。
      126 28
      |
      3月前
      |
      SQL 关系型数据库 MySQL
      MySQL 5.6/5.7 DDL 失败残留文件清理指南
      通过本文的指南,您可以更安全地处理 MySQL 5.6 和 5.7 版本中 DDL 失败后的残留文件,有效避免数据丢失和数据库不一致的问题。
      |
      4月前
      |
      开发框架 Java 关系型数据库
      在Linux系统中安装JDK、Tomcat、MySQL以及部署J2EE后端接口
      校验时,浏览器输入:http://[your_server_IP]:8080/myapp。如果你看到你的应用的欢迎页面,恭喜你,一切都已就绪。
      395 17
      |
      4月前
      |
      Ubuntu Linux
      "unzip"命令解析:Linux下如何处理压缩文件。
      总的来说,`unzip`命令是Linux系统下一款实用而方便的ZIP格式文件处理工具。本文通过简明扼要的方式,详细介绍了在各类Linux发行版上安装 `unzip`的方法,以及如何使用 `unzip`命令进行解压、查看和测试ZIP文件。希望本文章能为用户带来实际帮助,提高日常操作的效率。
      612 12
      |
      4月前
      |
      关系型数据库 MySQL Java
      安装和配置JDK、Tomcat、MySQL环境,以及如何在Linux下更改后端端口。
      遵循这些步骤,你可以顺利完成JDK、Tomcat、MySQL环境的安装和配置,并在Linux下更改后端端口。祝你顺利!
      350 11
      |
      3月前
      |
      Linux
      linux文件重命名命令
      本指南介绍Linux文件重命名方法,包括单文件操作的`mv`命令和批量处理的`rename`命令。`mv`可简单更改文件名并保留扩展名,如`mv old_file.txt new_name.txt`;`rename`支持正则表达式,适用于复杂批量操作,如`rename 's/2023/2024/' *.log`。提供实用技巧如大小写转换、数字序列处理等,并提醒覆盖风险与版本差异,建议使用`-n`参数预览效果。
      |
      Java 测试技术 Linux
      Linux系统小技巧(1):/dev/random设备可能导致java程序启动慢或者操作耗时不正常
      Linux系统设备/dev/random,因其可能阻塞在其上的读操作,有可能引致Java程序/进程异常,这是一个老问题,但是偶尔还是会遇到。为什么会这样以及如何解决类似问题,就在这篇短文里。
      9735 0