Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
M
MariaDB
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Analytics
Analytics
CI / CD
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
nexedi
MariaDB
Commits
1bd65d77
Commit
1bd65d77
authored
Sep 30, 2004
by
marko@hundin.mysql.fi
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
InnoDB: implement innodb_max_purge_lag
parent
9f92688b
Changes
9
Hide whitespace changes
Inline
Side-by-side
Showing
9 changed files
with
82 additions
and
1 deletion
+82
-1
innobase/include/srv0srv.h
innobase/include/srv0srv.h
+3
-0
innobase/include/trx0sys.h
innobase/include/trx0sys.h
+4
-0
innobase/row/row0mysql.c
innobase/row/row0mysql.c
+17
-0
innobase/srv/srv0srv.c
innobase/srv/srv0srv.c
+6
-0
innobase/trx/trx0purge.c
innobase/trx/trx0purge.c
+35
-0
innobase/trx/trx0rseg.c
innobase/trx/trx0rseg.c
+6
-1
sql/ha_innodb.h
sql/ha_innodb.h
+1
-0
sql/mysqld.cc
sql/mysqld.cc
+6
-0
sql/set_var.cc
sql/set_var.cc
+4
-0
No files found.
innobase/include/srv0srv.h
View file @
1bd65d77
...
@@ -110,6 +110,8 @@ extern int srv_query_thread_priority;
...
@@ -110,6 +110,8 @@ extern int srv_query_thread_priority;
extern
ibool
srv_use_awe
;
extern
ibool
srv_use_awe
;
extern
ibool
srv_use_adaptive_hash_indexes
;
extern
ibool
srv_use_adaptive_hash_indexes
;
extern
ulint
srv_max_purge_lag
;
/*-------------------------------------------*/
/*-------------------------------------------*/
extern
ulint
srv_n_rows_inserted
;
extern
ulint
srv_n_rows_inserted
;
...
@@ -163,6 +165,7 @@ extern ulint srv_test_array_size;
...
@@ -163,6 +165,7 @@ extern ulint srv_test_array_size;
extern
ulint
srv_activity_count
;
extern
ulint
srv_activity_count
;
extern
ulint
srv_fatal_semaphore_wait_threshold
;
extern
ulint
srv_fatal_semaphore_wait_threshold
;
extern
ulint
srv_dml_needed_delay
;
extern
mutex_t
*
kernel_mutex_temp
;
/* mutex protecting the server, trx structs,
extern
mutex_t
*
kernel_mutex_temp
;
/* mutex protecting the server, trx structs,
query threads, and lock table: we allocate
query threads, and lock table: we allocate
...
...
innobase/include/trx0sys.h
View file @
1bd65d77
...
@@ -432,6 +432,10 @@ struct trx_sys_struct{
...
@@ -432,6 +432,10 @@ struct trx_sys_struct{
trx_rseg_t
*
rseg_array
[
TRX_SYS_N_RSEGS
];
trx_rseg_t
*
rseg_array
[
TRX_SYS_N_RSEGS
];
/* Pointer array to rollback segments;
/* Pointer array to rollback segments;
NULL if slot not in use */
NULL if slot not in use */
ulint
rseg_history_len
;
/* Length of the TRX_RSEG_HISTORY
list (update undo logs for committed
transactions), protected by
rseg->mutex */
UT_LIST_BASE_NODE_T
(
read_view_t
)
view_list
;
UT_LIST_BASE_NODE_T
(
read_view_t
)
view_list
;
/* List of read views sorted on trx no,
/* List of read views sorted on trx no,
biggest first */
biggest first */
...
...
innobase/row/row0mysql.c
View file @
1bd65d77
...
@@ -92,6 +92,19 @@ row_mysql_is_system_table(
...
@@ -92,6 +92,19 @@ row_mysql_is_system_table(
||
0
==
strcmp
(
name
+
6
,
"user"
)
||
0
==
strcmp
(
name
+
6
,
"user"
)
||
0
==
strcmp
(
name
+
6
,
"db"
));
||
0
==
strcmp
(
name
+
6
,
"db"
));
}
}
/***********************************************************************
Delays an INSERT, DELETE or UPDATE operation if the purge is lagging. */
static
void
row_mysql_delay_if_needed
(
void
)
/*===========================*/
{
if
(
srv_dml_needed_delay
)
{
os_thread_sleep
(
srv_dml_needed_delay
);
}
}
/***********************************************************************
/***********************************************************************
Reads a MySQL format variable-length field (like VARCHAR) length and
Reads a MySQL format variable-length field (like VARCHAR) length and
returns pointer to the field data. */
returns pointer to the field data. */
...
@@ -873,6 +886,8 @@ row_insert_for_mysql(
...
@@ -873,6 +886,8 @@ row_insert_for_mysql(
trx
->
op_info
=
"inserting"
;
trx
->
op_info
=
"inserting"
;
row_mysql_delay_if_needed
();
trx_start_if_not_started
(
trx
);
trx_start_if_not_started
(
trx
);
if
(
node
==
NULL
)
{
if
(
node
==
NULL
)
{
...
@@ -1088,6 +1103,8 @@ row_update_for_mysql(
...
@@ -1088,6 +1103,8 @@ row_update_for_mysql(
trx
->
op_info
=
"updating or deleting"
;
trx
->
op_info
=
"updating or deleting"
;
row_mysql_delay_if_needed
();
trx_start_if_not_started
(
trx
);
trx_start_if_not_started
(
trx
);
node
=
prebuilt
->
upd_node
;
node
=
prebuilt
->
upd_node
;
...
...
innobase/srv/srv0srv.c
View file @
1bd65d77
...
@@ -58,6 +58,10 @@ ulint srv_activity_count = 0;
...
@@ -58,6 +58,10 @@ ulint srv_activity_count = 0;
/* The following is the maximum allowed duration of a lock wait. */
/* The following is the maximum allowed duration of a lock wait. */
ulint
srv_fatal_semaphore_wait_threshold
=
600
;
ulint
srv_fatal_semaphore_wait_threshold
=
600
;
/* How much data manipulation language (DML) statements need to be delayed,
in microseconds, in order to reduce the lagging of the purge thread. */
ulint
srv_dml_needed_delay
=
0
;
ibool
srv_lock_timeout_and_monitor_active
=
FALSE
;
ibool
srv_lock_timeout_and_monitor_active
=
FALSE
;
ibool
srv_error_monitor_active
=
FALSE
;
ibool
srv_error_monitor_active
=
FALSE
;
...
@@ -258,6 +262,8 @@ disable adaptive hash indexes */
...
@@ -258,6 +262,8 @@ disable adaptive hash indexes */
ibool
srv_use_awe
=
FALSE
;
ibool
srv_use_awe
=
FALSE
;
ibool
srv_use_adaptive_hash_indexes
=
TRUE
;
ibool
srv_use_adaptive_hash_indexes
=
TRUE
;
/* Maximum allowable purge history length. <=0 means 'infinite'. */
ulint
srv_max_purge_lag
=
0
;
/*-------------------------------------------*/
/*-------------------------------------------*/
ulint
srv_n_spin_wait_rounds
=
20
;
ulint
srv_n_spin_wait_rounds
=
20
;
...
...
innobase/trx/trx0purge.c
View file @
1bd65d77
...
@@ -295,6 +295,9 @@ trx_purge_add_update_undo_to_history(
...
@@ -295,6 +295,9 @@ trx_purge_add_update_undo_to_history(
/* Add the log as the first in the history list */
/* Add the log as the first in the history list */
flst_add_first
(
rseg_header
+
TRX_RSEG_HISTORY
,
flst_add_first
(
rseg_header
+
TRX_RSEG_HISTORY
,
undo_header
+
TRX_UNDO_HISTORY_NODE
,
mtr
);
undo_header
+
TRX_UNDO_HISTORY_NODE
,
mtr
);
mutex_enter
(
&
kernel_mutex
);
trx_sys
->
rseg_history_len
++
;
mutex_exit
(
&
kernel_mutex
);
/* Write the trx number to the undo log header */
/* Write the trx number to the undo log header */
mlog_write_dulint
(
undo_header
+
TRX_UNDO_TRX_NO
,
trx
->
no
,
mtr
);
mlog_write_dulint
(
undo_header
+
TRX_UNDO_TRX_NO
,
trx
->
no
,
mtr
);
...
@@ -386,6 +389,12 @@ trx_purge_free_segment(
...
@@ -386,6 +389,12 @@ trx_purge_free_segment(
flst_cut_end
(
rseg_hdr
+
TRX_RSEG_HISTORY
,
flst_cut_end
(
rseg_hdr
+
TRX_RSEG_HISTORY
,
log_hdr
+
TRX_UNDO_HISTORY_NODE
,
n_removed_logs
,
&
mtr
);
log_hdr
+
TRX_UNDO_HISTORY_NODE
,
n_removed_logs
,
&
mtr
);
mutex_enter
(
&
kernel_mutex
);
ut_ad
(
trx_sys
->
rseg_history_len
>=
n_removed_logs
);
trx_sys
->
rseg_history_len
-=
n_removed_logs
;
mutex_exit
(
&
kernel_mutex
);
freed
=
FALSE
;
freed
=
FALSE
;
while
(
!
freed
)
{
while
(
!
freed
)
{
...
@@ -470,6 +479,11 @@ trx_purge_truncate_rseg_history(
...
@@ -470,6 +479,11 @@ trx_purge_truncate_rseg_history(
}
}
if
(
cmp
>=
0
)
{
if
(
cmp
>=
0
)
{
mutex_enter
(
&
kernel_mutex
);
ut_a
(
trx_sys
->
rseg_history_len
>=
n_removed_logs
);
trx_sys
->
rseg_history_len
-=
n_removed_logs
;
mutex_exit
(
&
kernel_mutex
);
flst_truncate_end
(
rseg_hdr
+
TRX_RSEG_HISTORY
,
flst_truncate_end
(
rseg_hdr
+
TRX_RSEG_HISTORY
,
log_hdr
+
TRX_UNDO_HISTORY_NODE
,
log_hdr
+
TRX_UNDO_HISTORY_NODE
,
n_removed_logs
,
&
mtr
);
n_removed_logs
,
&
mtr
);
...
@@ -1031,6 +1045,27 @@ trx_purge(void)
...
@@ -1031,6 +1045,27 @@ trx_purge(void)
purge_sys
->
view
=
NULL
;
purge_sys
->
view
=
NULL
;
mem_heap_empty
(
purge_sys
->
heap
);
mem_heap_empty
(
purge_sys
->
heap
);
/* Determine how much data manipulation language (DML) statements
need to be delayed in order to reduce the lagging of the purge
thread. */
srv_dml_needed_delay
=
0
;
/* in microseconds; default: no delay */
/* If we cannot advance the 'purge view' because of an old
'consistent read view', then the DML statements cannot be delayed.
Also, srv_max_purge_lag <= 0 means 'infinity'. */
if
(
srv_max_purge_lag
>
0
&&
!
UT_LIST_GET_LAST
(
trx_sys
->
view_list
))
{
float
ratio
=
(
float
)
trx_sys
->
rseg_history_len
/
srv_max_purge_lag
;
if
(
ratio
>
1
)
{
/* If the history list length exceeds the
innodb_max_purge_lag, the
data manipulation statements are delayed
by at least 5000 microseconds. */
srv_dml_needed_delay
=
(
ratio
-
.
5
)
*
10000
;
}
}
purge_sys
->
view
=
read_view_oldest_copy_or_open_new
(
NULL
,
purge_sys
->
view
=
read_view_oldest_copy_or_open_new
(
NULL
,
purge_sys
->
heap
);
purge_sys
->
heap
);
mutex_exit
(
&
kernel_mutex
);
mutex_exit
(
&
kernel_mutex
);
...
...
innobase/trx/trx0rseg.c
View file @
1bd65d77
...
@@ -135,6 +135,7 @@ trx_rseg_mem_create(
...
@@ -135,6 +135,7 @@ trx_rseg_mem_create(
trx_ulogf_t
*
undo_log_hdr
;
trx_ulogf_t
*
undo_log_hdr
;
fil_addr_t
node_addr
;
fil_addr_t
node_addr
;
ulint
sum_of_undo_sizes
;
ulint
sum_of_undo_sizes
;
ulint
len
;
#ifdef UNIV_SYNC_DEBUG
#ifdef UNIV_SYNC_DEBUG
ut_ad
(
mutex_own
(
&
kernel_mutex
));
ut_ad
(
mutex_own
(
&
kernel_mutex
));
...
@@ -166,7 +167,9 @@ trx_rseg_mem_create(
...
@@ -166,7 +167,9 @@ trx_rseg_mem_create(
MLOG_4BYTES
,
mtr
)
MLOG_4BYTES
,
mtr
)
+
1
+
sum_of_undo_sizes
;
+
1
+
sum_of_undo_sizes
;
if
(
flst_get_len
(
rseg_header
+
TRX_RSEG_HISTORY
,
mtr
)
>
0
)
{
len
=
flst_get_len
(
rseg_header
+
TRX_RSEG_HISTORY
,
mtr
);
if
(
len
>
0
)
{
trx_sys
->
rseg_history_len
+=
len
;
node_addr
=
trx_purge_get_log_from_hist
(
node_addr
=
trx_purge_get_log_from_hist
(
flst_get_last
(
rseg_header
+
TRX_RSEG_HISTORY
,
flst_get_last
(
rseg_header
+
TRX_RSEG_HISTORY
,
...
@@ -206,6 +209,8 @@ trx_rseg_list_and_array_init(
...
@@ -206,6 +209,8 @@ trx_rseg_list_and_array_init(
UT_LIST_INIT
(
trx_sys
->
rseg_list
);
UT_LIST_INIT
(
trx_sys
->
rseg_list
);
trx_sys
->
rseg_history_len
=
0
;
for
(
i
=
0
;
i
<
TRX_SYS_N_RSEGS
;
i
++
)
{
for
(
i
=
0
;
i
<
TRX_SYS_N_RSEGS
;
i
++
)
{
page_no
=
trx_sysf_rseg_get_page_no
(
sys_header
,
i
,
mtr
);
page_no
=
trx_sysf_rseg_get_page_no
(
sys_header
,
i
,
mtr
);
...
...
sql/ha_innodb.h
View file @
1bd65d77
...
@@ -194,6 +194,7 @@ extern my_bool innobase_log_archive,
...
@@ -194,6 +194,7 @@ extern my_bool innobase_log_archive,
extern
"C"
{
extern
"C"
{
extern
ulong
srv_max_buf_pool_modified_pct
;
extern
ulong
srv_max_buf_pool_modified_pct
;
extern
ulong
srv_auto_extend_increment
;
extern
ulong
srv_auto_extend_increment
;
extern
ulong
srv_max_purge_lag
;
}
}
extern
TYPELIB
innobase_lock_typelib
;
extern
TYPELIB
innobase_lock_typelib
;
...
...
sql/mysqld.cc
View file @
1bd65d77
...
@@ -3998,6 +3998,7 @@ enum options_mysqld
...
@@ -3998,6 +3998,7 @@ enum options_mysqld
OPT_INNODB_BUFFER_POOL_SIZE
,
OPT_INNODB_BUFFER_POOL_SIZE
,
OPT_INNODB_BUFFER_POOL_AWE_MEM_MB
,
OPT_INNODB_BUFFER_POOL_AWE_MEM_MB
,
OPT_INNODB_ADDITIONAL_MEM_POOL_SIZE
,
OPT_INNODB_ADDITIONAL_MEM_POOL_SIZE
,
OPT_INNODB_MAX_PURGE_LAG
,
OPT_INNODB_FILE_IO_THREADS
,
OPT_INNODB_FILE_IO_THREADS
,
OPT_INNODB_LOCK_WAIT_TIMEOUT
,
OPT_INNODB_LOCK_WAIT_TIMEOUT
,
OPT_INNODB_THREAD_CONCURRENCY
,
OPT_INNODB_THREAD_CONCURRENCY
,
...
@@ -4233,6 +4234,11 @@ Disable with --skip-innodb (will save memory).",
...
@@ -4233,6 +4234,11 @@ Disable with --skip-innodb (will save memory).",
{
"innodb_max_dirty_pages_pct"
,
OPT_INNODB_MAX_DIRTY_PAGES_PCT
,
{
"innodb_max_dirty_pages_pct"
,
OPT_INNODB_MAX_DIRTY_PAGES_PCT
,
"Percentage of dirty pages allowed in bufferpool."
,
(
gptr
*
)
&
srv_max_buf_pool_modified_pct
,
"Percentage of dirty pages allowed in bufferpool."
,
(
gptr
*
)
&
srv_max_buf_pool_modified_pct
,
(
gptr
*
)
&
srv_max_buf_pool_modified_pct
,
0
,
GET_ULONG
,
REQUIRED_ARG
,
90
,
0
,
100
,
0
,
0
,
0
},
(
gptr
*
)
&
srv_max_buf_pool_modified_pct
,
0
,
GET_ULONG
,
REQUIRED_ARG
,
90
,
0
,
100
,
0
,
0
,
0
},
{
"innodb_max_purge_lag"
,
OPT_INNODB_MAX_PURGE_LAG
,
""
,
(
gptr
*
)
&
srv_max_purge_lag
,
(
gptr
*
)
&
srv_max_purge_lag
,
0
,
GET_LONG
,
REQUIRED_ARG
,
0
,
0
,
~
0L
,
0
,
1L
,
0
},
{
"innodb_status_file"
,
OPT_INNODB_STATUS_FILE
,
{
"innodb_status_file"
,
OPT_INNODB_STATUS_FILE
,
"Enable SHOW INNODB STATUS output in the innodb_status.<pid> file"
,
"Enable SHOW INNODB STATUS output in the innodb_status.<pid> file"
,
(
gptr
*
)
&
innobase_create_status_file
,
(
gptr
*
)
&
innobase_create_status_file
,
(
gptr
*
)
&
innobase_create_status_file
,
(
gptr
*
)
&
innobase_create_status_file
,
...
...
sql/set_var.cc
View file @
1bd65d77
...
@@ -353,6 +353,8 @@ sys_var_long_ptr sys_innodb_max_dirty_pages_pct("innodb_max_dirty_pages_p
...
@@ -353,6 +353,8 @@ sys_var_long_ptr sys_innodb_max_dirty_pages_pct("innodb_max_dirty_pages_p
&
srv_max_buf_pool_modified_pct
);
&
srv_max_buf_pool_modified_pct
);
sys_var_long_ptr
sys_innodb_autoextend_increment
(
"innodb_autoextend_increment"
,
sys_var_long_ptr
sys_innodb_autoextend_increment
(
"innodb_autoextend_increment"
,
&
srv_auto_extend_increment
);
&
srv_auto_extend_increment
);
sys_var_long_ptr
sys_innodb_max_purge_lag
(
"innodb_max_purge_lag"
,
&
srv_max_purge_lag
);
#endif
#endif
/* Time/date/datetime formats */
/* Time/date/datetime formats */
...
@@ -603,6 +605,7 @@ sys_var *sys_variables[]=
...
@@ -603,6 +605,7 @@ sys_var *sys_variables[]=
&
sys_os
,
&
sys_os
,
#ifdef HAVE_INNOBASE_DB
#ifdef HAVE_INNOBASE_DB
&
sys_innodb_max_dirty_pages_pct
,
&
sys_innodb_max_dirty_pages_pct
,
&
sys_innodb_max_purge_lag
,
&
sys_innodb_autoextend_increment
,
&
sys_innodb_autoextend_increment
,
#endif
#endif
&
sys_unique_checks
,
&
sys_unique_checks
,
...
@@ -697,6 +700,7 @@ struct show_var_st init_vars[]= {
...
@@ -697,6 +700,7 @@ struct show_var_st init_vars[]= {
{
"innodb_log_files_in_group"
,
(
char
*
)
&
innobase_log_files_in_group
,
SHOW_LONG
},
{
"innodb_log_files_in_group"
,
(
char
*
)
&
innobase_log_files_in_group
,
SHOW_LONG
},
{
"innodb_log_group_home_dir"
,
(
char
*
)
&
innobase_log_group_home_dir
,
SHOW_CHAR_PTR
},
{
"innodb_log_group_home_dir"
,
(
char
*
)
&
innobase_log_group_home_dir
,
SHOW_CHAR_PTR
},
{
sys_innodb_max_dirty_pages_pct
.
name
,
(
char
*
)
&
sys_innodb_max_dirty_pages_pct
,
SHOW_SYS
},
{
sys_innodb_max_dirty_pages_pct
.
name
,
(
char
*
)
&
sys_innodb_max_dirty_pages_pct
,
SHOW_SYS
},
{
sys_innodb_max_purge_lag
.
name
,
(
char
*
)
&
sys_innodb_max_purge_lag
,
SHOW_SYS
},
{
"innodb_mirrored_log_groups"
,
(
char
*
)
&
innobase_mirrored_log_groups
,
SHOW_LONG
},
{
"innodb_mirrored_log_groups"
,
(
char
*
)
&
innobase_mirrored_log_groups
,
SHOW_LONG
},
{
"innodb_open_files"
,
(
char
*
)
&
innobase_open_files
,
SHOW_LONG
},
{
"innodb_open_files"
,
(
char
*
)
&
innobase_open_files
,
SHOW_LONG
},
{
"innodb_thread_concurrency"
,
(
char
*
)
&
innobase_thread_concurrency
,
SHOW_LONG
},
{
"innodb_thread_concurrency"
,
(
char
*
)
&
innobase_thread_concurrency
,
SHOW_LONG
},
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment