AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • 主页
  • 系统&网络
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • 主页
  • 系统&网络
    • 最新
    • 热门
    • 标签
  • Ubuntu
    • 最新
    • 热门
    • 标签
  • Unix
    • 最新
    • 标签
  • DBA
    • 最新
    • 标签
  • Computer
    • 最新
    • 标签
  • Coding
    • 最新
    • 标签
主页 / server / 问题 / 669787
Accepted
Mr.Boon
Mr.Boon
Asked: 2015-02-20 00:18:15 +0800 CST2015-02-20 00:18:15 +0800 CST 2015-02-20 00:18:15 +0800 CST

数据库更改期间的 InnoDB “表 xx 已满”

  • 772

我在 CentOS 6.3 64 位上运行 Percona Mysql Server 5.6.14-56。

服务器有足够的内存 (96gb) 和免费存储。文件系统类型:ext4

dev/sda6     ext4   1093623528  56576512 981494148   6% /mysqlstorage

我试图对一个有 42M 记录的表(大约 12.5gb 大小(其中大约 50% 是索引))进行一些更改,今天它向我显示了 Table Is Full 错误。

我检查了加载的变量,innodb_data_file_path = ibdata1:12M:autoextend它显示在我的 mysql 管理器中。

这个数据库是实时的,我更喜欢在没有(或最少)停机时间的情况下解决这个问题。

file-per-table 处于活动状态 ibdata1 约为 3.9GB

来自 MYSQL 日志:

2015-02-19 01:43:04 7fe921f4b700 InnoDB: Error: Write to file (merge) failed at offset 356515840.
InnoDB: 1048576 bytes should have been written, only 1036288 were written.
InnoDB: Operating system error number 28.
InnoDB: Check that your OS and file system support files of this size.
InnoDB: Check also that the disk is not full or a disk quota exceeded.
InnoDB: Error number 28 means 'No space left on device'.
InnoDB: Some operating system error numbers are described at
InnoDB: http://dev.mysql.com/doc/refman/5.6/en/operating-system-error-codes.html

我该怎么做呢?

// 编辑

自从问了这个问题后,我了解到在这个“交替”期间,我的 /tmp 很快就会填满 100%。一旦达到 100%,mysql 就会推出该错误消息。

Filesystem           1K-blocks      Used Available Use% Mounted on
/dev/sda2             50395844   1745156  46090688   4% /
tmpfs                 37105808         0  37105808   0% /dev/shm
/dev/sda1               495844     37092    433152   8% /boot
/dev/sda5              4080064     73740   3799068   2% /tmp
/dev/sda6            1093623528  56576524 981494136   6% /storage

如何在不停机的情况下安全地增加 /tmp 的大小?

mysql
  • 1 1 个回答
  • 4473 Views

1 个回答

  • Voted
  1. Best Answer
    Kondybas
    2015-02-20T00:31:17+08:002015-02-20T00:31:17+08:00

    表更改涉及 /tmp 分区作为显式和隐式创建的临时表的中间存储。您必须在足够大的分区上使用 tmpdir。将下一行添加到my.cnf

    tmpdir = /path/to/the/mysqltmp
    
    • 2

相关问题

  • 开源与专有关系 db mgt 系统的优缺点是什么?

  • 在 solaris 10 上为 mysql 设置 max_allowed_pa​​cket

  • 如何移动 MySQL 的数据目录?

  • 通过 VPN 连接什么是远程服务器 IP?

  • mysql崩溃

Sidebar

Stats

  • 问题 205573
  • 回答 270741
  • 最佳答案 135370
  • 用户 68524
  • 热门
  • 回答
  • Marko Smith

    新安装后 postgres 的默认超级用户用户名/密码是什么?

    • 5 个回答
  • Marko Smith

    SFTP 使用什么端口?

    • 6 个回答
  • Marko Smith

    命令行列出 Windows Active Directory 组中的用户?

    • 9 个回答
  • Marko Smith

    什么是 Pem 文件,它与其他 OpenSSL 生成的密钥文件格式有何不同?

    • 3 个回答
  • Marko Smith

    如何确定bash变量是否为空?

    • 15 个回答
  • Martin Hope
    Tom Feiner 如何按大小对 du -h 输出进行排序 2009-02-26 05:42:42 +0800 CST
  • Martin Hope
    Noah Goodrich 什么是 Pem 文件,它与其他 OpenSSL 生成的密钥文件格式有何不同? 2009-05-19 18:24:42 +0800 CST
  • Martin Hope
    Brent 如何确定bash变量是否为空? 2009-05-13 09:54:48 +0800 CST
  • Martin Hope
    cletus 您如何找到在 Windows 中打开文件的进程? 2009-05-01 16:47:16 +0800 CST

热门标签

linux nginx windows networking ubuntu domain-name-system amazon-web-services active-directory apache-2.4 ssh

Explore

  • 主页
  • 问题
    • 最新
    • 热门
  • 标签
  • 帮助

Footer

AskOverflow.Dev

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve