ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

myisampack工具(MyISAM表压缩工具)

2021-04-13 08:51:47  阅读:256  来源: 互联网

标签:myisampack rw 压缩工具 17 压缩 ---- MyISAM mysql


myisampack工具(MyISAM表压缩工具)


适用范围

如果表在创建并导入数据以后,不会再进行修改操作,这样的表适合采用MyISAM压缩表2

 

好处

极大减少磁盘空间占用,因此减少磁盘的I/O,从而提升查询性能。

 

注意事项

压缩后的表是不能进行修改的(除非先将表解除压缩,修改数据,然后再次压缩)。压缩表支持索引,但索引也是只读的。2

 

压缩方法

使用myisampack对MyISAM表进行压缩(也叫打包)。

 
 

myisampack工具可以压缩MyISAM表.MYIsampack分别压缩表中的每一列。通常,myisampack可以将数据文件压缩到40%-70%。

当以后使用表时,解压缩列需要的信息被读入内存。当访问具体的记录时性能会更好,因为你只需要解压缩一个记录。

MySQL使用mmap()对压缩的表进行内存映射。如果mmap()不工作,MySQL返回到普通读/写文件操作。

请注意:

  • 如果用--skip-external-locking选项调用mysqld服务器,如果在压缩过程中表可能被更新,调用myisampack不是一个好注意。
  • 表压缩后,它变为只读。这是故意的(例如当访问CD上的压缩的表时)。允许写入到压缩的表位于我们的TODO列表中,但优先级较低。

     Myisampack的使用方式:

     /opt/mysql/bin/myisampack /opt/mysql/data/test/test

    

    运行myisampack后,必须运行myisamchk以重新创建索引。此时,你也可以排序索引块并创建MySQL优化器需要的统计信息以更有效地工作: 

 

    myisamchk的使用方法:

 

    myisamchk [OPTIONS] tables[.MYI]

 

    只能对MyISAM 存储引擎的索引文件有效


 



一、 简介

myisampack是一个压缩使用MyISAM引擎表的工具,一般会压缩40%~70%,当需要访问数据,服务器会将所需要的信息读入到内存中,所以当访问具体记录时,性能会更好,因为只需要解压一条记录

MySQL使用mmap()对变哦进行压缩映射,如果mmap()不工作,MySQL会返回到普通的读写文件操作

压缩后的表将会成为只读的,并且myisampack不支持分区表。

二、 命令格式

myisampack 选项 文件名

三、 常用参

--backup-b --backup 使用tbl_name .OLD备份数据文件

--force -f 产生一个压缩的表,即使它比原始表大,或如果以前调用myisampack的中间文件存在。(myisampack压缩表时在数据库目录中创建一个名为tbl_name.TMD的中间文件。如果杀掉myisampack,.TMD文件会被删除)。通常情况,如果myisampack发现tbl_name.TMD存在则退出并提示错误。用--force,myisampack则一定压缩表。

--join=big_tbl_name -j big_tbl_name 将命令行中的所有表联接为一个表big_tbl_name。将要连接的所有表必须有相等的结构(相同的列名和类型,相同的索引等等)。

--packlength=len,-p len 指定记录长度存储大小,以字节计。值应为1、2或者3。myisampack保存所有长度指针为1、2或者3字节的行。在大多数正常情况下,myisampack在开始压缩文件前可以确定准确的长度值,但在压缩过程中它可以提示它可能已经使用了一个短的长度。在这种情况下,myisampack输出一条提示,下次你压缩同一文件时,你可以使用更短的记录长度。

--silent,-s 沉默模式。只有发生错误时才写输出。

--test,-t 没有实际地压缩表,只是测试压缩。

--tmpdir=path,-T path 使用myisamchk创建临时文件的目录。

--verbose,-v 冗长模式。写压缩操作过程相关信息和其结果。

--version,-V 显示版本信息并退出。

--wait,-w 如果表正使用则等待并重试。如果用--skip-external-locking选项调用了mysqld服务器,如果在压缩过程中表可能被更新,调用myisampack不是一个好主意。

运行myisampack后,必须运行myisamchk以重新创建索引。此时,你也可以排序索引块并创建MySQL优化器需要的统计信息以更有效地工作: shell> myisamchk -rq --sort-index--analyze tbl_name.MYI 将压缩的表安装到MySQL数据库目录中后,应执行mysqladmin flush-tables以强制mysqld使用新的表。 要想解压缩一个压缩的表,使用myisamchk或isamchk的--unpack选项。

 

--help 帮助

 

四、 常用例子

1. myisampack压缩表

[root@localhosttest2]# ll -tr

总用量 180

-rw-rw---- 1 mysql mysql 65 7月 16 16:40 db.opt

-rw-rw---- 1 mysql mysql 8556 7月 16 16:46 t1.frm

-rw-rw---- 1 mysql mysql 1024 7月 16 17:29 t1.MYI

-rw-rw---- 1 mysql mysql 161742 7月 16 17:29 t1.MYD

[root@localhost test2]# myisampack t1

Compressing t1.MYD: (23106 records)

- Calculating statistics

- Compressing file

85.68%

[root@localhosttest2]# ll -tr

总用量 44

-rw-rw---- 1 mysql mysql 65 7月 16 16:40 db.opt

-rw-rw---- 1 mysql mysql 8556 7月 16 16:46 t1.frm

-rw-rw---- 1 mysql mysql 23167 7月 16 17:29 t1.MYD

-rw-rw---- 1 mysql mysql 1024 7月 16 17:30 t1.MYI

 

在Mysql中查询

mysql>show table status like 't1'\G;

*************************** 1. row***************************

Name: t1

Engine: MyISAM

Version: 10

Row_format: Fixed

Rows: 22857

Avg_row_length: 7

Data_length: 159999

Max_data_length: 1970324836974591

Index_length: 1024

Data_free: 0

Auto_increment: NULL

Create_time: 2015-07-16 16:46:17

Update_time: 2015-07-16 17:29:40

Check_time: NULL

Collation: latin1_swedish_ci

Checksum: NULL

Create_options:

Comment:

1 row in set (0.00 sec)

 

ERROR:

No query specified

 

mysql>show table status like 't1'\G;

*************************** 1. row***************************

Name: t1

Engine: MyISAM

Version: 10

Row_format: Fixed

Rows: 23177

Avg_row_length: 7

Data_length: 162239

Max_data_length: 1970324836974591

Index_length: 1024

Data_free: 0

Auto_increment: NULL

Create_time: 2015-07-16 16:46:17

Update_time: 2015-07-16 17:30:48

Check_time: NULL

Collation: latin1_swedish_ci

Checksum: NULL

Create_options:

Comment:

1 row in set (0.00 sec)

t8 lines: 7 columns: 9

2. myisampack备份数据库文件

[root@localhost test2]# ll

-rw-rw---- 1 mysql mysql 65 7月 16 16:40 db.opt

-rw-rw---- 1 mysql mysql 8572 7月 17 09:28 t1.frm

-rw-rw---- 1 mysql mysql 73 7月 17 09:50 t1.MYD

-rw-rw---- 1 mysql mysql 1024 7月 17 10:04 t1.MYI

-rw-rw---- 1 mysql mysql 217月 17 09:50 t1.OLD

-rw-rw---- 1 mysql mysql 8598 7月 17 10:10 t2.frm

-rw-rw---- 1 mysql mysql4344192 7月 17 10:11 t2.MYD

-rw-rw---- 1 mysql mysql 4955136 7月 17 10:11 t2.MYI

-rw-rw---- 1 mysql mysql 8572 7月 17 10:06 t3.frm

-rw-rw---- 1 mysql mysql 147456 7月 17 10:06 t3.ibd

-rw-rw---- 1 mysql mysql 8598 7月 17 10:11 t4.frm

-rw-rw---- 1 mysql mysql 4344192 7月 17 10:11 t4.MYD

-rw-rw---- 1 mysql mysql 1024 7月 17 10:11 t4.MYI

-rw-rw---- 1 mysql mysql 8598 7月 17 10:12 t5.frm

-rw-rw---- 1 mysql mysql 1996157 7月 17 10:12 t5.MYD

-rw-rw---- 1 mysql mysql 1024 7月 17 10:12 t5.MYI

-rw-rw---- 1 mysql mysql4344192 7月 17 10:12 t5.OLD

我们发现备份出来的数据文件与原来的文件大小一致,但是压缩后的数据文件会小一些

 

3. 向T5中插入数据

 

mysql> insert into t5(str_number)values(1);

ERROR 1036 (HY000): Table 't5' is read only

   

标签:myisampack,rw,压缩工具,17,压缩,----,MyISAM,mysql
来源: https://blog.51cto.com/lhrbest/2702383

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有