-
Notifications
You must be signed in to change notification settings - Fork 1.7k
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
MDEV-12615: InnoDB page compression method snappy mostly does not com…
…press pages Snappy compression method require that output buffer used for compression is bigger than input buffer. Similarly lzo require additional work memory buffer. Increase the allocated buffer accordingly. buf_tmp_buffer_t: removed unnecessary lzo_mem, crypt_buf_free and comp_buf_free. buf_pool_reserve_tmp_slot: use alligned_alloc and if snappy available allocate size based on snappy_max_compressed_length and if lzo is available increase buffer by LZO1X_1_15_MEM_COMPRESS. fil_compress_page: Remove unneeded lzo mem (we use same buffer) and if output buffer is not yet allocated allocate based similarly as above. Decompression does not require additional work area. Modify test to use same test as other compression method tests.
- Loading branch information
Jan Lindström
committed
May 20, 2017
1 parent
f880200
commit 90c52e5
Showing
12 changed files
with
276 additions
and
811 deletions.
There are no files selected for viewing
491 changes: 76 additions & 415 deletions
491
mysql-test/suite/innodb/r/innodb-page_compression_snappy.result
Large diffs are not rendered by default.
Oops, something went wrong.
252 changes: 6 additions & 246 deletions
252
mysql-test/suite/innodb/t/innodb-page_compression_snappy.test
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,253 +1,13 @@ | ||
-- source include/have_innodb.inc | ||
-- source include/have_innodb_snappy.inc | ||
--source include/not_embedded.inc | ||
|
||
call mtr.add_suppression("Compression failed for space*"); | ||
|
||
--disable_query_log | ||
let $innodb_compression_algorithm_orig=`select @@innodb_compression_algorithm`; | ||
let $innodb_file_format_orig = `select @@innodb_file_format`; | ||
let $innodb_file_per_table_orig = `select @@innodb_file_per_table`; | ||
--enable_query_log | ||
|
||
set global innodb_file_format = `barracuda`; | ||
set global innodb_file_per_table = on; | ||
call mtr.add_suppression("InnoDB: Compression failed for space [0-9]+ name test/innodb_page_compressed[0-9] len [0-9]+ err 2 write_size [0-9]+."); | ||
|
||
# snappy | ||
set global innodb_compression_algorithm = 6; | ||
|
||
create table innodb_compressed(c1 int, b char(20)) engine=innodb row_format=compressed key_block_size=8; | ||
show warnings; | ||
create table innodb_normal (c1 int, b char(20)) engine=innodb; | ||
show warnings; | ||
create table innodb_page_compressed1 (c1 int, b char(20)) engine=innodb page_compressed=1 page_compression_level=1; | ||
show warnings; | ||
show create table innodb_page_compressed1; | ||
create table innodb_page_compressed2 (c1 int, b char(20)) engine=innodb page_compressed=1 page_compression_level=2; | ||
show warnings; | ||
show create table innodb_page_compressed2; | ||
create table innodb_page_compressed3 (c1 int, b char(20)) engine=innodb page_compressed=1 page_compression_level=3; | ||
show warnings; | ||
show create table innodb_page_compressed3; | ||
create table innodb_page_compressed4 (c1 int, b char(20)) engine=innodb page_compressed=1 page_compression_level=4; | ||
show warnings; | ||
show create table innodb_page_compressed4; | ||
create table innodb_page_compressed5 (c1 int, b char(20)) engine=innodb page_compressed=1 page_compression_level=5; | ||
show warnings; | ||
show create table innodb_page_compressed5; | ||
create table innodb_page_compressed6 (c1 int, b char(20)) engine=innodb page_compressed=1 page_compression_level=6; | ||
show warnings; | ||
show create table innodb_page_compressed6; | ||
create table innodb_page_compressed7 (c1 int, b char(20)) engine=innodb page_compressed=1 page_compression_level=7; | ||
show warnings; | ||
show create table innodb_page_compressed7; | ||
create table innodb_page_compressed8 (c1 int, b char(20)) engine=innodb page_compressed=1 page_compression_level=8; | ||
show warnings; | ||
show create table innodb_page_compressed8; | ||
create table innodb_page_compressed9 (c1 int, b char(20)) engine=innodb page_compressed=1 page_compression_level=9; | ||
show warnings; | ||
show create table innodb_page_compressed9; | ||
delimiter //; | ||
create procedure innodb_insert_proc (repeat_count int) | ||
begin | ||
declare current_num int; | ||
set current_num = 0; | ||
while current_num < repeat_count do | ||
insert into innodb_normal values(current_num,'testing..'); | ||
set current_num = current_num + 1; | ||
end while; | ||
end// | ||
delimiter ;// | ||
commit; | ||
|
||
set autocommit=0; | ||
call innodb_insert_proc(5000); | ||
commit; | ||
set autocommit=1; | ||
select count(*) from innodb_normal; | ||
insert into innodb_compressed select * from innodb_normal; | ||
insert into innodb_page_compressed1 select * from innodb_normal; | ||
insert into innodb_page_compressed2 select * from innodb_normal; | ||
insert into innodb_page_compressed3 select * from innodb_normal; | ||
insert into innodb_page_compressed4 select * from innodb_normal; | ||
insert into innodb_page_compressed5 select * from innodb_normal; | ||
insert into innodb_page_compressed6 select * from innodb_normal; | ||
insert into innodb_page_compressed7 select * from innodb_normal; | ||
insert into innodb_page_compressed8 select * from innodb_normal; | ||
insert into innodb_page_compressed9 select * from innodb_normal; | ||
commit; | ||
select count(*) from innodb_compressed; | ||
select count(*) from innodb_page_compressed1; | ||
select count(*) from innodb_page_compressed1 where c1 < 500000; | ||
select count(*) from innodb_page_compressed2 where c1 < 500000; | ||
select count(*) from innodb_page_compressed3 where c1 < 500000; | ||
select count(*) from innodb_page_compressed4 where c1 < 500000; | ||
select count(*) from innodb_page_compressed5 where c1 < 500000; | ||
select count(*) from innodb_page_compressed6 where c1 < 500000; | ||
select count(*) from innodb_page_compressed7 where c1 < 500000; | ||
select count(*) from innodb_page_compressed8 where c1 < 500000; | ||
select count(*) from innodb_page_compressed9 where c1 < 500000; | ||
|
||
alter table innodb_normal page_compressed=1 page_compression_level=8; | ||
show warnings; | ||
show create table innodb_normal; | ||
alter table innodb_compressed row_format=default page_compressed=1 page_compression_level=8 key_block_size=0; | ||
show warnings; | ||
show create table innodb_compressed; | ||
|
||
update innodb_page_compressed1 set c1 = c1 + 1; | ||
update innodb_page_compressed2 set c1 = c1 + 1; | ||
update innodb_page_compressed3 set c1 = c1 + 1; | ||
update innodb_page_compressed4 set c1 = c1 + 1; | ||
update innodb_page_compressed5 set c1 = c1 + 1; | ||
update innodb_page_compressed6 set c1 = c1 + 1; | ||
update innodb_page_compressed7 set c1 = c1 + 1; | ||
update innodb_page_compressed8 set c1 = c1 + 1; | ||
update innodb_page_compressed9 set c1 = c1 + 1; | ||
select count(*) from innodb_compressed; | ||
select count(*) from innodb_page_compressed1; | ||
select count(*) from innodb_page_compressed1 where c1 < 500000; | ||
select count(*) from innodb_page_compressed2 where c1 < 500000; | ||
select count(*) from innodb_page_compressed3 where c1 < 500000; | ||
select count(*) from innodb_page_compressed4 where c1 < 500000; | ||
select count(*) from innodb_page_compressed5 where c1 < 500000; | ||
select count(*) from innodb_page_compressed6 where c1 < 500000; | ||
select count(*) from innodb_page_compressed7 where c1 < 500000; | ||
select count(*) from innodb_page_compressed8 where c1 < 500000; | ||
select count(*) from innodb_page_compressed9 where c1 < 500000; | ||
|
||
--source include/restart_mysqld.inc | ||
|
||
update innodb_page_compressed1 set c1 = c1 + 1; | ||
update innodb_page_compressed2 set c1 = c1 + 1; | ||
update innodb_page_compressed3 set c1 = c1 + 1; | ||
update innodb_page_compressed4 set c1 = c1 + 1; | ||
update innodb_page_compressed5 set c1 = c1 + 1; | ||
update innodb_page_compressed6 set c1 = c1 + 1; | ||
update innodb_page_compressed7 set c1 = c1 + 1; | ||
update innodb_page_compressed8 set c1 = c1 + 1; | ||
update innodb_page_compressed9 set c1 = c1 + 1; | ||
select count(*) from innodb_compressed; | ||
select count(*) from innodb_page_compressed1; | ||
select count(*) from innodb_page_compressed1 where c1 < 500000; | ||
select count(*) from innodb_page_compressed2 where c1 < 500000; | ||
select count(*) from innodb_page_compressed3 where c1 < 500000; | ||
select count(*) from innodb_page_compressed4 where c1 < 500000; | ||
select count(*) from innodb_page_compressed5 where c1 < 500000; | ||
select count(*) from innodb_page_compressed6 where c1 < 500000; | ||
select count(*) from innodb_page_compressed7 where c1 < 500000; | ||
select count(*) from innodb_page_compressed8 where c1 < 500000; | ||
select count(*) from innodb_page_compressed9 where c1 < 500000; | ||
|
||
# zlib | ||
set global innodb_compression_algorithm = 1; | ||
update innodb_page_compressed1 set c1 = c1 + 1; | ||
update innodb_page_compressed2 set c1 = c1 + 1; | ||
update innodb_page_compressed3 set c1 = c1 + 1; | ||
update innodb_page_compressed4 set c1 = c1 + 1; | ||
update innodb_page_compressed5 set c1 = c1 + 1; | ||
update innodb_page_compressed6 set c1 = c1 + 1; | ||
update innodb_page_compressed7 set c1 = c1 + 1; | ||
update innodb_page_compressed8 set c1 = c1 + 1; | ||
update innodb_page_compressed9 set c1 = c1 + 1; | ||
commit; | ||
select count(*) from innodb_compressed; | ||
select count(*) from innodb_page_compressed1; | ||
select count(*) from innodb_page_compressed1 where c1 < 500000; | ||
select count(*) from innodb_page_compressed2 where c1 < 500000; | ||
select count(*) from innodb_page_compressed3 where c1 < 500000; | ||
select count(*) from innodb_page_compressed4 where c1 < 500000; | ||
select count(*) from innodb_page_compressed5 where c1 < 500000; | ||
select count(*) from innodb_page_compressed6 where c1 < 500000; | ||
select count(*) from innodb_page_compressed7 where c1 < 500000; | ||
select count(*) from innodb_page_compressed8 where c1 < 500000; | ||
select count(*) from innodb_page_compressed9 where c1 < 500000; | ||
|
||
--source include/restart_mysqld.inc | ||
|
||
update innodb_page_compressed1 set c1 = c1 + 1; | ||
update innodb_page_compressed2 set c1 = c1 + 1; | ||
update innodb_page_compressed3 set c1 = c1 + 1; | ||
update innodb_page_compressed4 set c1 = c1 + 1; | ||
update innodb_page_compressed5 set c1 = c1 + 1; | ||
update innodb_page_compressed6 set c1 = c1 + 1; | ||
update innodb_page_compressed7 set c1 = c1 + 1; | ||
update innodb_page_compressed8 set c1 = c1 + 1; | ||
update innodb_page_compressed9 set c1 = c1 + 1; | ||
select count(*) from innodb_compressed; | ||
select count(*) from innodb_page_compressed1; | ||
select count(*) from innodb_page_compressed1 where c1 < 500000; | ||
select count(*) from innodb_page_compressed2 where c1 < 500000; | ||
select count(*) from innodb_page_compressed3 where c1 < 500000; | ||
select count(*) from innodb_page_compressed4 where c1 < 500000; | ||
select count(*) from innodb_page_compressed5 where c1 < 500000; | ||
select count(*) from innodb_page_compressed6 where c1 < 500000; | ||
select count(*) from innodb_page_compressed7 where c1 < 500000; | ||
select count(*) from innodb_page_compressed8 where c1 < 500000; | ||
select count(*) from innodb_page_compressed9 where c1 < 500000; | ||
|
||
# none | ||
set global innodb_compression_algorithm = 0; | ||
update innodb_page_compressed1 set c1 = c1 + 1; | ||
update innodb_page_compressed2 set c1 = c1 + 1; | ||
update innodb_page_compressed3 set c1 = c1 + 1; | ||
update innodb_page_compressed4 set c1 = c1 + 1; | ||
update innodb_page_compressed5 set c1 = c1 + 1; | ||
update innodb_page_compressed6 set c1 = c1 + 1; | ||
update innodb_page_compressed7 set c1 = c1 + 1; | ||
update innodb_page_compressed8 set c1 = c1 + 1; | ||
update innodb_page_compressed9 set c1 = c1 + 1; | ||
commit; | ||
select count(*) from innodb_compressed; | ||
select count(*) from innodb_page_compressed1; | ||
select count(*) from innodb_page_compressed1 where c1 < 500000; | ||
select count(*) from innodb_page_compressed2 where c1 < 500000; | ||
select count(*) from innodb_page_compressed3 where c1 < 500000; | ||
select count(*) from innodb_page_compressed4 where c1 < 500000; | ||
select count(*) from innodb_page_compressed5 where c1 < 500000; | ||
select count(*) from innodb_page_compressed6 where c1 < 500000; | ||
select count(*) from innodb_page_compressed7 where c1 < 500000; | ||
select count(*) from innodb_page_compressed8 where c1 < 500000; | ||
select count(*) from innodb_page_compressed9 where c1 < 500000; | ||
|
||
--source include/restart_mysqld.inc | ||
|
||
update innodb_page_compressed1 set c1 = c1 + 1; | ||
update innodb_page_compressed2 set c1 = c1 + 1; | ||
update innodb_page_compressed3 set c1 = c1 + 1; | ||
update innodb_page_compressed4 set c1 = c1 + 1; | ||
update innodb_page_compressed5 set c1 = c1 + 1; | ||
update innodb_page_compressed6 set c1 = c1 + 1; | ||
update innodb_page_compressed7 set c1 = c1 + 1; | ||
update innodb_page_compressed8 set c1 = c1 + 1; | ||
update innodb_page_compressed9 set c1 = c1 + 1; | ||
select count(*) from innodb_compressed; | ||
select count(*) from innodb_page_compressed1; | ||
select count(*) from innodb_page_compressed1 where c1 < 500000; | ||
select count(*) from innodb_page_compressed2 where c1 < 500000; | ||
select count(*) from innodb_page_compressed3 where c1 < 500000; | ||
select count(*) from innodb_page_compressed4 where c1 < 500000; | ||
select count(*) from innodb_page_compressed5 where c1 < 500000; | ||
select count(*) from innodb_page_compressed6 where c1 < 500000; | ||
select count(*) from innodb_page_compressed7 where c1 < 500000; | ||
select count(*) from innodb_page_compressed8 where c1 < 500000; | ||
select count(*) from innodb_page_compressed9 where c1 < 500000; | ||
set global innodb_compression_algorithm = snappy; | ||
|
||
drop procedure innodb_insert_proc; | ||
drop table innodb_normal; | ||
drop table innodb_compressed; | ||
drop table innodb_page_compressed1; | ||
drop table innodb_page_compressed2; | ||
drop table innodb_page_compressed3; | ||
drop table innodb_page_compressed4; | ||
drop table innodb_page_compressed5; | ||
drop table innodb_page_compressed6; | ||
drop table innodb_page_compressed7; | ||
drop table innodb_page_compressed8; | ||
drop table innodb_page_compressed9; | ||
# All page compression test use the same | ||
--source include/innodb-page-compression.inc | ||
|
||
# reset system | ||
--disable_query_log | ||
EVAL SET GLOBAL innodb_compression_algorithm = $innodb_compression_algorithm_orig; | ||
EVAL SET GLOBAL innodb_file_per_table = $innodb_file_per_table_orig; | ||
EVAL SET GLOBAL innodb_file_format = $innodb_file_format_orig; | ||
--enable_query_log | ||
-- echo #done |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.