ERROR 1114 (HY000): The table 'table1' is full

导出数据的时候提示表满了。


1. tmp空间不足:

tmp_table_size = 1024M

max_heap_table_size = 1024M

2. 磁盘空间不足:      清理磁盘空间.


在linux服务器执行程序时报错:awk: write failure (No space left on device) awk: close failed on file /dev/stdout (No space left on device)参考:

https://blog.csdn.net/liuxiangke0210/article/details/54924786

1. df命令用于显示磁盘分区上的可使用的磁盘空间。默认显示单位为KB。可以利用该命令来获取硬盘被占用了多少空间,目前还剩下多少空间等信息。

https://man.linuxde.net/df

采用df命令查看占用情况2. du命令也是查看使用空间的,但是与df命令不同的是Linux du命令是对文件和目录磁盘使用的空间的查看,还是和df命令有一些区别的。 https://man.linuxde.net/du采用:

du -sh /* | sort -nr

查看3. 找到最大的目录,自行查找原因,我自己是发现有服务一直写错误日志4. 删除大文件后重新用df检查 

通过 du 和 df 检查磁盘空间

在开始行动前,最好先检查一下是否磁盘上是否确实还有空间剩余。虽然桌面环境的工具也很不错,但命令行上的工具更直接,要好的多。

首先让我们看看du命令。用它来检查问题磁盘所在的挂载点目录。本文假设出问题的分区挂载点为根目录。

sudo du -sh /

由于它要遍历磁盘中的所有文件,因此需要花费一点时间。现在再让我们试试df。

sudo df -h

可能的原因

这里列出了一些产生这种情况的主要原因。若你发现du和df的结果之间有差别,那么可以直接检查第一项原因。否则从第二项原因开始检查。

已删除文件被进程所占用

有时,文件可能已经被删掉了,但有进程依然在使用它。在进程运行期间,Linux 不会释放该文件的存储空间。你需要找出这个进程然后重启这个进程。

使用下面命令来定位进程。

sudo lsof / | grep deleted

这应该会列出出问题的进程了,然后重启该进程。

sudo systemctl restart service_name

文件系统中有一些称为 “i 节点inode” 的元数据,其用来保存文件的相关信息。很多文件系统中的 i 节点数量是固定的,因此很可能 i 节点已经耗尽了而文件系统本身还没有用完。你可以使用df来检查。

sudo df -i /

比较一下已用的 i 节点和总共的 i 节点数量。如果没有可用的 i 节点了,那么很不幸,你也无法扩充 i 节点。删除一些无用的和过期的文件来释放一些 i 节点吧。

环块

最后一个很常见的问题就是坏的文件系统块。除非另有标记,否则操作系统很可能会认为这些块都是可用的,这会导致文件系统损坏或者硬盘坏死。最好是使用带-cc标志的fsck搜索并标记出这些块。记住,你不能使用正在使用的文件系统(LCTT 译注:即包含坏块的文件系统)中的fsck命令。你应该会要用到 live CD。

sudo fsck -vcck /dev/sda2

很明显,这里需要使用你想检查的磁盘路径取代命令中的磁盘位置。另外,要注意,这恐怕会花上很长一段时间。

相关:使用 fsck 检查并修复你的文件系统 [Linux][2]

希望这些方案能解决你的问题。这种问题在任何情况下都不是那么容易诊断的。但是,在运气好的情况下,你可以把文件系统清理干净并让你的硬盘再次正常工作。

你可能感兴趣的:(ERROR 1114 (HY000): The table 'table1' is full)