在线时间:8:00-16:00
迪恩网络APP
随时随地掌握行业动态
扫描二维码
关注迪恩网络微信公众号
今天我要跟你分享的话题是:“大家常说的表空间到底是什么?究竟什么又是数据表?” 这其实是一个概念性的知识点,当作拓展知识。涉及到的概念大家了解一下就好,涉及的参数,留个印象就好。 一、什么是表? 但凡是用过MySQL都知道,直观上看,MySQL的数据都存在数据表中。 比如一条Update SQL: update user set username = '白日梦' where id = 999; 它将user这张数据表中id为1的记录的username列修改成了‘白日梦' 这里的user其实就是数据表。当然这不是重点,重点是我想表达:数据表其实是逻辑上的概念。而下面要说的表空间是物理层面的概念。 二、什么是表空间? 不知道你有没有看到过这句话:“在innodb存储引擎中数据是按照表空间来组织存储的”。其实有个潜台词是:表空间是表空间文件是实际存在的物理文件。 大家不用纠结为啥它叫表空间、为啥表空间会对应着磁盘上的物理文件,因为MySQL就是这样设计、设定的。直接接受这个概念就好了。 MySQL有很多种表空间,下面一起来了解一下。 三、sys表空间 你可以像下面这样查看你的MySQL的系统表空间 Value部分的的组成是:name:size:attributes 默认情况下,MySQL会初始化一个大小为12MB,名为ibdata1文件,并且随着数据的增多,它会自动扩容。 这个ibdata1文件是系统表空间,也是默认的表空间,也是默认的表空间物理文件,也是传说中的共享表空间。
四、配置sys表空间 系统表空间的数量和大小可以通过启动参数:innodb_data_file_path # my.cnf [mysqld] innodb_data_file_path=/dir1/ibdata1:2000M;/dir2/ibdata2:2000M:autoextend 五、file per table 表空间 如果你想让每一个数据库表都有一个单独的表空间文件的话,可以通过参数innodb_file_per_table设置。
可以通过配置文件 [mysqld] innodb_file_per_table=ON 也可以通过命令 mysql> SET GLOBAL innodb_file_per_table=ON; 让你将其设置为ON,那之后InnoDB存储引擎产生的表都会自己独立的表空间文件。 独立的表空间文件命名规则:表名.ibd 注意:
查看我的表空间文件: 最后再简述一下这种file per table的优缺点: 优点:
缺点: 对fsync系统调用来说不友好,如果使用一个表空间文件的话单次系统调用可以完成数据的落盘,但是如果你将表空间文件拆分成多个。原来的一次fsync可能会就变成针对涉及到的所有表空间文件分别执行一次fsync,增加fsync的次数。 六、临时表空间 临时表空间用于存放用户创建的临时表和磁盘内部临时表。 参数innodb_temp_data_file_path定义了临时表空间的一些名称、大小、规格属性如下图: 查看临时表空间文件存放的目录 七、undo表空间 相信你肯定听过说undolog,常见的当你的程序想要将事物rollback时,底层MySQL其实就是通过这些undo信息帮你回滚的。 在MySQL的设定中,有一个表空间可以专门用来存放undolog的日志文件。 然而,在MySQL的设定中,默认的会将undolog放置到系统表空间中。 如果你的MySQL是新安装的,那你可以通过下面的命令看看你的MySQL undo表空间的使用情况: 大家可以看到,我的MySQL的undo log 表空间有两个。 也就是我的undo从默认的系统表空间中转移到了undo log专属表空间中了。 那undo log到底是该使用默认的配置放在系统表空间呢?还是该放在undo表空间呢? 这其实取决服务器使用的存储卷的类型。 如果是SSD存储,那推荐将undo info存放在 undo表空间中。 以上就是MySQL的表空间是什么的详细内容,更多关于MySQL 表空间的资料请关注极客世界其它相关文章! |
请发表评论