redis集群安装问题:ruby依赖redis.gem

2018-10-26  本文已影响259人  李不言被占用了

结论

出现如下问题,而且你确定你已经安装了redis.gem依赖,那么这篇文章值得你仔细参考。如果没有,也可以了解一下其中的原理。

/usr/local/lib/ruby/2.0.0/rubygems/core_ext/kernel_require.rb:45:in `require': cannot load such file -- redis (LoadError)
from /usr/local/lib/ruby/2.0.0/rubygems/core_ext/kernel_require.rb:45:in `require'
from ./redis-trib.rb:25:in `<main>'

问题的根源在于ruby的require找不到你安装的redis.gem,可能是权限问题,可能是安装用户不同的问题。问题解决了,就可以搭建集群了。

前言

redis集群安装,主要是大家需要利用官方的ruby脚本redis-trib.rb来帮助我们搭建集群,既然用到ruby了,ruby的安装就必不可少了。基本上大家遇到的问题都是ruby相关的问题。这些问题解决了,基本上就可以搭建好了。或者你够犀利的话,可以自己手动敲命令创建,或者自己写个脚步shell/python目测也是可以的。

你可能会碰到的问题

大家搭建redis集群会碰到的问题形形色色,基本上没有一个标准答案,主要是每个人的基础环境不同。大概收集了一下,如果有碰到类似问题的童鞋可以了解,没有碰到的,跳过即可:
ruby版本过低的问题
缺少zlib或者openssl

今天要讲的问题

今天要讲的问题是,大家把ruby环境准备好后,执行:

./redis-trib.rb create --replicas 1 ${IP}:${PORT} ${IP}:${PORT} ${IP}:${PORT} ${IP}:${PORT} ${IP}:${PORT} ${IP}:${PORT}

这个命令的时候可能会出现下面这个错误:

/usr/local/lib/ruby/2.0.0/rubygems/core_ext/kernel_require.rb:45:in `require': cannot load such file -- redis (LoadError)
from /usr/local/lib/ruby/2.0.0/rubygems/core_ext/kernel_require.rb:45:in `require'
from ./redis-trib.rb:25:in `<main>'

于是乎你找到搜索引擎,基本上所有文章都告诉你:

gem install redis

可以解决这个问题。实际上是可以解决大部分人的问题。所以你的问题如果解决了,就没必要往下看了。

内网机器无rubygems源

如果你是内网集群而且公司没有rubygems源,你会发现你压根不能执行gem install redis,因为这个命令很像yum install,所以你需要离线安装:

  1. 下载地址
    国外镜像
    国内ruby gems镜像
    搜索
挑选你需要的版本
  1. 本地安装
# 笔者下载的是redis-3.2.2.gem
# (这一步一定要执行不然下面执行gem install 时会去链接该网址,连不上有可能执行不了下一步)
> gem sources –remove https://rubygems.org/
> gem install -l ./redis-3.2.2.gem
  1. 可以执行搭建脚本了

安装了redis依赖还是报错

如果你安装了redis还是报错:

/usr/local/lib/ruby/2.0.0/rubygems/core_ext/kernel_require.rb:45:in `require': cannot load such file -- redis (LoadError)
from /usr/local/lib/ruby/2.0.0/rubygems/core_ext/kernel_require.rb:45:in `require'
from ./redis-trib.rb:25:in `<main>'

那就是安装的redis.gem不能被redis-trib.rb脚本所依赖,先看看redis-trib.rb的第25行代码:

代码
从代码中可以看到,require ‘redis’这行代码有问题,就是说这个脚本需要依赖redis这个组件,也就是redis.gem,即我们安装的那个。出现这个问题的原因当然就是ruby找不到相应的依赖,一般在linux下面,可能是权限问题,也有可能是路径问题:ruby去找它认为你安装redis.gem的路径,没有找到,那就报错了。
简单介绍一下,ruby的依赖有点像python的import或者java里的import,java里需要知道classpath才能通过classloader加载到相应的依赖,ruby也是一样的,那ruby会去哪里找reids.gem呢?gem env命令给你答案: 普通用户视图下的gem env root用户视图下的gem env

看到这里就很显然了,require会去gem paths下面找你安装的redis.gem依赖。如果你用root用户去安装的gem,用root安装的redis.gem,那么安装的东西用普通用户执行require redis是找不到的,于是就有了上面这个报错。

最简单的方法,把你刚才安装的东西cp到你的gem paths下面:


image.png

这样,ruby require redis就能找到依赖了,就不会出现:cannot load such file -- redis (LoadError)这样的问题了。

一点点背景知识

ruby require
Ruby Gem命令详解
Ruby 模块(Module)
更新镜像源的方法

最后

如果你觉得对你有一丁点帮助,可以点个赞。

上一篇下一篇

猜你喜欢

热点阅读