mirror of
https://github.com/fluencelabs/redis
synced 2025-04-04 08:41:04 +00:00
Cluster: rough support for sub-command options in redis-trib.
This commit is contained in:
parent
0c9f60a628
commit
85f52ebcd8
@ -589,19 +589,19 @@ class RedisTrib
|
|||||||
|
|
||||||
# redis-trib subcommands implementations
|
# redis-trib subcommands implementations
|
||||||
|
|
||||||
def check_cluster_cmd
|
def check_cluster_cmd(argv,opt)
|
||||||
load_cluster_info_from_node(ARGV[1])
|
load_cluster_info_from_node(argv[0])
|
||||||
check_cluster
|
check_cluster
|
||||||
end
|
end
|
||||||
|
|
||||||
def fix_cluster_cmd
|
def fix_cluster_cmd(argv,opt)
|
||||||
@fix = true
|
@fix = true
|
||||||
load_cluster_info_from_node(ARGV[1])
|
load_cluster_info_from_node(argv[0])
|
||||||
check_cluster
|
check_cluster
|
||||||
end
|
end
|
||||||
|
|
||||||
def reshard_cluster_cmd
|
def reshard_cluster_cmd(argv,opt)
|
||||||
load_cluster_info_from_node(ARGV[1])
|
load_cluster_info_from_node(argv[0])
|
||||||
check_cluster
|
check_cluster
|
||||||
if @errors.length != 0
|
if @errors.length != 0
|
||||||
puts "*** Please fix your cluster problems before resharding"
|
puts "*** Please fix your cluster problems before resharding"
|
||||||
@ -667,9 +667,9 @@ class RedisTrib
|
|||||||
}
|
}
|
||||||
end
|
end
|
||||||
|
|
||||||
def create_cluster_cmd
|
def create_cluster_cmd(argv,opt)
|
||||||
xputs ">>> Creating cluster"
|
xputs ">>> Creating cluster"
|
||||||
ARGV[1..-1].each{|n|
|
argv[0..-1].each{|n|
|
||||||
node = ClusterNode.new(n)
|
node = ClusterNode.new(n)
|
||||||
node.connect(:abort => true)
|
node.connect(:abort => true)
|
||||||
node.assert_cluster
|
node.assert_cluster
|
||||||
@ -693,15 +693,15 @@ class RedisTrib
|
|||||||
check_cluster
|
check_cluster
|
||||||
end
|
end
|
||||||
|
|
||||||
def addnode_cluster_cmd
|
def addnode_cluster_cmd(argv,opt)
|
||||||
xputs ">>> Adding node #{ARGV[1]} to cluster #{ARGV[2]}"
|
xputs ">>> Adding node #{argv[0]} to cluster #{argv[1]}"
|
||||||
|
|
||||||
# Check the existing cluster
|
# Check the existing cluster
|
||||||
load_cluster_info_from_node(ARGV[2])
|
load_cluster_info_from_node(argv[1])
|
||||||
check_cluster
|
check_cluster
|
||||||
|
|
||||||
# Add the new node
|
# Add the new node
|
||||||
new = ClusterNode.new(ARGV[1])
|
new = ClusterNode.new(argv[0])
|
||||||
new.connect(:abort => true)
|
new.connect(:abort => true)
|
||||||
new.assert_cluster
|
new.assert_cluster
|
||||||
new.load_info
|
new.load_info
|
||||||
@ -713,10 +713,39 @@ class RedisTrib
|
|||||||
new.r.cluster("meet",first[:host],first[:port])
|
new.r.cluster("meet",first[:host],first[:port])
|
||||||
end
|
end
|
||||||
|
|
||||||
def help_cluster_cmd
|
def help_cluster_cmd(opt)
|
||||||
show_help
|
show_help
|
||||||
exit 0
|
exit 0
|
||||||
end
|
end
|
||||||
|
|
||||||
|
# Parse the options for the specific command "cmd".
|
||||||
|
# Returns an hash populate with option => value pairs, and the index of
|
||||||
|
# the first non-option argument in ARGV.
|
||||||
|
def parse_options(cmd)
|
||||||
|
idx = 1 ; # Current index into ARGV
|
||||||
|
options={}
|
||||||
|
while idx < ARGV.length && ARGV[idx][0..1] == '--'
|
||||||
|
if ARGV[idx][0..1] == "--"
|
||||||
|
option = ARGV[idx][2..-1]
|
||||||
|
idx += 1
|
||||||
|
if ALLOWED_OPTIONS[cmd] == nil || ALLOWED_OPTIONS[cmd][option] == nil
|
||||||
|
puts "Unknown option '#{option}' for command '#{cmd}'"
|
||||||
|
exit 1
|
||||||
|
end
|
||||||
|
if ALLOWED_OPTIONS[cmd][option]
|
||||||
|
value = ARGV[idx]
|
||||||
|
idx += 1
|
||||||
|
else
|
||||||
|
value = true
|
||||||
|
end
|
||||||
|
options[option] = value
|
||||||
|
else
|
||||||
|
# Remaining arguments are not options.
|
||||||
|
break
|
||||||
|
end
|
||||||
|
end
|
||||||
|
return options,idx
|
||||||
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
COMMANDS={
|
COMMANDS={
|
||||||
@ -728,6 +757,10 @@ COMMANDS={
|
|||||||
"help" => ["help_cluster_cmd", 1, "(show this help)"]
|
"help" => ["help_cluster_cmd", 1, "(show this help)"]
|
||||||
}
|
}
|
||||||
|
|
||||||
|
ALLOWED_OPTIONS={
|
||||||
|
"create" => {"slaves" => false}
|
||||||
|
}
|
||||||
|
|
||||||
def show_help
|
def show_help
|
||||||
puts "Usage: redis-trib <command> <arguments ...>"
|
puts "Usage: redis-trib <command> <arguments ...>"
|
||||||
puts
|
puts
|
||||||
@ -749,7 +782,10 @@ if !cmd_spec
|
|||||||
puts "Unknown redis-trib subcommand '#{ARGV[0]}'"
|
puts "Unknown redis-trib subcommand '#{ARGV[0]}'"
|
||||||
exit 1
|
exit 1
|
||||||
end
|
end
|
||||||
rt.check_arity(cmd_spec[1],ARGV.length)
|
|
||||||
|
# Parse options
|
||||||
|
cmd_options,first_non_option = rt.parse_options(ARGV[0].downcase)
|
||||||
|
rt.check_arity(cmd_spec[1],ARGV.length-(first_non_option-1))
|
||||||
|
|
||||||
# Dispatch
|
# Dispatch
|
||||||
rt.send(cmd_spec[0])
|
rt.send(cmd_spec[0],ARGV[first_non_option..-1],cmd_options)
|
||||||
|
Loading…
x
Reference in New Issue
Block a user