您好,欢迎来到三六零分类信息网!老站,搜索引擎当天收录,欢迎发信息

每天进步一点达MySQLmyisampack_MySQL

2024/11/11 13:46:57发布22次查看
一、 简介
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
该用户其它信息

VIP推荐

免费发布信息,免费发布B2B信息网站平台 - 三六零分类信息网 沪ICP备09012988号-2
企业名录 Product