mirror of
https://github.com/MariaDB/server.git
synced 2025-02-05 13:22:17 +01:00
41 lines
1.6 KiB
PHP
41 lines
1.6 KiB
PHP
#
|
|
# Macro to run wsrep recovery step. This is adapted from
|
|
# suite/galera/include/galera_wsrep_recover.inc, with additional
|
|
# option to pass binlog argument to recovery command. The macro
|
|
# returns recovered position split in uuid and seqno parts.
|
|
#
|
|
# Arguments:
|
|
#
|
|
# wsrep_recover_binlog_opt - Binlog options to recovery command
|
|
#
|
|
# Return:
|
|
#
|
|
# wsrep_recover_start_position_uuid - UUID corresponding to recovered position
|
|
# wsrep_recover_start_position_seqno - seqno corresponding to recovered position
|
|
#
|
|
|
|
--exec $MYSQLD --defaults-group-suffix=.1 --defaults-file=$MYSQLTEST_VARDIR/my.cnf --log-error=$MYSQL_TMP_DIR/galera_wsrep_recover.log --innodb --wsrep-recover $wsrep_recover_binlog_opt --core-file > $MYSQL_TMP_DIR/galera_wsrep_recover.log 2>&1
|
|
|
|
--perl
|
|
use strict;
|
|
my $wsrep_start_position = `grep -a 'WSREP: Recovered position:' $ENV{MYSQL_TMP_DIR}/galera_wsrep_recover.log | sed 's/.*WSREP\:\ Recovered\ position://' | sed 's/^[ \t]*//'`;
|
|
chomp($wsrep_start_position);
|
|
die if $wsrep_start_position eq '';
|
|
open(FILE, ">", "$ENV{MYSQL_TMP_DIR}/galera_wsrep_start_position.inc") or die;
|
|
my ($uuid, $seqno) = split /:/, $wsrep_start_position;
|
|
print FILE "--let \$wsrep_recover_start_position_uuid = $uuid\n";
|
|
print FILE "--let \$wsrep_recover_start_position_seqno = $seqno\n";
|
|
close FILE;
|
|
EOF
|
|
|
|
--source $MYSQL_TMP_DIR/galera_wsrep_start_position.inc
|
|
|
|
if ($wsrep_recover_start_position_uuid == '') {
|
|
--die "Could not obtain start_position_uuid."
|
|
}
|
|
|
|
if ($wsrep_recover_start_position_seqno == '') {
|
|
--die "Could not obtain start_position_seqno."
|
|
}
|
|
|
|
--remove_file $MYSQL_TMP_DIR/galera_wsrep_start_position.inc
|