zoukankan      html  css  js  c++  java
  • MySQL不同存储引擎下optimize的用法

    optimize命令是mysql的常用优化命令,但是在InnoDB与MyISAM这两个存储引擎中却有很大的分别。本文将对这两个常用的存储引擎进行区分跟实例解析

      1、查看mysql当前的存储引擎

    一般情况下,mysql会默认提供多种存储引擎,你可以通过下面的查看:
     
    看你的mysql现在已提供什么存储引擎:
    mysql> show engines;
     
    看你的mysql当前默认的存储引擎:
    mysql> show variables like '%storage_engine%';
     
    你要看某个表用了什么引擎(在显示结果里参数engine后面的就表示该表当前用的存储引擎):
    mysql> show create table 表名;

    如下显示zabbix history表的存储引擎

    MariaDB [zabbix]> show create table history G;
    *************************** 1. row ***************************
    Table: history
    Create Table: CREATE TABLE `history` (
    `itemid` bigint(20) unsigned NOT NULL,
    `clock` int(11) NOT NULL DEFAULT '0',
    `value` double(16,4) NOT NULL DEFAULT '0.0000',
    `ns` int(11) NOT NULL DEFAULT '0',
    KEY `history_1` (`itemid`,`clock`)
    ) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_bin
    /*!50100 PARTITION BY RANGE (`clock`)
    (PARTITION p201802010000 VALUES LESS THAN (1517500800) ENGINE = InnoDB,
    PARTITION p201802020000 VALUES LESS THAN (1517587200) ENGINE = InnoDB,
    PARTITION p201802030000 VALUES LESS THAN (1517673600) ENGINE = InnoDB,
    PARTITION p201802040000 VALUES LESS THAN (1517760000) ENGINE = InnoDB,
    PARTITION p201802050000 VALUES LESS THAN (1517846400) ENGINE = InnoDB,
    PARTITION p201802070000 VALUES LESS THAN (1518019200) ENGINE = InnoDB,
    PARTITION p201802080000 VALUES LESS THAN (1518105600) ENGINE = InnoDB,
    PARTITION p201802090000 VALUES LESS THAN (1518192000) ENGINE = InnoDB,
    PARTITION p201802100000 VALUES LESS THAN (1518278400) ENGINE = InnoDB,
    PARTITION p201802110000 VALUES LESS THAN (1518364800) ENGINE = InnoDB,
    PARTITION p201802120000 VALUES LESS THAN (1518451200) ENGINE = InnoDB,
    PARTITION p201802130000 VALUES LESS THAN (1518537600) ENGINE = InnoDB,
    PARTITION p201802140000 VALUES LESS THAN (1518624000) ENGINE = InnoDB,
    PARTITION p201802150000 VALUES LESS THAN (1518710400) ENGINE = InnoDB,
    PARTITION p201802160000 VALUES LESS THAN (1518796800) ENGINE = InnoDB,
    PARTITION p201802170000 VALUES LESS THAN (1518883200) ENGINE = InnoDB,
    PARTITION p201802180000 VALUES LESS THAN (1518969600) ENGINE = InnoDB,
    PARTITION p201802190000 VALUES LESS THAN (1519056000) ENGINE = InnoDB,
    PARTITION p201802200000 VALUES LESS THAN (1519142400) ENGINE = InnoDB,
    PARTITION p201802210000 VALUES LESS THAN (1519228800) ENGINE = InnoDB) */
    1 row in set (0.00 sec)

     当对表有大量的增删改操作时,需要用optimize对表进行优化。可以减少空间与提高I/O性能性能;

    如果表存储引擎为MyISAM可以直接使用命令optimize table 表名;

    查看show table status like 'history' G; 中的data_free选项;data_free选项代表数据碎片。 

    如果是InnoDB引擎,首先查看innodb_file_per_table(是否独享表空间)。

    MariaDB [zabbix]> show variables like 'innodb_file_per_table';
    +-----------------------+-------+
    | Variable_name         | Value |
    +-----------------------+-------+
    | innodb_file_per_table | ON    |
    +-----------------------+-------+
    1 row in set (0.01 sec)

    ON代表共享表空间打开,OFF代表开启共享表空间没有打开,即采用的是默认的共享表空间。这个时候可以在mysql的datadir路径下看到一个非常大的文件ibdata1,这个文件存储了所有InnoDB表的数据与索引。

    如果表是InnoDB,执行如下命令

    MariaDB [zabbix]>  optimize table history;
    +----------------+----------+----------+-------------------------------------------------------------------+
    | Table          | Op       | Msg_type | Msg_text                                                          |
    +----------------+----------+----------+-------------------------------------------------------------------+
    | zabbix.history | optimize | note     | Table does not support optimize, doing recreate + analyze instead |
    | zabbix.history | optimize | status   | OK                                                                |
    +----------------+----------+----------+-------------------------------------------------------------------+
    2 rows in set (14.33 sec)

    会返回如图信息,最后的一条Table does not support optimize, doing recreate + analyze instead,即代表optimize无法优化表。

    这个时候使用如下命令优化表

    MariaDB [zabbix]> alter table history  ENGINE = 'InnoDB';
    Query OK, 256060 rows affected (14.27 sec)             
    Records: 256060  Duplicates: 0  Warnings: 0
    
    MariaDB [zabbix]> analyze table history;
    +----------------+---------+----------+----------+
    | Table          | Op      | Msg_type | Msg_text |
    +----------------+---------+----------+----------+
    | zabbix.history | analyze | status   | OK       |
    +----------------+---------+----------+----------+
    1 row in set (0.00 sec)
    1. 如果开启了独享表空间,即每张表都有ibdfile。这个时候如果删除了大量的行,索引会重组并且会释放相应的空间因此不必优化

    2. 由于共享表空间所有表的数据与索引都存放于ibddata1文件中,随着数据量的增长会导致该文件越来越大。超过10G的时候查询速度就非常慢,因此在编译的时候最好开启独享表空间。因为mysql默认是关闭了独享表空间,下面有两个解决方案
    3. 方案一:先逻辑备份所有的数据库,将配置文件中innodb_file_per_table参数=1,再将备份导入
    4. 方案二:只要修改innodb_file_per_table参数,然后将需要修改的所有innodb的表都运行一遍 alter table table_name engine=innodb;即可使用第二种方式修改后,原来库中的表中的数据会继续存放于ibdata1中,新建的表才会使用独立表空间
  • 相关阅读:
    Java虚拟机一览表
    Java程序员的10道XML面试题
    bzoj 1644: [Usaco2007 Oct]Obstacle Course 障碍训练课【spfa】
    bzoj 1703: [Usaco2007 Mar]Ranking the Cows 奶牛排名【bitset+Floyd传递闭包】
    bzoj 1664: [Usaco2006 Open]County Fair Events 参加节日庆祝【dp+树状数组】
    bzoj 2100: [Usaco2010 Dec]Apple Delivery【spfa】
    bzoj 2015: [Usaco2010 Feb]Chocolate Giving【spfa】
    bzoj 1741: [Usaco2005 nov]Asteroids 穿越小行星群【最大点覆盖】
    bzoj 1645: [Usaco2007 Open]City Horizon 城市地平线【线段树+hash】
    bzoj 2060: [Usaco2010 Nov]Visiting Cows 拜访奶牛【树形dp】
  • 原文地址:https://www.cnblogs.com/w787815/p/8433548.html
Copyright © 2011-2022 走看看