zoukankan      html  css  js  c++  java
  • InnoDB独立表空间

    在查看MySQL的数据库文件的时候会发现,MyISAM存储引擎类型的表会有三个文件,*.frm,*.MYD,*.MYI,但是InnoDB存储引擎的文件只有一个*.frm,原来是因为InnoDB没有开启独立表空间,执行如下命令可以看到:

    mysql> show variables like '%per%';
    +-----------------------+-------+
    | Variable_name         | Value |
    +-----------------------+-------+
    | innodb_file_per_table | OFF    |
    +-----------------------+-------+
    1 row in set (0.00 sec)
    

      

    导致InnoDB的所有表的数据都存储在sys/var/lib/mysql/ibdata1文件中,我这个文件已经有10G了,这样在对InnoDB的单个表做冷备份的时候就会备份很多无用的数据,所以需要开启独立表空间。

    于是我这样做

    mysql> set global innodb_file_per_table='ON';
    ERROR 1238 (HY000): Variable 'innodb_file_per_table' is a read only variable
    

      原因应该是这个参数的含义是针对InnoDB存储引擎的,不能在一个会话中进行设置,于是查阅资料后

    修改my.cnf,在[mysqld]模块下添加参数,这里注意值是1而不是ON,我一开始设成了ON,结果就是没成功

    innodb_file_per_table=1
    

      重启MySQL,再看一下这个变量的值


    mysql> show variables like '%per%'; +-----------------------+-------+ | Variable_name | Value | +-----------------------+-------+ | innodb_file_per_table | ON | +-----------------------+-------+ 1 row in set (0.00 sec)

    可以看到这个变量已经被设置成功了

    在这里我开始往表里面插入数据,想看一下怎么独立存储的,可是在mysql目录下执行命令

    ll -rt
    

      发现

    -rwxrwx--- 1 mysql mysql 10211033088  4月 27 16:01 ibdata1
    -rwxrwx--- 1 mysql mysql     5242880  4月 27 16:01 ib_logfile0
    -rwxrwx--- 1 mysql mysql     5242880  4月 27 16:01 ib_logfile1
    

      这三个文件是随着插入语句的执行而实时更新时间的,但是大小却没变。为什么?难道说是因为数据在缓存里,执行语句

    flush query cache
    

    大小还是没反应(这里需要确认一下数据在写入MySQL时,是如何落地的),应该不是这个原因,如果是这样的话修改时间就不会实时变吧,

    想到之前看的《MySQL技术内幕》中说的,应该是重复利用之前的页来存储了,回去翻书确认一下。MARK

     书里没看到为啥,那就新建一个InnoDB表来看一下效果吧暂时

    CREATE TABLE `app_zhushou_data2` (
      `id` int(11) NOT NULL AUTO_INCREMENT,
      `appid` int(11) NOT NULL DEFAULT '0',
      `downloadurl` varchar(255) NOT NULL DEFAULT '',
      `icon` varchar(255) NOT NULL DEFAULT '',
      `mainpng` varchar(255) NOT NULL DEFAULT '',
      PRIMARY KEY (`id`),
      UNIQUE KEY `appid` (`appid`) USING BTREE
    ) ENGINE=InnoDB AUTO_INCREMENT=351064 DEFAULT CHARSET=utf8
    

      这时可以看到当前数据库下果然多了一个独立的ibd文件

    -rw-rw---- 1 mysql mysql 8.5K Apr 28 06:44 app_zhushou_data2.frm
    -rw-rw---- 1 mysql mysql 112K Apr 28 06:46 app_zhushou_data2.ibd
    

     这个ibd文件一开始的大小是112k,书上不是说一次默认申请4-5个区吗,每个区固定大小1M,然后我往表中插入数据,插了几十条数据后,发现大小变为如下:

    -rw-rw---- 1 mysql mysql 8.5K Apr 28 06:44 app_zhushou_data2.frm
    -rw-rw---- 1 mysql mysql 144K Apr 28 06:57 app_zhushou_data2.ibd
    

      原来我的数据库应该是第一次申请112k大小,然后之后每次申请32K,这个之后需要确认下原因,原因找到了,书上也有写,在每个段开始时,先用32个页大小的碎片页来存放数据,用完这些碎片页之后,还是用的碎片页,仍然不是一次申请1M,妈的,这又是为啥,这篇博客算是写不完了

  • 相关阅读:
    【STM32 .NET MF开发板学习29】摄像头蓝牙图像远程获取
    【.Net MF网络开发板研究04】Socket编程之服务端
    【.Net MF网络开发板研究01】IP地址设定及简单web演示
    【.Net MF网络开发板研究02】Http Server功能演示
    用VB.net开发.NET Micro Framework
    【.Net MF网络开发板研究03】获取雅虎天气(HttpClient示例)
    js中URL编码参数(UrlEncode,UrlDecode)[ansi编码] PHP好使 简单
    PHP通过SMTP实现发送邮件_包括附件 简单
    mysql case then使用 简单
    PHP中$_SERVER的详细参数与说明 简单
  • 原文地址:https://www.cnblogs.com/xiongji/p/3694759.html
Copyright © 2011-2022 走看看