美文网首页
redis集群安装问题:ruby依赖redis.gem

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

作者: 李不言被占用了 | 来源:发表于2018-10-26 11:36 被阅读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)
    更新镜像源的方法

    最后

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

    相关文章

      网友评论

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

          本文链接:https://www.haomeiwen.com/subject/iytktqtx.html