目录:
解决-gem install redis提示版本问题
解决-Ruby版本过低的问题
解决-哈希槽被占用错误问题
解决-集群节点不为空
本文根据笔者亲身搭建Redis集群环境遇到的一些问题,在此把它们整理归纳,问题描述已经解决方法:
1.1 解决-gem install redis提示版本问题
gem install redis此命令无法安装,报错:
[root@hadoop01 redis-4.0.11]# gem install redis
ERROR: Error installing redis:
redis requires Ruby version >= 2.3.0.
[root@hadoop01 redis-4.0.11]#
Redis依赖的Ruby的版本太低,需要2.3.0或以上版本。
查看ruby版本:
[root@hadoop01 redis-4.0.11]# ruby -v
ruby 1.8.7 (2013-06-27 patchlevel 374) [x86_64-linux]
当前ruby版本1.8.7,需要升级到2.3.0或以上版本。具体解决方案详见:1.2解决ruby版本过低的问题
1.2 解决-Ruby版本过低的问题
错误:Ruby与redis版本不兼容造成的错误:
data:image/s3,"s3://crabby-images/55e02/55e023186130fe727008c738e47ca13113c22379" alt=""
解决方法:
gem list
gem uninstall redis --version 3.0.0
gem install redis
1、yum install curl
2、curl -sSL https://rvm.io/mpapis.asc | gpg2 --import -
data:image/s3,"s3://crabby-images/ccc83/ccc839529ac980ea8007a514e6f2afb0a2deab42" alt=""
3、curl -sSL https://rvm.io/pkuczynski.asc | gpg2 --import -
data:image/s3,"s3://crabby-images/d217f/d217f9efdb17cadac484ca84292bb21c38b8a1b7" alt=""
4、curl -L https://get.rvm.io | bash -s stable
data:image/s3,"s3://crabby-images/30705/307058fb5d523f435c818e251cf443c9ca73af4c" alt=""
5、查找rvm的启动文件:find / -name rvm.sh
data:image/s3,"s3://crabby-images/7c27b/7c27b9a0f64cb26c51be751db2149fb9cd783f07" alt=""
6、source /etc/profile.d/rvm.sh
7、rvm requirements
data:image/s3,"s3://crabby-images/d6c2f/d6c2f90d024a671d2d6e97a1853f7438535bc098" alt=""
8、rvmsudo yum install -y gcc-c++ patch readline readline-devel zlib zlib-devel libyaml-devel libffi-devel openssl-devel make bzip2 autoconf automake libtool bison iconv-devel
9、source /usr/local/rvm/scripts/rvm
10、rvm list known
data:image/s3,"s3://crabby-images/0712e/0712e25ef1db873a7aecbc486d284791e0c0374a" alt=""
11、rvm install 2.3.8
data:image/s3,"s3://crabby-images/50229/50229074e83b8a5ad7c2ac3fae8e6ca50feedcb7" alt=""
12、rvm use 2.3.8
data:image/s3,"s3://crabby-images/4ac1c/4ac1c60f155ac1de9338662331bcdd02b4fc63d2" alt=""
13、删除低版本 rvm remove 1.8.7
14、ruby –v
data:image/s3,"s3://crabby-images/26119/261193d7215c2fa049f92c23a1f8c35a5c14e292" alt=""
15、gem install redis
data:image/s3,"s3://crabby-images/83207/8320766aad1e9e55027e95b46bcdcd7da6c868ac" alt=""
参考:https://blog.csdn.net/chengxiadenghuo/article/details/103531480
1.3 解决-哈希槽被占用错误问题
错误:提示哈希槽被占用
/usr/lib/ruby/gems/-2.3.8/gems/redis-4.1.3/lib/redis/client.rb:126:in `call': ERR Slot 5461 is already busy (Redis::CommandError)
data:image/s3,"s3://crabby-images/5a999/5a999120ce981c663f39c6275095f5b47df3bbd6" alt=""
解决方法:所有节点,清除上一次的错误残留,重启Cluster节点。
[root@hadoop01 bin]# redis-cli -h 192.168.100.129 -p 7000
192.168.100.129:7000> flushall
OK
192.168.100.129:7000> cluster reset
OK
192.168.100.129:7000>
1.4 解决-集群节点不为空
启动集群时错误提示:
[ERR] Node 192.168.100.129:7000 is not empty. Either the node already knows other nodes (check with CLUSTER NODES) or contains some key in database 0.
解决方法:
删除所有节点的appendonly.aof、nodes.conf,重新启动服务。
|