2011-04-11 10:41:06 -04:00
|
|
|
#!/usr/bin/env ruby
|
|
|
|
|
2018-06-27 10:42:22 -04:00
|
|
|
def colorized(str, color)
|
|
|
|
return str if !(ENV['TERM'] || '')["xterm"]
|
|
|
|
color_code = {
|
|
|
|
white: 29,
|
|
|
|
bold: '29;1',
|
|
|
|
black: 30,
|
|
|
|
red: 31,
|
|
|
|
green: 32,
|
|
|
|
yellow: 33,
|
|
|
|
blue: 34,
|
|
|
|
magenta: 35,
|
|
|
|
cyan: 36,
|
|
|
|
gray: 37
|
|
|
|
}[color]
|
|
|
|
return str if !color_code
|
|
|
|
"\033[#{color_code}m#{str}\033[0m"
|
2011-04-11 10:58:47 -04:00
|
|
|
end
|
2011-04-11 10:41:06 -04:00
|
|
|
|
2018-06-27 10:42:22 -04:00
|
|
|
class String
|
2013-11-05 05:24:24 -05:00
|
|
|
|
2018-06-27 10:42:22 -04:00
|
|
|
%w(white bold black red green yellow blue magenta cyan gray).each{|color|
|
|
|
|
color = :"#{color}"
|
|
|
|
define_method(color){
|
|
|
|
colorized(self, color)
|
2013-02-22 06:25:16 -05:00
|
|
|
}
|
2018-06-27 10:42:22 -04:00
|
|
|
}
|
2011-04-12 11:06:33 -04:00
|
|
|
|
2011-04-11 10:58:47 -04:00
|
|
|
end
|
|
|
|
|
2018-06-27 10:42:22 -04:00
|
|
|
COMMANDS = %w(create check info fix reshard rebalance add-node
|
|
|
|
del-node set-timeout call import help)
|
2014-07-18 11:43:49 -04:00
|
|
|
|
2018-06-27 10:42:22 -04:00
|
|
|
ALLOWED_OPTIONS={
|
|
|
|
"create" => {"replicas" => true},
|
|
|
|
"add-node" => {"slave" => false, "master-id" => true},
|
|
|
|
"import" => {"from" => :required, "copy" => false, "replace" => false},
|
|
|
|
"reshard" => {"from" => true, "to" => true, "slots" => true, "yes" => false, "timeout" => true, "pipeline" => true},
|
|
|
|
"rebalance" => {"weight" => [], "auto-weights" => false, "use-empty-masters" => false, "timeout" => true, "simulate" => false, "pipeline" => true, "threshold" => true},
|
|
|
|
"fix" => {"timeout" => 0},
|
|
|
|
}
|
2013-02-27 09:58:41 -05:00
|
|
|
|
2018-06-27 10:42:22 -04:00
|
|
|
def parse_options(cmd)
|
|
|
|
cmd = cmd.downcase
|
|
|
|
idx = 0
|
|
|
|
options = {}
|
|
|
|
args = []
|
|
|
|
while (arg = ARGV.shift)
|
|
|
|
if arg[0..1] == "--"
|
|
|
|
option = arg[2..-1]
|
|
|
|
|
|
|
|
# --verbose is a global option
|
|
|
|
if option == "--verbose"
|
|
|
|
options['verbose'] = true
|
|
|
|
next
|
|
|
|
end
|
|
|
|
if ALLOWED_OPTIONS[cmd] == nil ||
|
|
|
|
ALLOWED_OPTIONS[cmd][option] == nil
|
|
|
|
next
|
|
|
|
end
|
|
|
|
if ALLOWED_OPTIONS[cmd][option] != false
|
|
|
|
value = ARGV.shift
|
|
|
|
next if !value
|
2014-01-17 05:48:42 -05:00
|
|
|
else
|
2018-06-27 10:42:22 -04:00
|
|
|
value = true
|
2014-03-11 09:58:33 -04:00
|
|
|
end
|
2016-10-09 12:13:20 -04:00
|
|
|
|
2018-06-27 10:42:22 -04:00
|
|
|
# If the option is set to [], it's a multiple arguments
|
|
|
|
# option. We just queue every new value into an array.
|
|
|
|
if ALLOWED_OPTIONS[cmd][option] == []
|
|
|
|
options[option] = [] if !options[option]
|
|
|
|
options[option] << value
|
2013-10-11 11:33:19 -04:00
|
|
|
else
|
2018-06-27 10:42:22 -04:00
|
|
|
options[option] = value
|
2013-10-11 11:33:19 -04:00
|
|
|
end
|
2018-06-27 10:42:22 -04:00
|
|
|
else
|
|
|
|
next if arg[0,1] == '-'
|
|
|
|
args << arg
|
2013-10-11 11:33:19 -04:00
|
|
|
end
|
|
|
|
end
|
2014-05-10 11:59:31 -04:00
|
|
|
|
2018-06-27 10:42:22 -04:00
|
|
|
return options,args
|
2014-05-10 11:59:31 -04:00
|
|
|
end
|
|
|
|
|
2018-06-27 10:42:22 -04:00
|
|
|
def command_example(cmd, args, opts)
|
|
|
|
cmd = "redis-cli --cluster #{cmd}"
|
|
|
|
args.each{|a|
|
|
|
|
a = a.to_s
|
|
|
|
a = a.inspect if a[' ']
|
|
|
|
cmd << " #{a}"
|
|
|
|
}
|
|
|
|
opts.each{|opt, val|
|
|
|
|
opt = " --cluster-#{opt.downcase}"
|
|
|
|
if val != true
|
|
|
|
val = val.join(' ') if val.is_a? Array
|
|
|
|
opt << " #{val}"
|
2014-01-16 10:23:28 -05:00
|
|
|
end
|
2018-06-27 10:42:22 -04:00
|
|
|
cmd << opt
|
2011-04-13 04:38:56 -04:00
|
|
|
}
|
2018-06-27 10:42:22 -04:00
|
|
|
cmd
|
2011-04-11 10:41:06 -04:00
|
|
|
end
|
|
|
|
|
2018-06-27 10:42:22 -04:00
|
|
|
$command = ARGV.shift
|
|
|
|
$opts, $args = parse_options($command) if $command
|
|
|
|
|
|
|
|
puts "WARNING: redis-trib.rb is not longer available!".yellow
|
|
|
|
puts "You should use #{'redis-cli'.bold} instead."
|
|
|
|
puts ''
|
|
|
|
puts "All commands and features belonging to redis-trib.rb "+
|
|
|
|
"have been moved\nto redis-cli."
|
|
|
|
puts "In order to use them you should call redis-cli with the #{'--cluster'.bold}"
|
|
|
|
puts "option followed by the subcommand name, arguments and options."
|
|
|
|
puts ''
|
|
|
|
puts "Use the following syntax:"
|
|
|
|
puts "redis-cli --cluster SUBCOMMAND [ARGUMENTS] [OPTIONS]".bold
|
|
|
|
puts ''
|
|
|
|
puts "Example:"
|
|
|
|
if $command
|
|
|
|
example = command_example $command, $args, $opts
|
|
|
|
else
|
|
|
|
example = "redis-cli --cluster info 127.0.0.1:7000"
|
2011-04-11 10:41:06 -04:00
|
|
|
end
|
2018-06-27 10:42:22 -04:00
|
|
|
puts example.bold
|
|
|
|
puts ''
|
|
|
|
puts "To get help about all subcommands, type:"
|
|
|
|
puts "redis-cli --cluster help".bold
|
|
|
|
puts ''
|
|
|
|
exit 1
|