2021-10-19 16:50:37 +08:00
|
|
|
# Primitive tests on cluster-enabled redis using redis-cli
|
|
|
|
|
|
|
|
source tests/support/cli.tcl
|
|
|
|
|
|
|
|
# make sure the test infra won't use SELECT
|
2022-03-18 20:10:24 +08:00
|
|
|
set old_singledb $::singledb
|
2021-10-19 16:50:37 +08:00
|
|
|
set ::singledb 1
|
|
|
|
|
2021-10-20 15:40:28 +03:00
|
|
|
# cluster creation is complicated with TLS, and the current tests don't really need that coverage
|
|
|
|
tags {tls:skip external:skip cluster} {
|
|
|
|
|
2021-10-19 16:50:37 +08:00
|
|
|
# start three servers
|
2022-08-19 00:18:18 +08:00
|
|
|
set base_conf [list cluster-enabled yes cluster-node-timeout 1000]
|
2022-03-16 18:11:38 +01:00
|
|
|
start_multiple_servers 3 [list overrides $base_conf] {
|
2021-10-19 16:50:37 +08:00
|
|
|
|
|
|
|
set node1 [srv 0 client]
|
|
|
|
set node2 [srv -1 client]
|
|
|
|
set node3 [srv -2 client]
|
|
|
|
set node3_pid [srv -2 pid]
|
2022-03-16 18:11:38 +01:00
|
|
|
set node3_rd [redis_deferring_client -2]
|
2021-10-19 16:50:37 +08:00
|
|
|
|
|
|
|
test {Create 3 node cluster} {
|
|
|
|
exec src/redis-cli --cluster-yes --cluster create \
|
|
|
|
127.0.0.1:[srv 0 port] \
|
|
|
|
127.0.0.1:[srv -1 port] \
|
|
|
|
127.0.0.1:[srv -2 port]
|
|
|
|
|
|
|
|
wait_for_condition 1000 50 {
|
2022-07-12 10:41:29 -07:00
|
|
|
[CI 0 cluster_state] eq {ok} &&
|
|
|
|
[CI 1 cluster_state] eq {ok} &&
|
|
|
|
[CI 2 cluster_state] eq {ok}
|
2021-10-19 16:50:37 +08:00
|
|
|
} else {
|
|
|
|
fail "Cluster doesn't stabilize"
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
test "Run blocking command on cluster node3" {
|
|
|
|
# key9184688 is mapped to slot 10923 (first slot of node 3)
|
|
|
|
$node3_rd brpop key9184688 0
|
|
|
|
$node3_rd flush
|
|
|
|
|
|
|
|
wait_for_condition 50 100 {
|
|
|
|
[s -2 blocked_clients] eq {1}
|
|
|
|
} else {
|
|
|
|
fail "Client not blocked"
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
test "Perform a Resharding" {
|
|
|
|
exec src/redis-cli --cluster-yes --cluster reshard 127.0.0.1:[srv -2 port] \
|
|
|
|
--cluster-to [$node1 cluster myid] \
|
|
|
|
--cluster-from [$node3 cluster myid] \
|
|
|
|
--cluster-slots 1
|
|
|
|
}
|
|
|
|
|
|
|
|
test "Verify command got unblocked after resharding" {
|
|
|
|
# this (read) will wait for the node3 to realize the new topology
|
|
|
|
assert_error {*MOVED*} {$node3_rd read}
|
|
|
|
|
|
|
|
# verify there are no blocked clients
|
|
|
|
assert_equal [s 0 blocked_clients] {0}
|
|
|
|
assert_equal [s -1 blocked_clients] {0}
|
|
|
|
assert_equal [s -2 blocked_clients] {0}
|
|
|
|
}
|
|
|
|
|
|
|
|
test "Wait for cluster to be stable" {
|
2023-05-09 07:12:44 +08:00
|
|
|
# Cluster check just verifies the config state is self-consistent,
|
2022-07-19 11:35:13 +08:00
|
|
|
# waiting for cluster_state to be okay is an independent check that all the
|
|
|
|
# nodes actually believe each other are healthy, prevent cluster down error.
|
|
|
|
wait_for_condition 1000 50 {
|
|
|
|
[catch {exec src/redis-cli --cluster check 127.0.0.1:[srv 0 port]}] == 0 &&
|
|
|
|
[catch {exec src/redis-cli --cluster check 127.0.0.1:[srv -1 port]}] == 0 &&
|
|
|
|
[catch {exec src/redis-cli --cluster check 127.0.0.1:[srv -2 port]}] == 0 &&
|
|
|
|
[CI 0 cluster_state] eq {ok} &&
|
|
|
|
[CI 1 cluster_state] eq {ok} &&
|
|
|
|
[CI 2 cluster_state] eq {ok}
|
2021-10-19 16:50:37 +08:00
|
|
|
} else {
|
|
|
|
fail "Cluster doesn't stabilize"
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2022-03-16 18:11:38 +01:00
|
|
|
set node1_rd [redis_deferring_client 0]
|
|
|
|
|
2021-10-19 16:50:37 +08:00
|
|
|
test "Sanity test push cmd after resharding" {
|
|
|
|
assert_error {*MOVED*} {$node3 lpush key9184688 v1}
|
|
|
|
|
|
|
|
$node1_rd brpop key9184688 0
|
|
|
|
$node1_rd flush
|
|
|
|
|
|
|
|
wait_for_condition 50 100 {
|
|
|
|
[s 0 blocked_clients] eq {1}
|
|
|
|
} else {
|
|
|
|
puts "Client not blocked"
|
|
|
|
puts "read from blocked client: [$node1_rd read]"
|
|
|
|
fail "Client not blocked"
|
|
|
|
}
|
|
|
|
|
|
|
|
$node1 lpush key9184688 v2
|
|
|
|
assert_equal {key9184688 v2} [$node1_rd read]
|
|
|
|
}
|
|
|
|
|
|
|
|
$node3_rd close
|
Add cluster-port support to redis-cli --cluster (#10344)
In #9389, we add a new `cluster-port` config and make cluster bus port configurable,
and currently redis-cli --cluster create/add-node doesn't support with a configurable `cluster-port` instance.
Because redis-cli uses the old way (port + 10000) to send the `CLUSTER MEET` command.
Now we add this support on redis-cli `--cluster`, note we don't need to explicitly pass in the
`cluster-port` parameter, we can get the real `cluster-port` of the node in `clusterManagerNodeLoadInfo`,
so the `--cluster create` and `--cluster add-node` interfaces have not changed.
We will use the `cluster-port` when we are doing `CLUSTER MEET`, also note that `CLUSTER MEET` bus-port
parameter was added in 4.0, so if the bus_port (the one in redis-cli) is 0, or equal (port + 10000),
we just call `CLUSTER MEET` with 2 arguments, using the old form.
Co-authored-by: Madelyn Olson <34459052+madolson@users.noreply.github.com>
2022-07-11 16:23:31 +08:00
|
|
|
|
2021-10-19 16:50:37 +08:00
|
|
|
test "Run blocking command again on cluster node1" {
|
|
|
|
$node1 del key9184688
|
|
|
|
# key9184688 is mapped to slot 10923 which has been moved to node1
|
|
|
|
$node1_rd brpop key9184688 0
|
|
|
|
$node1_rd flush
|
|
|
|
|
|
|
|
wait_for_condition 50 100 {
|
|
|
|
[s 0 blocked_clients] eq {1}
|
|
|
|
} else {
|
|
|
|
fail "Client not blocked"
|
|
|
|
}
|
|
|
|
}
|
Add cluster-port support to redis-cli --cluster (#10344)
In #9389, we add a new `cluster-port` config and make cluster bus port configurable,
and currently redis-cli --cluster create/add-node doesn't support with a configurable `cluster-port` instance.
Because redis-cli uses the old way (port + 10000) to send the `CLUSTER MEET` command.
Now we add this support on redis-cli `--cluster`, note we don't need to explicitly pass in the
`cluster-port` parameter, we can get the real `cluster-port` of the node in `clusterManagerNodeLoadInfo`,
so the `--cluster create` and `--cluster add-node` interfaces have not changed.
We will use the `cluster-port` when we are doing `CLUSTER MEET`, also note that `CLUSTER MEET` bus-port
parameter was added in 4.0, so if the bus_port (the one in redis-cli) is 0, or equal (port + 10000),
we just call `CLUSTER MEET` with 2 arguments, using the old form.
Co-authored-by: Madelyn Olson <34459052+madolson@users.noreply.github.com>
2022-07-11 16:23:31 +08:00
|
|
|
|
2021-10-19 16:50:37 +08:00
|
|
|
test "Kill a cluster node and wait for fail state" {
|
Add cluster-port support to redis-cli --cluster (#10344)
In #9389, we add a new `cluster-port` config and make cluster bus port configurable,
and currently redis-cli --cluster create/add-node doesn't support with a configurable `cluster-port` instance.
Because redis-cli uses the old way (port + 10000) to send the `CLUSTER MEET` command.
Now we add this support on redis-cli `--cluster`, note we don't need to explicitly pass in the
`cluster-port` parameter, we can get the real `cluster-port` of the node in `clusterManagerNodeLoadInfo`,
so the `--cluster create` and `--cluster add-node` interfaces have not changed.
We will use the `cluster-port` when we are doing `CLUSTER MEET`, also note that `CLUSTER MEET` bus-port
parameter was added in 4.0, so if the bus_port (the one in redis-cli) is 0, or equal (port + 10000),
we just call `CLUSTER MEET` with 2 arguments, using the old form.
Co-authored-by: Madelyn Olson <34459052+madolson@users.noreply.github.com>
2022-07-11 16:23:31 +08:00
|
|
|
# kill node3 in cluster
|
Attempt to solve MacOS CI issues in GH Actions (#12013)
The MacOS CI in github actions often hangs without any logs. GH argues that
it's due to resource utilization, either running out of disk space, memory, or CPU
starvation, and thus the runner is terminated.
This PR contains multiple attempts to resolve this:
1. introducing pause_process instead of SIGSTOP, which waits for the process
to stop before resuming the test, possibly resolving race conditions in some tests,
this was a suspect since there was one test that could result in an infinite loop in that
case, in practice this didn't help, but still a good idea to keep.
2. disable the `save` config in many tests that don't need it, specifically ones that use
heavy writes and could create large files.
3. change the `populate` proc to use short pipeline rather than an infinite one.
4. use `--clients 1` in the macos CI so that we don't risk running multiple resource
demanding tests in parallel.
5. enable `--verbose` to be repeated to elevate verbosity and print more info to stdout
when a test or a server starts.
2023-04-12 09:19:21 +03:00
|
|
|
pause_process $node3_pid
|
2021-10-19 16:50:37 +08:00
|
|
|
|
|
|
|
wait_for_condition 1000 50 {
|
2022-07-12 10:41:29 -07:00
|
|
|
[CI 0 cluster_state] eq {fail} &&
|
|
|
|
[CI 1 cluster_state] eq {fail}
|
2021-10-19 16:50:37 +08:00
|
|
|
} else {
|
|
|
|
fail "Cluster doesn't fail"
|
|
|
|
}
|
|
|
|
}
|
Add cluster-port support to redis-cli --cluster (#10344)
In #9389, we add a new `cluster-port` config and make cluster bus port configurable,
and currently redis-cli --cluster create/add-node doesn't support with a configurable `cluster-port` instance.
Because redis-cli uses the old way (port + 10000) to send the `CLUSTER MEET` command.
Now we add this support on redis-cli `--cluster`, note we don't need to explicitly pass in the
`cluster-port` parameter, we can get the real `cluster-port` of the node in `clusterManagerNodeLoadInfo`,
so the `--cluster create` and `--cluster add-node` interfaces have not changed.
We will use the `cluster-port` when we are doing `CLUSTER MEET`, also note that `CLUSTER MEET` bus-port
parameter was added in 4.0, so if the bus_port (the one in redis-cli) is 0, or equal (port + 10000),
we just call `CLUSTER MEET` with 2 arguments, using the old form.
Co-authored-by: Madelyn Olson <34459052+madolson@users.noreply.github.com>
2022-07-11 16:23:31 +08:00
|
|
|
|
2021-10-19 16:50:37 +08:00
|
|
|
test "Verify command got unblocked after cluster failure" {
|
|
|
|
assert_error {*CLUSTERDOWN*} {$node1_rd read}
|
|
|
|
|
|
|
|
# verify there are no blocked clients
|
|
|
|
assert_equal [s 0 blocked_clients] {0}
|
|
|
|
assert_equal [s -1 blocked_clients] {0}
|
|
|
|
}
|
|
|
|
|
Attempt to solve MacOS CI issues in GH Actions (#12013)
The MacOS CI in github actions often hangs without any logs. GH argues that
it's due to resource utilization, either running out of disk space, memory, or CPU
starvation, and thus the runner is terminated.
This PR contains multiple attempts to resolve this:
1. introducing pause_process instead of SIGSTOP, which waits for the process
to stop before resuming the test, possibly resolving race conditions in some tests,
this was a suspect since there was one test that could result in an infinite loop in that
case, in practice this didn't help, but still a good idea to keep.
2. disable the `save` config in many tests that don't need it, specifically ones that use
heavy writes and could create large files.
3. change the `populate` proc to use short pipeline rather than an infinite one.
4. use `--clients 1` in the macos CI so that we don't risk running multiple resource
demanding tests in parallel.
5. enable `--verbose` to be repeated to elevate verbosity and print more info to stdout
when a test or a server starts.
2023-04-12 09:19:21 +03:00
|
|
|
resume_process $node3_pid
|
2021-10-19 16:50:37 +08:00
|
|
|
$node1_rd close
|
|
|
|
|
2022-03-16 18:11:38 +01:00
|
|
|
} ;# stop servers
|
2021-10-20 15:40:28 +03:00
|
|
|
|
2021-12-26 09:03:37 +02:00
|
|
|
# Test redis-cli -- cluster create, add-node, call.
|
|
|
|
# Test that functions are propagated on add-node
|
2022-03-16 18:11:38 +01:00
|
|
|
start_multiple_servers 5 [list overrides $base_conf] {
|
2021-12-26 09:03:37 +02:00
|
|
|
|
|
|
|
set node4_rd [redis_client -3]
|
|
|
|
set node5_rd [redis_client -4]
|
|
|
|
|
|
|
|
test {Functions are added to new node on redis-cli cluster add-node} {
|
|
|
|
exec src/redis-cli --cluster-yes --cluster create \
|
|
|
|
127.0.0.1:[srv 0 port] \
|
|
|
|
127.0.0.1:[srv -1 port] \
|
|
|
|
127.0.0.1:[srv -2 port]
|
|
|
|
|
|
|
|
|
|
|
|
wait_for_condition 1000 50 {
|
2022-07-12 10:41:29 -07:00
|
|
|
[CI 0 cluster_state] eq {ok} &&
|
|
|
|
[CI 1 cluster_state] eq {ok} &&
|
|
|
|
[CI 2 cluster_state] eq {ok}
|
2021-12-26 09:03:37 +02:00
|
|
|
} else {
|
|
|
|
fail "Cluster doesn't stabilize"
|
|
|
|
}
|
|
|
|
|
|
|
|
# upload a function to all the cluster
|
|
|
|
exec src/redis-cli --cluster-yes --cluster call 127.0.0.1:[srv 0 port] \
|
2022-04-05 10:27:24 +03:00
|
|
|
FUNCTION LOAD {#!lua name=TEST
|
|
|
|
redis.register_function('test', function() return 'hello' end)
|
|
|
|
}
|
2021-12-26 09:03:37 +02:00
|
|
|
|
|
|
|
# adding node to the cluster
|
|
|
|
exec src/redis-cli --cluster-yes --cluster add-node \
|
|
|
|
127.0.0.1:[srv -3 port] \
|
|
|
|
127.0.0.1:[srv 0 port]
|
|
|
|
|
2022-10-03 14:21:41 +08:00
|
|
|
wait_for_cluster_size 4
|
|
|
|
|
2021-12-26 09:03:37 +02:00
|
|
|
wait_for_condition 1000 50 {
|
2022-07-12 10:41:29 -07:00
|
|
|
[CI 0 cluster_state] eq {ok} &&
|
|
|
|
[CI 1 cluster_state] eq {ok} &&
|
|
|
|
[CI 2 cluster_state] eq {ok} &&
|
|
|
|
[CI 3 cluster_state] eq {ok}
|
2021-12-26 09:03:37 +02:00
|
|
|
} else {
|
|
|
|
fail "Cluster doesn't stabilize"
|
|
|
|
}
|
|
|
|
|
|
|
|
# make sure 'test' function was added to the new node
|
2022-04-05 10:27:24 +03:00
|
|
|
assert_equal {{library_name TEST engine LUA functions {{name test description {} flags {}}}}} [$node4_rd FUNCTION LIST]
|
2021-12-26 09:03:37 +02:00
|
|
|
|
|
|
|
# add function to node 5
|
2022-04-05 10:27:24 +03:00
|
|
|
assert_equal {TEST} [$node5_rd FUNCTION LOAD {#!lua name=TEST
|
|
|
|
redis.register_function('test', function() return 'hello' end)
|
|
|
|
}]
|
2021-12-26 09:03:37 +02:00
|
|
|
|
|
|
|
# make sure functions was added to node 5
|
2022-04-05 10:27:24 +03:00
|
|
|
assert_equal {{library_name TEST engine LUA functions {{name test description {} flags {}}}}} [$node5_rd FUNCTION LIST]
|
2021-12-26 09:03:37 +02:00
|
|
|
|
|
|
|
# adding node 5 to the cluster should failed because it already contains the 'test' function
|
|
|
|
catch {
|
|
|
|
exec src/redis-cli --cluster-yes --cluster add-node \
|
|
|
|
127.0.0.1:[srv -4 port] \
|
|
|
|
127.0.0.1:[srv 0 port]
|
|
|
|
} e
|
Add cluster-port support to redis-cli --cluster (#10344)
In #9389, we add a new `cluster-port` config and make cluster bus port configurable,
and currently redis-cli --cluster create/add-node doesn't support with a configurable `cluster-port` instance.
Because redis-cli uses the old way (port + 10000) to send the `CLUSTER MEET` command.
Now we add this support on redis-cli `--cluster`, note we don't need to explicitly pass in the
`cluster-port` parameter, we can get the real `cluster-port` of the node in `clusterManagerNodeLoadInfo`,
so the `--cluster create` and `--cluster add-node` interfaces have not changed.
We will use the `cluster-port` when we are doing `CLUSTER MEET`, also note that `CLUSTER MEET` bus-port
parameter was added in 4.0, so if the bus_port (the one in redis-cli) is 0, or equal (port + 10000),
we just call `CLUSTER MEET` with 2 arguments, using the old form.
Co-authored-by: Madelyn Olson <34459052+madolson@users.noreply.github.com>
2022-07-11 16:23:31 +08:00
|
|
|
assert_match {*node already contains functions*} $e
|
2021-12-26 09:03:37 +02:00
|
|
|
}
|
2022-03-16 18:11:38 +01:00
|
|
|
} ;# stop servers
|
|
|
|
|
|
|
|
# Test redis-cli --cluster create, add-node.
|
|
|
|
# Test that one slot can be migrated to and then away from the new node.
|
|
|
|
test {Migrate the last slot away from a node using redis-cli} {
|
|
|
|
start_multiple_servers 4 [list overrides $base_conf] {
|
|
|
|
|
|
|
|
# Create a cluster of 3 nodes
|
|
|
|
exec src/redis-cli --cluster-yes --cluster create \
|
|
|
|
127.0.0.1:[srv 0 port] \
|
|
|
|
127.0.0.1:[srv -1 port] \
|
|
|
|
127.0.0.1:[srv -2 port]
|
|
|
|
|
|
|
|
wait_for_condition 1000 50 {
|
2022-07-12 10:41:29 -07:00
|
|
|
[CI 0 cluster_state] eq {ok} &&
|
|
|
|
[CI 1 cluster_state] eq {ok} &&
|
|
|
|
[CI 2 cluster_state] eq {ok}
|
2022-03-16 18:11:38 +01:00
|
|
|
} else {
|
|
|
|
fail "Cluster doesn't stabilize"
|
|
|
|
}
|
|
|
|
|
|
|
|
# Insert some data
|
|
|
|
assert_equal OK [exec src/redis-cli -c -p [srv 0 port] SET foo bar]
|
|
|
|
set slot [exec src/redis-cli -c -p [srv 0 port] CLUSTER KEYSLOT foo]
|
|
|
|
|
|
|
|
# Add new node to the cluster
|
|
|
|
exec src/redis-cli --cluster-yes --cluster add-node \
|
|
|
|
127.0.0.1:[srv -3 port] \
|
|
|
|
127.0.0.1:[srv 0 port]
|
2022-09-07 02:54:24 +03:00
|
|
|
|
2022-10-03 14:21:41 +08:00
|
|
|
# First we wait for new node to be recognized by entire cluster
|
2022-09-07 02:54:24 +03:00
|
|
|
wait_for_cluster_size 4
|
|
|
|
|
2022-03-16 18:11:38 +01:00
|
|
|
wait_for_condition 1000 50 {
|
2022-07-12 10:41:29 -07:00
|
|
|
[CI 0 cluster_state] eq {ok} &&
|
|
|
|
[CI 1 cluster_state] eq {ok} &&
|
|
|
|
[CI 2 cluster_state] eq {ok} &&
|
|
|
|
[CI 3 cluster_state] eq {ok}
|
2022-03-16 18:11:38 +01:00
|
|
|
} else {
|
|
|
|
fail "Cluster doesn't stabilize"
|
|
|
|
}
|
|
|
|
|
|
|
|
set newnode_r [redis_client -3]
|
|
|
|
set newnode_id [$newnode_r CLUSTER MYID]
|
|
|
|
|
|
|
|
# Find out which node has the key "foo" by asking the new node for a
|
|
|
|
# redirect.
|
|
|
|
catch { $newnode_r get foo } e
|
|
|
|
assert_match "MOVED $slot *" $e
|
|
|
|
lassign [split [lindex $e 2] :] owner_host owner_port
|
|
|
|
set owner_r [redis $owner_host $owner_port 0 $::tls]
|
|
|
|
set owner_id [$owner_r CLUSTER MYID]
|
|
|
|
|
|
|
|
# Move slot to new node using plain Redis commands
|
|
|
|
assert_equal OK [$newnode_r CLUSTER SETSLOT $slot IMPORTING $owner_id]
|
|
|
|
assert_equal OK [$owner_r CLUSTER SETSLOT $slot MIGRATING $newnode_id]
|
|
|
|
assert_equal {foo} [$owner_r CLUSTER GETKEYSINSLOT $slot 10]
|
|
|
|
assert_equal OK [$owner_r MIGRATE 127.0.0.1 [srv -3 port] "" 0 5000 KEYS foo]
|
|
|
|
assert_equal OK [$newnode_r CLUSTER SETSLOT $slot NODE $newnode_id]
|
|
|
|
assert_equal OK [$owner_r CLUSTER SETSLOT $slot NODE $newnode_id]
|
|
|
|
|
2022-03-31 11:14:21 +08:00
|
|
|
# Using --cluster check make sure we won't get `Not all slots are covered by nodes`.
|
|
|
|
# Wait for the cluster to become stable make sure the cluster is up during MIGRATE.
|
|
|
|
wait_for_condition 1000 50 {
|
|
|
|
[catch {exec src/redis-cli --cluster check 127.0.0.1:[srv 0 port]}] == 0 &&
|
|
|
|
[catch {exec src/redis-cli --cluster check 127.0.0.1:[srv -1 port]}] == 0 &&
|
|
|
|
[catch {exec src/redis-cli --cluster check 127.0.0.1:[srv -2 port]}] == 0 &&
|
|
|
|
[catch {exec src/redis-cli --cluster check 127.0.0.1:[srv -3 port]}] == 0 &&
|
2022-07-12 10:41:29 -07:00
|
|
|
[CI 0 cluster_state] eq {ok} &&
|
|
|
|
[CI 1 cluster_state] eq {ok} &&
|
|
|
|
[CI 2 cluster_state] eq {ok} &&
|
|
|
|
[CI 3 cluster_state] eq {ok}
|
2022-03-31 11:14:21 +08:00
|
|
|
} else {
|
|
|
|
fail "Cluster doesn't stabilize"
|
|
|
|
}
|
|
|
|
|
2022-03-16 18:11:38 +01:00
|
|
|
# Move the only slot back to original node using redis-cli
|
|
|
|
exec src/redis-cli --cluster reshard 127.0.0.1:[srv -3 port] \
|
|
|
|
--cluster-from $newnode_id \
|
|
|
|
--cluster-to $owner_id \
|
|
|
|
--cluster-slots 1 \
|
|
|
|
--cluster-yes
|
|
|
|
|
2022-03-31 11:14:21 +08:00
|
|
|
# The empty node will become a replica of the new owner before the
|
|
|
|
# `MOVED` check, so let's wait for the cluster to become stable.
|
|
|
|
wait_for_condition 1000 50 {
|
2022-07-12 10:41:29 -07:00
|
|
|
[CI 0 cluster_state] eq {ok} &&
|
|
|
|
[CI 1 cluster_state] eq {ok} &&
|
|
|
|
[CI 2 cluster_state] eq {ok} &&
|
|
|
|
[CI 3 cluster_state] eq {ok}
|
2022-03-31 11:14:21 +08:00
|
|
|
} else {
|
|
|
|
fail "Cluster doesn't stabilize"
|
|
|
|
}
|
|
|
|
|
2022-03-16 18:11:38 +01:00
|
|
|
# Check that the key foo has been migrated back to the original owner.
|
|
|
|
catch { $newnode_r get foo } e
|
|
|
|
assert_equal "MOVED $slot $owner_host:$owner_port" $e
|
2022-04-02 23:58:07 +02:00
|
|
|
|
|
|
|
# Check that the empty node has turned itself into a replica of the new
|
|
|
|
# owner and that the new owner knows that.
|
|
|
|
wait_for_condition 1000 50 {
|
|
|
|
[string match "*slave*" [$owner_r CLUSTER REPLICAS $owner_id]]
|
|
|
|
} else {
|
|
|
|
fail "Empty node didn't turn itself into a replica."
|
|
|
|
}
|
2022-03-16 18:11:38 +01:00
|
|
|
}
|
2021-12-26 09:03:37 +02:00
|
|
|
}
|
|
|
|
|
Add cluster-port support to redis-cli --cluster (#10344)
In #9389, we add a new `cluster-port` config and make cluster bus port configurable,
and currently redis-cli --cluster create/add-node doesn't support with a configurable `cluster-port` instance.
Because redis-cli uses the old way (port + 10000) to send the `CLUSTER MEET` command.
Now we add this support on redis-cli `--cluster`, note we don't need to explicitly pass in the
`cluster-port` parameter, we can get the real `cluster-port` of the node in `clusterManagerNodeLoadInfo`,
so the `--cluster create` and `--cluster add-node` interfaces have not changed.
We will use the `cluster-port` when we are doing `CLUSTER MEET`, also note that `CLUSTER MEET` bus-port
parameter was added in 4.0, so if the bus_port (the one in redis-cli) is 0, or equal (port + 10000),
we just call `CLUSTER MEET` with 2 arguments, using the old form.
Co-authored-by: Madelyn Olson <34459052+madolson@users.noreply.github.com>
2022-07-11 16:23:31 +08:00
|
|
|
# Test redis-cli --cluster create, add-node with cluster-port.
|
|
|
|
# Create five nodes, three with custom cluster_port and two with default values.
|
|
|
|
start_server [list overrides [list cluster-enabled yes cluster-node-timeout 1 cluster-port [find_available_port $::baseport $::portcount]]] {
|
|
|
|
start_server [list overrides [list cluster-enabled yes cluster-node-timeout 1]] {
|
|
|
|
start_server [list overrides [list cluster-enabled yes cluster-node-timeout 1 cluster-port [find_available_port $::baseport $::portcount]]] {
|
|
|
|
start_server [list overrides [list cluster-enabled yes cluster-node-timeout 1]] {
|
|
|
|
start_server [list overrides [list cluster-enabled yes cluster-node-timeout 1 cluster-port [find_available_port $::baseport $::portcount]]] {
|
|
|
|
|
|
|
|
# The first three are used to test --cluster create.
|
|
|
|
# The last two are used to test --cluster add-node
|
|
|
|
set node1_rd [redis_client 0]
|
|
|
|
set node2_rd [redis_client -1]
|
|
|
|
set node3_rd [redis_client -2]
|
|
|
|
set node4_rd [redis_client -3]
|
|
|
|
set node5_rd [redis_client -4]
|
|
|
|
|
|
|
|
test {redis-cli --cluster create with cluster-port} {
|
|
|
|
exec src/redis-cli --cluster-yes --cluster create \
|
|
|
|
127.0.0.1:[srv 0 port] \
|
|
|
|
127.0.0.1:[srv -1 port] \
|
|
|
|
127.0.0.1:[srv -2 port]
|
|
|
|
|
|
|
|
wait_for_condition 1000 50 {
|
2022-07-12 10:41:29 -07:00
|
|
|
[CI 0 cluster_state] eq {ok} &&
|
|
|
|
[CI 1 cluster_state] eq {ok} &&
|
|
|
|
[CI 2 cluster_state] eq {ok}
|
Add cluster-port support to redis-cli --cluster (#10344)
In #9389, we add a new `cluster-port` config and make cluster bus port configurable,
and currently redis-cli --cluster create/add-node doesn't support with a configurable `cluster-port` instance.
Because redis-cli uses the old way (port + 10000) to send the `CLUSTER MEET` command.
Now we add this support on redis-cli `--cluster`, note we don't need to explicitly pass in the
`cluster-port` parameter, we can get the real `cluster-port` of the node in `clusterManagerNodeLoadInfo`,
so the `--cluster create` and `--cluster add-node` interfaces have not changed.
We will use the `cluster-port` when we are doing `CLUSTER MEET`, also note that `CLUSTER MEET` bus-port
parameter was added in 4.0, so if the bus_port (the one in redis-cli) is 0, or equal (port + 10000),
we just call `CLUSTER MEET` with 2 arguments, using the old form.
Co-authored-by: Madelyn Olson <34459052+madolson@users.noreply.github.com>
2022-07-11 16:23:31 +08:00
|
|
|
} else {
|
|
|
|
fail "Cluster doesn't stabilize"
|
|
|
|
}
|
|
|
|
|
|
|
|
# Make sure each node can meet other nodes
|
2022-07-12 10:41:29 -07:00
|
|
|
assert_equal 3 [CI 0 cluster_known_nodes]
|
|
|
|
assert_equal 3 [CI 1 cluster_known_nodes]
|
|
|
|
assert_equal 3 [CI 2 cluster_known_nodes]
|
Add cluster-port support to redis-cli --cluster (#10344)
In #9389, we add a new `cluster-port` config and make cluster bus port configurable,
and currently redis-cli --cluster create/add-node doesn't support with a configurable `cluster-port` instance.
Because redis-cli uses the old way (port + 10000) to send the `CLUSTER MEET` command.
Now we add this support on redis-cli `--cluster`, note we don't need to explicitly pass in the
`cluster-port` parameter, we can get the real `cluster-port` of the node in `clusterManagerNodeLoadInfo`,
so the `--cluster create` and `--cluster add-node` interfaces have not changed.
We will use the `cluster-port` when we are doing `CLUSTER MEET`, also note that `CLUSTER MEET` bus-port
parameter was added in 4.0, so if the bus_port (the one in redis-cli) is 0, or equal (port + 10000),
we just call `CLUSTER MEET` with 2 arguments, using the old form.
Co-authored-by: Madelyn Olson <34459052+madolson@users.noreply.github.com>
2022-07-11 16:23:31 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
test {redis-cli --cluster add-node with cluster-port} {
|
|
|
|
# Adding node to the cluster (without cluster-port)
|
|
|
|
exec src/redis-cli --cluster-yes --cluster add-node \
|
|
|
|
127.0.0.1:[srv -3 port] \
|
|
|
|
127.0.0.1:[srv 0 port]
|
|
|
|
|
2022-10-03 14:21:41 +08:00
|
|
|
wait_for_cluster_size 4
|
|
|
|
|
Add cluster-port support to redis-cli --cluster (#10344)
In #9389, we add a new `cluster-port` config and make cluster bus port configurable,
and currently redis-cli --cluster create/add-node doesn't support with a configurable `cluster-port` instance.
Because redis-cli uses the old way (port + 10000) to send the `CLUSTER MEET` command.
Now we add this support on redis-cli `--cluster`, note we don't need to explicitly pass in the
`cluster-port` parameter, we can get the real `cluster-port` of the node in `clusterManagerNodeLoadInfo`,
so the `--cluster create` and `--cluster add-node` interfaces have not changed.
We will use the `cluster-port` when we are doing `CLUSTER MEET`, also note that `CLUSTER MEET` bus-port
parameter was added in 4.0, so if the bus_port (the one in redis-cli) is 0, or equal (port + 10000),
we just call `CLUSTER MEET` with 2 arguments, using the old form.
Co-authored-by: Madelyn Olson <34459052+madolson@users.noreply.github.com>
2022-07-11 16:23:31 +08:00
|
|
|
wait_for_condition 1000 50 {
|
2022-07-12 10:41:29 -07:00
|
|
|
[CI 0 cluster_state] eq {ok} &&
|
|
|
|
[CI 1 cluster_state] eq {ok} &&
|
|
|
|
[CI 2 cluster_state] eq {ok} &&
|
|
|
|
[CI 3 cluster_state] eq {ok}
|
Add cluster-port support to redis-cli --cluster (#10344)
In #9389, we add a new `cluster-port` config and make cluster bus port configurable,
and currently redis-cli --cluster create/add-node doesn't support with a configurable `cluster-port` instance.
Because redis-cli uses the old way (port + 10000) to send the `CLUSTER MEET` command.
Now we add this support on redis-cli `--cluster`, note we don't need to explicitly pass in the
`cluster-port` parameter, we can get the real `cluster-port` of the node in `clusterManagerNodeLoadInfo`,
so the `--cluster create` and `--cluster add-node` interfaces have not changed.
We will use the `cluster-port` when we are doing `CLUSTER MEET`, also note that `CLUSTER MEET` bus-port
parameter was added in 4.0, so if the bus_port (the one in redis-cli) is 0, or equal (port + 10000),
we just call `CLUSTER MEET` with 2 arguments, using the old form.
Co-authored-by: Madelyn Olson <34459052+madolson@users.noreply.github.com>
2022-07-11 16:23:31 +08:00
|
|
|
} else {
|
|
|
|
fail "Cluster doesn't stabilize"
|
|
|
|
}
|
|
|
|
|
|
|
|
# Adding node to the cluster (with cluster-port)
|
|
|
|
exec src/redis-cli --cluster-yes --cluster add-node \
|
|
|
|
127.0.0.1:[srv -4 port] \
|
|
|
|
127.0.0.1:[srv 0 port]
|
|
|
|
|
2022-10-03 14:21:41 +08:00
|
|
|
wait_for_cluster_size 5
|
|
|
|
|
Add cluster-port support to redis-cli --cluster (#10344)
In #9389, we add a new `cluster-port` config and make cluster bus port configurable,
and currently redis-cli --cluster create/add-node doesn't support with a configurable `cluster-port` instance.
Because redis-cli uses the old way (port + 10000) to send the `CLUSTER MEET` command.
Now we add this support on redis-cli `--cluster`, note we don't need to explicitly pass in the
`cluster-port` parameter, we can get the real `cluster-port` of the node in `clusterManagerNodeLoadInfo`,
so the `--cluster create` and `--cluster add-node` interfaces have not changed.
We will use the `cluster-port` when we are doing `CLUSTER MEET`, also note that `CLUSTER MEET` bus-port
parameter was added in 4.0, so if the bus_port (the one in redis-cli) is 0, or equal (port + 10000),
we just call `CLUSTER MEET` with 2 arguments, using the old form.
Co-authored-by: Madelyn Olson <34459052+madolson@users.noreply.github.com>
2022-07-11 16:23:31 +08:00
|
|
|
wait_for_condition 1000 50 {
|
2022-07-12 10:41:29 -07:00
|
|
|
[CI 0 cluster_state] eq {ok} &&
|
|
|
|
[CI 1 cluster_state] eq {ok} &&
|
|
|
|
[CI 2 cluster_state] eq {ok} &&
|
|
|
|
[CI 3 cluster_state] eq {ok} &&
|
|
|
|
[CI 4 cluster_state] eq {ok}
|
Add cluster-port support to redis-cli --cluster (#10344)
In #9389, we add a new `cluster-port` config and make cluster bus port configurable,
and currently redis-cli --cluster create/add-node doesn't support with a configurable `cluster-port` instance.
Because redis-cli uses the old way (port + 10000) to send the `CLUSTER MEET` command.
Now we add this support on redis-cli `--cluster`, note we don't need to explicitly pass in the
`cluster-port` parameter, we can get the real `cluster-port` of the node in `clusterManagerNodeLoadInfo`,
so the `--cluster create` and `--cluster add-node` interfaces have not changed.
We will use the `cluster-port` when we are doing `CLUSTER MEET`, also note that `CLUSTER MEET` bus-port
parameter was added in 4.0, so if the bus_port (the one in redis-cli) is 0, or equal (port + 10000),
we just call `CLUSTER MEET` with 2 arguments, using the old form.
Co-authored-by: Madelyn Olson <34459052+madolson@users.noreply.github.com>
2022-07-11 16:23:31 +08:00
|
|
|
} else {
|
|
|
|
fail "Cluster doesn't stabilize"
|
|
|
|
}
|
|
|
|
|
|
|
|
# Make sure each node can meet other nodes
|
2022-07-12 10:41:29 -07:00
|
|
|
assert_equal 5 [CI 0 cluster_known_nodes]
|
|
|
|
assert_equal 5 [CI 1 cluster_known_nodes]
|
|
|
|
assert_equal 5 [CI 2 cluster_known_nodes]
|
|
|
|
assert_equal 5 [CI 3 cluster_known_nodes]
|
|
|
|
assert_equal 5 [CI 4 cluster_known_nodes]
|
Add cluster-port support to redis-cli --cluster (#10344)
In #9389, we add a new `cluster-port` config and make cluster bus port configurable,
and currently redis-cli --cluster create/add-node doesn't support with a configurable `cluster-port` instance.
Because redis-cli uses the old way (port + 10000) to send the `CLUSTER MEET` command.
Now we add this support on redis-cli `--cluster`, note we don't need to explicitly pass in the
`cluster-port` parameter, we can get the real `cluster-port` of the node in `clusterManagerNodeLoadInfo`,
so the `--cluster create` and `--cluster add-node` interfaces have not changed.
We will use the `cluster-port` when we are doing `CLUSTER MEET`, also note that `CLUSTER MEET` bus-port
parameter was added in 4.0, so if the bus_port (the one in redis-cli) is 0, or equal (port + 10000),
we just call `CLUSTER MEET` with 2 arguments, using the old form.
Co-authored-by: Madelyn Olson <34459052+madolson@users.noreply.github.com>
2022-07-11 16:23:31 +08:00
|
|
|
}
|
|
|
|
# stop 5 servers
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2022-03-16 18:11:38 +01:00
|
|
|
} ;# tags
|
2022-03-18 20:10:24 +08:00
|
|
|
|
|
|
|
set ::singledb $old_singledb
|