Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
Turbo码先生
redis
提交
85b514d1
R
redis
项目概览
Turbo码先生
/
redis
与 Fork 源项目一致
从无法访问的项目Fork
通知
1
Star
0
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
R
redis
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
体验新版 GitCode,发现更多精彩内容 >>
提交
85b514d1
编写于
9月 29, 2011
作者:
A
antirez
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
redis-trib: reshard command work in progress
上级
9514aa32
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
28 addition
and
3 deletion
+28
-3
src/redis-trib.rb
src/redis-trib.rb
+28
-3
未找到文件。
src/redis-trib.rb
浏览文件 @
85b514d1
...
...
@@ -164,7 +164,7 @@ class ClusterNode
x
.
count
==
1
?
x
.
first
.
to_s
:
"
#{
x
.
first
}
-
#{
x
.
last
}
"
}.
join
(
","
)
"[
#{
@info
[
:cluster_state
].
upcase
}
]
#{
self
.
to_s
.
ljust
(
25
)
}
slots:
#{
slots
}
"
"[
#{
@info
[
:cluster_state
].
upcase
}
]
#{
self
.
info
[
:name
]
}
#{
self
.
to_s
.
ljust
(
25
)
}
slots:
#{
slots
}
"
end
def
info
...
...
@@ -197,8 +197,16 @@ class RedisTrib
@nodes
<<
node
end
def
get_node_by_name
(
name
)
@nodes
.
each
{
|
n
|
return
n
if
n
.
info
[
:name
]
==
name
.
downcase
}
return
nil
end
def
check_cluster
puts
"Performing Cluster Check (using node
#{
@nodes
[
0
]
}
)"
errors
=
[]
show_nodes
# Check if all the slots are covered
slots
=
{}
...
...
@@ -208,8 +216,10 @@ class RedisTrib
if
slots
.
length
==
4096
puts
"[OK] All 4096 slots covered."
else
puts
"[ERR] Not all 4096 slots are covered by nodes."
errors
<<
"[ERR] Not all 4096 slots are covered by nodes."
puts
errors
[
-
1
]
end
return
errors
end
def
alloc_slots
...
...
@@ -279,6 +289,20 @@ class RedisTrib
check_cluster
end
def
reshard_cluster_cmd
load_cluster_info_from_node
(
ARGV
[
1
])
errors
=
check_cluster
if
errors
.
length
!=
0
puts
"Please fix your cluster problems before resharding."
exit
1
end
many
=
0
while
many
<=
0
or
many
>
4096
print
"How many slots do you want to move? "
many
=
STDIN
.
gets
.
to_i
end
end
def
create_cluster_cmd
puts
"Creating cluster"
ARGV
[
1
..-
1
].
each
{
|
n
|
...
...
@@ -302,7 +326,8 @@ end
COMMANDS
=
{
"create"
=>
[
"create_cluster_cmd"
,
-
2
,
"host1:port host2:port ... hostN:port"
],
"check"
=>
[
"check_cluster_cmd"
,
2
,
"host:port"
]
"check"
=>
[
"check_cluster_cmd"
,
2
,
"host:port"
],
"reshard"
=>
[
"reshard_cluster_cmd"
,
2
,
"host:port"
]
}
# Sanity check
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录