首页 > 代码库 > MySQL 5.7新支持--------通用表空间实战

MySQL 5.7新支持--------通用表空间实战

1. 背景

  * 一个通用的表空间是一个共享的InnoDB表空间。

   * 与系统表空间类似,一般的表空间是共享的表空间,可以存储多个表的数据

   * 一般的表空间比文件表的表空间具有潜在的内存优势。

   * MySQL 将表空间元数据保存到一个表空间的生命周期中。在更少的一般表空间中,多个表对表空间元数据的内存比在单独的文件表空间表空间中的相同数量的表要少。    

   * 一般的表空间数据文件可能放在一个相对于MySQL数据目录的目录中,它为您提供了许多文件表空间的数据文件和存储管理功能。与文件表的表空间一样,在MySQL数据目录之外放置数据文件的能力允许您单独管理关键表的性能,为特定的表设置RAID或DRBD,或者将表绑定到特定的磁盘。

   * MySQL 5.7开始支持通用表空间管理功能。


2. MySQL 环境

Welcome to the MySQL monitor.  Commands end with ; or \g.
Your MySQL connection id is 4
Server version: 5.7.18 MySQL Community Server (GPL)

Copyright (c) 2000, 2017, Oracle and/or its affiliates. All rights reserved.

Oracle is a registered trademark of Oracle Corporation and/or its
affiliates. Other names may be trademarks of their respective
owners.

Type ‘help;‘ or ‘\h‘ for help. Type ‘\c‘ to clear the current input statement.

mysql> show variables like ‘version‘;
+---------------+--------+
| Variable_name | Value  |
+---------------+--------+
| version       | 5.7.18 |
+---------------+--------+
1 row in set (0.01 sec)

mysql> show variables like ‘datadir‘;
+---------------+-------------------+
| Variable_name | Value             |
+---------------+-------------------+
| datadir       | /data/mysql_data/ |
+---------------+-------------------+
1 row in set (0.04 sec)


3. 创建通用表空间

  * 创建表空间文件存放目录

[root@MySQL mytest]# mkdir -v /mysql_general_data
mkdir: created directory `/mysql_general_data‘


   * 查看mysqld 运行用户

[root@MySQL mytest]# ps aux | grep mysqld | grep -v grep
root       1468  0.0  0.0 110400  1532 ?        S    16:00   0:00 /bin/sh /usr/local/mysql/bin/mysqld_safe --datadir=/data/mysql_data --pid-file=/data/mysql_data/MySQL.pid
mysql      1614  0.1  5.0 1309380 196656 ?      Sl   16:00   0:06 /usr/local/mysql/bin/mysqld --basedir=/usr/local/mysql --datadir=/data/mysql_data --plugin-dir=/usr/local/mysql/lib/plugin --user=mysql --log-error=/data/mysql_data/error.log --pid-file=/data/mysql_data/MySQL.pid


   * 修改表空间文件存放目录所属用户与组为mysql运行用户 [ 此步必须 ]

[root@MySQL mytest]# chown -v mysql.mysql /mysql_general_data 
changed ownership of `/mysql_general_data‘ to mysql:mysql


   * 创建通用表空间

   ADD datafile: 指定通用表空间文件存放路径

     FILE_BLOCK_SIZE: 指定文件块大小,推荐与Innodb_page_size参数大小对应

     ENGINE: 指定存储引擎

mysql> CREATE TABLESPACE ts1 ADD datafile ‘/mysql_general_data/ts1.ibd‘ FILE_BLOCK_SIZE=16384  ENGINE=InnoDB;
Query OK, 0 rows affected (0.06 sec)

mysql> show variables like ‘innodb_page_size‘;
+------------------+-------+
| Variable_name    | Value |
+------------------+-------+
| innodb_page_size | 16384 |
+------------------+-------+
1 row in set (0.02 sec)


  * 查看通用表空间文件

mysql> system ls -l /mysql_general_data;
total 64
-rw-r----- 1 mysql mysql 65536 Jul  5 17:15 ts1.ibd


4. 测试通用表空间文件

  * 使用通用表空间作为数据存储创建表

mysql> CREATE TABLE test_general(
    -> id BIGINT PRIMARY KEY NOT NULL AUTO_INCREMENT,
    -> name VARCHAR(64) NOT NULL
    -> )ENGINE=InnoDB TABLESPACE=ts1 DEFAULT CHARSET=utf8mb4;
Query OK, 0 rows affected (0.04 sec)


  * 查看表信息

mysql> show create table test_general;
+--------------+---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
| Table        | Create Table                                                                                                                                                                                      |
+--------------+---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
| test_general | CREATE TABLE `test_general` (
  `id` bigint(20) NOT NULL AUTO_INCREMENT,
  `name` varchar(64) NOT NULL,
  PRIMARY KEY (`id`)
) /*!50100 TABLESPACE `ts1` */ ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 |
+--------------+---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
1 row in set (0.06 sec)


  * 查看表文件

mysql> select database();
+------------+
| database() |
+------------+
| mytest     |
+------------+
1 row in set (0.01 sec)

mysql> system ls -l /data/mysql_data/mytest;
total 16
-rw-r----- 1 mysql mysql   67 Jul  5 16:30 db.opt
-rw-r----- 1 mysql mysql 8586 Jul  5 17:19 test_general.frm


5. 删除表空间文件

   * 有表占用时直接删除

mysql> drop tablespace ts1;
ERROR 1529 (HY000): Failed to drop TABLESPACE ts1


  * 先删除占用表,再删除

mysql> drop table test_general;
Query OK, 0 rows affected (0.04 sec)

mysql> drop tablespace ts1;
Query OK, 0 rows affected (0.03 sec)


6. 总结


以需求驱动技术,技术本身没有优略之分,只有业务之分。

本文出自 “sea” 博客,请务必保留此出处http://lisea.blog.51cto.com/5491873/1945446

MySQL 5.7新支持--------通用表空间实战