mirror of
https://github.com/MariaDB/server.git
synced 2025-10-24 00:27:49 +02:00

Problem: ======= - In case of large file size, InnoDB eagerly adds the new extent even though there are many existing unused pages of the segment. Reason is that in case of larger file size, threshold (1/8 of reserved pages) for adding new extent has been reached frequently. Solution: ========= - Try to utilise the unused pages in the segment before adding the new extent in the file segment. need_for_new_extent(): In case of larger file size, try to use the 4 * FSP_EXTENT_SIZE as threshold to allocate the new extent. fseg_alloc_free_page_low(): Rewrote the function to allocate the page in the following order. 1) Try to get the page from existing segment extent. 2) Check whether the segment needs new extent (need_for_new_extent()) and allocate the new extent, find the page. 3) Take individual page from the unused page from segment or tablespace. 4) Allocate a new extent and take first page from it. Removed FSEG_FILLFACTOR, FSEG_FRAG_LIMIT variable.
122 lines
3.6 KiB
Text
122 lines
3.6 KiB
Text
SET GLOBAL innodb_adaptive_hash_index = false;
|
|
SET GLOBAL innodb_stats_persistent = false;
|
|
connect purge_control,localhost,root,,;
|
|
START TRANSACTION WITH CONSISTENT SNAPSHOT;
|
|
connect con2,localhost,root,,;
|
|
CREATE TABLE t1 (
|
|
a00 CHAR(255) NOT NULL DEFAULT 'a',
|
|
a01 CHAR(255) NOT NULL DEFAULT 'a',
|
|
a02 CHAR(255) NOT NULL DEFAULT 'a',
|
|
b INT NOT NULL DEFAULT 0,
|
|
PRIMARY KEY(a00, a01, a02)
|
|
) charset latin1 ENGINE = InnoDB COMMENT='MERGE_THRESHOLD=45';
|
|
SET GLOBAL innodb_limit_optimistic_insert_debug = 3;
|
|
CREATE PROCEDURE data_load_t1()
|
|
BEGIN
|
|
DECLARE c1 INT DEFAULT 97;
|
|
DECLARE c2 INT DEFAULT 97;
|
|
DECLARE c3 INT DEFAULT 97;
|
|
WHILE c1 < 102 DO
|
|
WHILE c2 < 123 DO
|
|
WHILE c3 < 123 DO
|
|
INSERT INTO t1 (a00) VALUES (CHAR(c1,c2,c3));
|
|
SET c3 = c3 + 1;
|
|
END WHILE;
|
|
SET c3 = 97;
|
|
SET c2 = c2 + 1;
|
|
END WHILE;
|
|
SET c2 = 97;
|
|
SET c1 = c1 + 1;
|
|
END WHILE;
|
|
END |
|
|
call data_load_t1();
|
|
DROP PROCEDURE data_load_t1;
|
|
ANALYZE TABLE t1;
|
|
Table Op Msg_type Msg_text
|
|
test.t1 analyze status Engine-independent statistics collected
|
|
test.t1 analyze status OK
|
|
SELECT CLUST_INDEX_SIZE FROM information_schema.INNODB_SYS_TABLESTATS WHERE NAME = 'test/t1';
|
|
CLUST_INDEX_SIZE
|
|
1792
|
|
connection con2;
|
|
DELETE FROM t1 WHERE a00 = 'cnm';
|
|
COMMIT;
|
|
BEGIN;
|
|
INSERT INTO t1 SET a00 = 'cnm';
|
|
connection purge_control;
|
|
COMMIT;
|
|
connection con2;
|
|
SET GLOBAL innodb_limit_optimistic_insert_debug = 0;
|
|
ROLLBACK;
|
|
# Test start
|
|
connection purge_control;
|
|
START TRANSACTION WITH CONSISTENT SNAPSHOT;
|
|
connection con2;
|
|
DELETE FROM t1 WHERE a00 = 'bii';
|
|
COMMIT;
|
|
BEGIN;
|
|
INSERT INTO t1 SET a00 = 'bii';
|
|
SET DEBUG_SYNC = 'rollback_undo_pk SIGNAL roll1_wait WAIT_FOR roll2';
|
|
SET DEBUG_SYNC = 'rollback_purge_clust SIGNAL rollback_waiting WAIT_FOR resume';
|
|
ROLLBACK;
|
|
connection purge_control;
|
|
SET DEBUG_SYNC = 'now WAIT_FOR roll1_wait';
|
|
COMMIT;
|
|
SET DEBUG_SYNC = 'now SIGNAL roll2';
|
|
connect con1,localhost,root,,;
|
|
SET DEBUG_SYNC = 'now WAIT_FOR rollback_waiting TIMEOUT 1';
|
|
SET DEBUG_SYNC = 'rw_s_lock_waiting SIGNAL lockwait1';
|
|
SELECT a00 FROM t1 WHERE a00 = 'bii';
|
|
connection default;
|
|
SET DEBUG_SYNC = 'now WAIT_FOR lockwait1 TIMEOUT 1';
|
|
SET DEBUG_SYNC = 'now SIGNAL resume';
|
|
connection con1;
|
|
a00
|
|
connection con2;
|
|
connection default;
|
|
ANALYZE TABLE t1;
|
|
Table Op Msg_type Msg_text
|
|
test.t1 analyze status Engine-independent statistics collected
|
|
test.t1 analyze status OK
|
|
SELECT CLUST_INDEX_SIZE FROM information_schema.INNODB_SYS_TABLESTATS WHERE NAME = 'test/t1';
|
|
CLUST_INDEX_SIZE
|
|
1792
|
|
DELETE FROM t1 WHERE a00 = 'dpn';
|
|
COMMIT;
|
|
INSERT INTO t1 SET a00 = 'dpn';
|
|
ROLLBACK;
|
|
ALTER TABLE t1 COMMENT='MERGE_THRESHOLD=35';
|
|
connection purge_control;
|
|
START TRANSACTION WITH CONSISTENT SNAPSHOT;
|
|
connection con2;
|
|
DELETE FROM t1 WHERE a00 = 'cnd';
|
|
COMMIT;
|
|
BEGIN;
|
|
INSERT INTO t1 SET a00 = 'cnd';
|
|
SET DEBUG_SYNC = 'rollback_undo_pk SIGNAL roll1_wait WAIT_FOR roll2';
|
|
SET DEBUG_SYNC = 'rollback_purge_clust SIGNAL rollback_waiting WAIT_FOR resume EXECUTE 2';
|
|
ROLLBACK;
|
|
connection purge_control;
|
|
SET DEBUG_SYNC = 'now WAIT_FOR roll1_wait';
|
|
START TRANSACTION WITH CONSISTENT SNAPSHOT;
|
|
SET DEBUG_SYNC = 'now SIGNAL roll2';
|
|
connection con1;
|
|
SET DEBUG_SYNC = 'now WAIT_FOR rollback_waiting TIMEOUT 1';
|
|
SET DEBUG_SYNC = 'now SIGNAL resume';
|
|
SET DEBUG_SYNC = 'now WAIT_FOR rollback_waiting TIMEOUT 1';
|
|
disconnect purge_control;
|
|
connection default;
|
|
SET DEBUG_SYNC = 'now SIGNAL resume';
|
|
disconnect con1;
|
|
connection con2;
|
|
disconnect con2;
|
|
connection default;
|
|
ANALYZE TABLE t1;
|
|
Table Op Msg_type Msg_text
|
|
test.t1 analyze status Engine-independent statistics collected
|
|
test.t1 analyze status OK
|
|
SELECT CLUST_INDEX_SIZE FROM information_schema.INNODB_SYS_TABLESTATS WHERE NAME = 'test/t1';
|
|
CLUST_INDEX_SIZE
|
|
1792
|
|
SET DEBUG_SYNC = 'RESET';
|
|
DROP TABLE t1;
|