249 lines
5.6 KiB
Plaintext
249 lines
5.6 KiB
Plaintext
source include/have_memcached_plugin.inc;
|
|
source include/not_valgrind.inc;
|
|
source include/have_log_bin.inc;
|
|
|
|
# Test of master and both with slave with memcached access and binlog-format=raw.
|
|
#
|
|
source include/not_windows.inc;
|
|
--disable_warnings
|
|
source include/master-slave.inc;
|
|
--enable_warnings
|
|
|
|
--disable_query_log
|
|
CALL mtr.add_suppression("daemon-memcached-w-batch-size': unsigned");
|
|
CALL mtr.add_suppression("Could not obtain server's UPN to be used as target service name");
|
|
CALL mtr.add_suppression("Warning: MySQL is trying to drop");
|
|
--enable_query_log
|
|
|
|
--enable_connect_log
|
|
SET @transaction_isolation= @@global.transaction_isolation;
|
|
SET GLOBAL TRANSACTION ISOLATION LEVEL READ UNCOMMITTED;
|
|
|
|
# Create the memcached tables
|
|
--disable_query_log
|
|
source include/memcache_config.inc;
|
|
--enable_query_log
|
|
|
|
INSERT INTO cache_policies VALUES("cache_policy", "innodb_only",
|
|
"innodb_only", "innodb_only", "innodb_only");
|
|
|
|
INSERT INTO config_options VALUES("separator", "|");
|
|
|
|
# describe table for memcache
|
|
INSERT INTO containers VALUES ("desc_t1", "test", "t1",
|
|
"c1", "c2,c21", "c3", "c4", "c5", "PRIMARY");
|
|
|
|
USE test;
|
|
|
|
--disable_warnings
|
|
DROP TABLE IF EXISTS t1;
|
|
--enable_warnings
|
|
CREATE TABLE t1 (c1 VARCHAR(32),
|
|
c2 VARCHAR(1024),
|
|
c21 VARCHAR(1024),
|
|
c3 INT, c4 BIGINT UNSIGNED, c5 INT, primary key(c1))
|
|
ENGINE = INNODB;
|
|
|
|
INSERT INTO t1 VALUES ('D', 'Darmstadt', 'City', 0, 0, 0);
|
|
INSERT INTO t1 VALUES ('B', 'Berlin', 'Mitte', 0, 0, 0);
|
|
INSERT INTO t1 VALUES ('C', 'Cottbus', 'West', 0, 0 ,0);
|
|
INSERT INTO t1 VALUES ('H', 'Hamburg', 'Norderstedt', 0, 0, 0);
|
|
|
|
# Tables must exist before plugin can be started!
|
|
--let $memcached_address=127.0.0.1:11270
|
|
--source ../include/load_daemon_memcached_expecting_success.inc
|
|
|
|
--sorted_result
|
|
SELECT c1,c2,c21 FROM t1;
|
|
|
|
perl;
|
|
use DBI;
|
|
use Cache::Memcached;
|
|
my $memd = new Cache::Memcached {
|
|
'servers' => [ "127.0.0.1:11270" ]
|
|
};
|
|
print "Here are the memcached results with D,B,H,C:\n";
|
|
$val = $memd->get("D");
|
|
if ($val) { print "$val\n"; }
|
|
$val = $memd->get("B");
|
|
if ($val) { print "$val\n"; }
|
|
$val = $memd->get("H");
|
|
if ($val) { print "$val\n"; }
|
|
$val = $memd->get("C");
|
|
if ($val) { print "$val\n"; }
|
|
$memd->disconnect_all;
|
|
EOF
|
|
|
|
--sorted_result
|
|
SELECT c1,c2,c21 FROM t1;
|
|
|
|
--echo sync_slave_with_master;
|
|
sync_slave_with_master;
|
|
|
|
connection slave;
|
|
--sorted_result
|
|
SELECT c1,c2,c21 FROM t1;
|
|
|
|
connection master;
|
|
perl;
|
|
use DBI;
|
|
use Cache::Memcached;
|
|
my $memd = new Cache::Memcached {
|
|
'servers' => [ "127.0.0.1:11270" ]
|
|
};
|
|
print "Here are the memcached results after set:\n";
|
|
$val = $memd->set("E","Essen|Ost");
|
|
$val = $memd->get("E");
|
|
if ($val) { print "$val\n"; }
|
|
$memd->disconnect_all;
|
|
EOF
|
|
|
|
--sorted_result
|
|
SELECT c1,c2,c21 FROM t1;
|
|
|
|
--echo sync_slave_with_master;
|
|
sync_slave_with_master;
|
|
|
|
connection slave;
|
|
--sorted_result
|
|
SELECT c1,c2,c21 FROM t1;
|
|
|
|
connection master;
|
|
perl;
|
|
use DBI;
|
|
use Cache::Memcached;
|
|
my $memd = new Cache::Memcached {
|
|
'servers' => [ "127.0.0.1:11270" ]
|
|
};
|
|
print "Here are the memcached results after add:\n";
|
|
$val = $memd->add("F","Frankfurt|Sachsenhause");
|
|
$val = $memd->get("F");
|
|
if ($val) { print "$val\n"; }
|
|
$memd->disconnect_all;
|
|
EOF
|
|
|
|
--sorted_result
|
|
SELECT c1,c2,c21 FROM t1;
|
|
|
|
--echo sync_slave_with_master;
|
|
sync_slave_with_master;
|
|
|
|
connection slave;
|
|
--sorted_result
|
|
SELECT c1,c2,c21 FROM t1;
|
|
|
|
connection master;
|
|
perl;
|
|
use DBI;
|
|
use Cache::Memcached;
|
|
my $memd = new Cache::Memcached {
|
|
'servers' => [ "127.0.0.1:11270" ]
|
|
};
|
|
print "Here are the memcached results after replace:\n";
|
|
$val = $memd->replace("F","Frankfurt a. M.|Sachsenhausen");
|
|
$val = $memd->get("F");
|
|
if ($val) { print "$val\n"; }
|
|
$memd->disconnect_all;
|
|
EOF
|
|
|
|
--sorted_result
|
|
SELECT c1,c2,c21 FROM t1;
|
|
|
|
--echo sync_slave_with_master;
|
|
sync_slave_with_master;
|
|
|
|
connection slave;
|
|
--sorted_result
|
|
SELECT c1,c2,c21 FROM t1;
|
|
|
|
connection master;
|
|
perl;
|
|
use DBI;
|
|
use Cache::Memcached;
|
|
my $memd = new Cache::Memcached {
|
|
'servers' => [ "127.0.0.1:11270" ]
|
|
};
|
|
print "Here are the memcached results after delete:\n";
|
|
$val = $memd->delete("F");
|
|
$val = $memd->get("F");
|
|
if ($val) { print "$val\n"; }
|
|
$memd->disconnect_all;
|
|
EOF
|
|
|
|
--sorted_result
|
|
SELECT c1,c2,c21 FROM t1;
|
|
|
|
--echo sync_slave_with_master;
|
|
sync_slave_with_master;
|
|
|
|
connection slave;
|
|
--sorted_result
|
|
SELECT c1,c2,c21 FROM t1;
|
|
|
|
connection master;
|
|
perl;
|
|
use DBI;
|
|
use Cache::Memcached;
|
|
my $memd = new Cache::Memcached {
|
|
'servers' => [ "127.0.0.1:11270" ]
|
|
};
|
|
print "Here are the memcached results after add Frankfurt|:\n";
|
|
$val = $memd->add("F","Frankfurt|");
|
|
$val = $memd->get("F");
|
|
if ($val) { print "$val\n"; }
|
|
print "Here are the memcached results after add |Airport:\n";
|
|
$val = $memd->add("F","|");
|
|
$val = $memd->get("F");
|
|
if ($val) { print "$val\n"; }
|
|
$memd->disconnect_all;
|
|
EOF
|
|
|
|
--sorted_result
|
|
SELECT c1,c2,c21 FROM t1;
|
|
|
|
--echo sync_slave_with_master;
|
|
sync_slave_with_master;
|
|
|
|
connection slave;
|
|
--sorted_result
|
|
SELECT c1,c2,c21 FROM t1;
|
|
|
|
connection master;
|
|
perl;
|
|
use DBI;
|
|
use Cache::Memcached;
|
|
my $memd = new Cache::Memcached {
|
|
'servers' => [ "127.0.0.1:11270" ]
|
|
};
|
|
print "Here are the memcached results after replace Frankfurt a.M.:\n";
|
|
$val = $memd->replace("F","Frankfurt a. M.|");
|
|
$val = $memd->get("F");
|
|
if ($val) { print "$val\n"; }
|
|
print "Here are the memcached results after replace Sachsenhausen:\n";
|
|
$val = $memd->replace("F","|Sachsenhausen");
|
|
$val = $memd->get("F");
|
|
if ($val) { print "$val\n"; }
|
|
$memd->disconnect_all;
|
|
EOF
|
|
|
|
--sorted_result
|
|
SELECT c1,c2,c21 FROM t1;
|
|
|
|
--echo sync_slave_with_master;
|
|
sync_slave_with_master;
|
|
|
|
connection slave;
|
|
--sorted_result
|
|
SELECT c1,c2,c21 FROM t1;
|
|
|
|
connection master;
|
|
DROP TABLE t1;
|
|
|
|
UNINSTALL PLUGIN daemon_memcached;
|
|
DROP DATABASE innodb_memcache;
|
|
|
|
SET @@global.transaction_isolation= @transaction_isolation;
|
|
sync_slave_with_master;
|
|
source include/rpl_end.inc;
|
|
|