Commit b9a326b6 authored by Vladislav Vaintroub's avatar Vladislav Vaintroub

MDEV-12709 : mariabackup - during backup phase read some innodb parameter

using "show variables", rather than take the value from my.cnf.

"show variables" is more accurate than my.cnf,it also works for parameters
set on the mysqld command line, which is especially important for MTR.
parent d1e182d6
...@@ -344,7 +344,8 @@ get_mysql_vars(MYSQL *connection) ...@@ -344,7 +344,8 @@ get_mysql_vars(MYSQL *connection)
char *innodb_data_home_dir_var = NULL; char *innodb_data_home_dir_var = NULL;
char *innodb_undo_directory_var = NULL; char *innodb_undo_directory_var = NULL;
char *innodb_page_size_var = NULL; char *innodb_page_size_var = NULL;
char *innodb_undo_tablespaces_var = NULL;
char *endptr;
unsigned long server_version = mysql_get_server_version(connection); unsigned long server_version = mysql_get_server_version(connection);
bool ret = true; bool ret = true;
...@@ -372,6 +373,7 @@ get_mysql_vars(MYSQL *connection) ...@@ -372,6 +373,7 @@ get_mysql_vars(MYSQL *connection)
{"innodb_data_home_dir", &innodb_data_home_dir_var}, {"innodb_data_home_dir", &innodb_data_home_dir_var},
{"innodb_undo_directory", &innodb_undo_directory_var}, {"innodb_undo_directory", &innodb_undo_directory_var},
{"innodb_page_size", &innodb_page_size_var}, {"innodb_page_size", &innodb_page_size_var},
{"innodb_undo_tablespaces", &innodb_undo_tablespaces_var},
{NULL, NULL} {NULL, NULL}
}; };
...@@ -460,62 +462,55 @@ get_mysql_vars(MYSQL *connection) ...@@ -460,62 +462,55 @@ get_mysql_vars(MYSQL *connection)
} }
/* get some default values is they are missing from my.cnf */ /* get some default values is they are missing from my.cnf */
if (!check_if_param_set("datadir") && datadir_var && *datadir_var) { if (datadir_var && *datadir_var) {
strmake(mysql_real_data_home, datadir_var, FN_REFLEN - 1); strmake(mysql_real_data_home, datadir_var, FN_REFLEN - 1);
mysql_data_home= mysql_real_data_home; mysql_data_home= mysql_real_data_home;
} }
if (!check_if_param_set("innodb_data_file_path") if (innodb_data_file_path_var && *innodb_data_file_path_var) {
&& innodb_data_file_path_var && *innodb_data_file_path_var) {
innobase_data_file_path = my_strdup( innobase_data_file_path = my_strdup(
innodb_data_file_path_var, MYF(MY_FAE)); innodb_data_file_path_var, MYF(MY_FAE));
} }
if (!check_if_param_set("innodb_data_home_dir") if (innodb_data_home_dir_var && *innodb_data_home_dir_var) {
&& innodb_data_home_dir_var && *innodb_data_home_dir_var) {
innobase_data_home_dir = my_strdup( innobase_data_home_dir = my_strdup(
innodb_data_home_dir_var, MYF(MY_FAE)); innodb_data_home_dir_var, MYF(MY_FAE));
} }
if (!check_if_param_set("innodb_log_group_home_dir") if (innodb_log_group_home_dir_var
&& innodb_log_group_home_dir_var
&& *innodb_log_group_home_dir_var) { && *innodb_log_group_home_dir_var) {
srv_log_group_home_dir = my_strdup( srv_log_group_home_dir = my_strdup(
innodb_log_group_home_dir_var, MYF(MY_FAE)); innodb_log_group_home_dir_var, MYF(MY_FAE));
} }
if (!check_if_param_set("innodb_undo_directory") if (innodb_undo_directory_var && *innodb_undo_directory_var) {
&& innodb_undo_directory_var && *innodb_undo_directory_var) {
srv_undo_dir = my_strdup( srv_undo_dir = my_strdup(
innodb_undo_directory_var, MYF(MY_FAE)); innodb_undo_directory_var, MYF(MY_FAE));
} }
if (!check_if_param_set("innodb_log_files_in_group") if (innodb_log_files_in_group_var) {
&& innodb_log_files_in_group_var) {
char *endptr;
innobase_log_files_in_group = strtol( innobase_log_files_in_group = strtol(
innodb_log_files_in_group_var, &endptr, 10); innodb_log_files_in_group_var, &endptr, 10);
ut_ad(*endptr == 0); ut_ad(*endptr == 0);
} }
if (!check_if_param_set("innodb_log_file_size") if (innodb_log_file_size_var) {
&& innodb_log_file_size_var) {
char *endptr;
innobase_log_file_size = strtoll( innobase_log_file_size = strtoll(
innodb_log_file_size_var, &endptr, 10); innodb_log_file_size_var, &endptr, 10);
ut_ad(*endptr == 0); ut_ad(*endptr == 0);
} }
if (!check_if_param_set("innodb_page_size") && innodb_page_size_var) { if (innodb_page_size_var) {
char *endptr;
innobase_page_size = strtoll( innobase_page_size = strtoll(
innodb_page_size_var, &endptr, 10); innodb_page_size_var, &endptr, 10);
ut_ad(*endptr == 0); ut_ad(*endptr == 0);
} }
if (innodb_undo_tablespaces_var) {
srv_undo_tablespaces = strtoul(innodb_undo_tablespaces_var, &endptr, 10);
ut_ad(*endptr == 0);
}
out: out:
free_mysql_variables(mysql_vars); free_mysql_variables(mysql_vars);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment