MySQL 5.7通用表空间案例分析
admin
2023-05-17 14:42:32
0

下文内容主要给大家带来MySQL 5.7通用表空间案例分析,这里所讲到的知识,与书籍略有不同,都是专业技术人员在与用户接触过程中,总结出来的,具有一定的经验分享价值,希望给广大读者带来帮助。

1. 背景

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

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

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

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

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

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

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. 总结


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

对于以上关于MySQL 5.7通用表空间案例分析,如果大家还有更多需要了解的可以持续关注我们的行业推新,如需获取专业解答,可在官网联系售前售后的,希望该文章可给大家带来一定的知识更新。

 

 



相关内容

热门资讯

广西一载15人车辆坠河,10人... 记者从广西环江毛南族自治县相关方面获悉,据初步了解,5月16日21时30分许,一辆汽车在环江县洛阳镇...
iOS 26.5更新苹果地图两... 苹果地图是iOS 26.5此次更新中获得新功能的应用之一。以下是地图用户需要了解的最新变化。 推荐...
每经热评 | 黄仁勋喝蜜雪冰城... 每经评论员 朱成祥 黄仁勋近期到访北京,被拍到在胡同喝豆汁、吃炸酱面、举着蜜雪冰城饮料。他表情轻松,...
我省3项目被列入工信部先进计算... 本报太原5月15日讯(记者王蕾)近日,工业和信息化部公布了2025年先进计算赋能新质生产力典型应用案...
薛贵:学习的革命——脑科学与人... 1 学习的本质不是知识的装卸, 而是雕刻大脑的“芯片” 耶鲁大学前校长理查德·查尔斯·莱文曾说过:如...
伊朗:已制定管理霍尔木兹海峡指... 新华社德黑兰5月16日电 伊朗伊斯兰议会国家安全和外交政策委员会主席易卜拉欣·阿齐兹16日在社交媒体...
微纳星空双星成功入轨!迈入批产... 来源:北京日报客户端 5月15日12时33分,由海淀企业北京微纳星空科技股份有限公司研制的泰景三号0...
摆拍盲道被撞,反对“愤怒诱饵”... □李琛5月16日,据北京警方通报:刘某(男,26岁)和江某某(女,24岁)为吸粉引流、博取关注、牟取...
原创 这... 此次美高层行程中,随行团队中两位华裔面孔格外引人注目。一位是AI领域的重量级人物黄仁勋,自带科技光环...
联合国教科文组织总干事阿纳尼一... 5月14日下午,联合国教科文组织总干事阿纳尼一行到访张江人工智能创新小镇AI应用商店。 上海于20...