MySQL磁盘空间不够怎么办

介绍

这篇文章主要讲解了“MySQL磁盘空间不够怎么办”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“MySQL磁盘空间不够怎么办”吧!

大部分数据库都有存储数据文件扩展的功能,甲骨文可以扩展你的表空间,SQL SERVER可以多建立几个FILEGROUP, PostgreSQL也可以建立相关类似的扩展。这些都是对付当前存储空间不足,将数据文件跨物理位置进行存储。

MySQL本身从5.6就开始支持相关的扩展,但实际上使用的人是少之又少,今天来说说相关扩展的东西,版本基于MySQL 5.7, MySQL专业的叫法叫做外部表。

首先使用一项技术都是有目地的,使用MySQL的外部表主要有以下几个原因

1,存储空间不够,某个大表需要更大的存储空间

2,存储介质更新,部分表需要存放到更快的存储介质中

下面在看看到底怎么做,目前在数据目录下挂载了mysql的目录以及mysql_extend两个目录,目前数据都在mysql目录下存放,我们需要将员工库中的新建立的表都不在mysql目录下员工存放,都要存放在新的位置/数据/mysql_extend/员工目录

下面有几种方法

1,只针对新表的数据,存储到新的物理位置

 mysql磁盘空间不够怎么办

,创建表“d_extend”(

,,→,,dept_no char (4) NOT NULL,

,,→,,‘dept_name varchar (40) NOT NULL,

,,→,,主键(“dept_no”),

,,→,,唯一键“dept_name”(dept_name)

,,→)引擎=InnoDB默认字符集=utf8mb4 数据目录=& # 39;/数据/mysql_extend& # 39;;

我们可以看到物理文件已经到了指定的位置

 MySQL磁盘空间不够怎么办

在原目录中会产生一个isl文件,

 MySQL磁盘空间不够怎么办

isl文件其实里面仅仅包含了实际ibd文件的存储位置

 MySQL磁盘空间不够怎么办

在实际中的应用可能会存在这样一个实际情况,就是我们更换了SSD磁盘

但怎么将表的物理文件安全的迁移到新的SSD磁盘上。

我们继续往下看,举例我们要将员工表迁移到SSD磁盘环境,而SSD的磁盘环境的对应的目录是/数据/mysql_extend下

1我们创建一个表空间,并指定到/数据/mysql_extend下

创建员工表空间添加数据文件& # 39;/数据/mysql_extend/员工/employees.ibd& # 39;引擎=innodb;

 MySQL磁盘空间不够怎么办

2之间迁移数据到新的表空间

 MySQL磁盘空间不够怎么办

 MySQL磁盘空间不够怎么办

上面两张图可以看到ibd文件已经从原来的目录迁移到了新的位置,但纳文件还是保留在原来的目录。

另外需要注意的是,如果是下,复制等,要保证其他集群上的目录都要一样,在做相关的操作。

另外通过查看表空间我们可以发现两点问题

select * from INNODB_SYS_TABLESPACES;

 MySQL磁盘空间不够怎么办

新建立的表空间的文件格式是任何row_format也是任何并且space_type是一般,说明两个问这题1个表空间并不是per_table的,是可以多个表公用的存储空间,这点和其他数据库是一致的。

另外根据官方文档,如果将多个表存储在一个表空间,相对于一个表一个表空间有以下问题

1不支持周二说的快速移动表的方式也就是表抛弃

2分区表误使用这样的方法

3官方文档说明由于多表公用一个表空间,在元数据读取上会优于单表单文件的方式,但未提供具体的数据以及相关的实验证明。

感谢各位的阅读,以上就是“MySQL磁盘空间不够怎么办”的内容了,经过本文的学习后,相信大家对MySQL磁盘空间不够怎么办这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是,小编将为大家推送更多相关知识点的文章,欢迎关注!

MySQL磁盘空间不够怎么办