热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

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

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

出现如下问题,而且你确定你已经安装了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 `

'

问题的根源在于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 `

'

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

gem install redis

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

内网机器无rubygems源

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

  1. 下载地址
    国外镜像
    国内ruby gems镜像
    《redis集群安装问题:ruby依赖redis.gem》 搜索

《redis集群安装问题:ruby依赖redis.gem》 挑选你需要的版本

  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 `

'

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

《redis集群安装问题:ruby依赖redis.gem》 代码

从代码中可以看到,
require ‘redis’这行代码有问题,就是说这个脚本需要依赖
redis这个组件,也就是
redis.gem,即我们安装的那个。出现这个问题的原因当然就是ruby找不到相应的依赖,一般在linux下面,可能是权限问题,也有可能是路径问题:ruby去找它认为你安装redis.gem的路径,没有找到,那就报错了。

简单介绍一下,ruby的依赖有点像python的import或者java里的import,java里需要知道classpath才能通过classloader加载到相应的依赖,ruby也是一样的,那ruby会去哪里找reids.gem呢?
gem env命令给你答案:

《redis集群安装问题:ruby依赖redis.gem》 普通用户视图下的gem env
《redis集群安装问题:ruby依赖redis.gem》 root用户视图下的gem env

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

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

《redis集群安装问题:ruby依赖redis.gem》 image.png

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

一点点背景知识

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

最后

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


推荐阅读
  • 在使用 `requests` 库进行 HTTP 请求时,如果遇到 `requests.exceptions.SSLError: HTTPSConnectionPool` 错误,通常是因为 SSL 证书验证失败。解决这一问题的方法包括:检查目标网站的 SSL 证书是否有效、更新本地的 CA 证书库、禁用 SSL 验证(不推荐用于生产环境)或使用自定义的 SSL 上下文。此外,确保 `requests` 库和相关依赖项已更新到最新版本,以避免潜在的安全漏洞。 ... [详细]
  • 本文深入探讨了使用Puppet进行软件包分发与管理的方法。首先介绍了fpm这一跨平台的软件包制作工具,其简便的操作流程使得软件包的创建变得轻松快捷。fpm的项目地址为:https://github.com/jordansissel/fpm。通过结合Puppet和fpm,可以实现高效、可靠的软件包管理和部署。 ... [详细]
  • 在 CentOS 7 中,为了扩展可用软件包的数量,通常需要配置多个第三方软件源。这些第三方源包括 EPEL、Nux Dextop 和 ELRepo 等,它们提供了大量官方源中未包含的软件包,从而增强了系统的功能性和灵活性。通过正确配置这些源,用户可以轻松安装和管理更多种类的软件,满足不同的需求。 ... [详细]
  • 在前文探讨了Spring如何为特定的bean选择合适的通知器后,本文将进一步深入分析Spring AOP框架中代理对象的生成机制。具体而言,我们将详细解析如何通过代理技术将通知器(Advisor)中包含的通知(Advice)应用到目标bean上,以实现切面编程的核心功能。 ... [详细]
  • 本文详细介绍了在 Vue.js 前端框架中集成 vue-i18n 插件以实现多语言支持的方法。通过具体的配置步骤和示例代码,帮助开发者快速掌握如何在项目中实现国际化功能,提升用户体验。同时,文章还探讨了常见的多语言切换问题及解决方案,为开发人员提供了实用的参考。 ... [详细]
  • 在腾讯云服务器上部署Nginx的详细指南中,首先需要确保安装必要的依赖包。如果这些依赖包已安装,可直接跳过此步骤。具体命令包括 `yum -y install gcc gcc-c++ wget net-tools pcre-devel zlib-devel`。接下来,本文将详细介绍如何下载、编译和配置Nginx,以确保其在腾讯云服务器上顺利运行。此外,还将提供一些优化建议,帮助用户提升Nginx的性能和安全性。 ... [详细]
  • 美团优选推荐系统架构师 L7/L8:算法与工程深度融合 ... [详细]
  • 本文介绍了UUID(通用唯一标识符)的概念及其在JavaScript中生成Java兼容UUID的代码实现与优化技巧。UUID是一个128位的唯一标识符,广泛应用于分布式系统中以确保唯一性。文章详细探讨了如何利用JavaScript生成符合Java标准的UUID,并提供了多种优化方法,以提高生成效率和兼容性。 ... [详细]
  • 掌握PHP编程必备知识与技巧——全面教程在当今的PHP开发中,了解并运用最新的技术和最佳实践至关重要。本教程将详细介绍PHP编程的核心知识与实用技巧。首先,确保你正在使用PHP 5.3或更高版本,最好是最新版本,以充分利用其性能优化和新特性。此外,我们还将探讨代码结构、安全性和性能优化等方面的内容,帮助你成为一名更高效的PHP开发者。 ... [详细]
  • 如果程序使用Go语言编写并涉及单向或双向TLS认证,可能会遭受CPU拒绝服务攻击(DoS)。本文深入分析了CVE-2018-16875漏洞,探讨其成因、影响及防范措施,为开发者提供全面的安全指导。 ... [详细]
  • 2019年后蚂蚁集团与拼多多面试经验详述与深度剖析
    2019年后蚂蚁集团与拼多多面试经验详述与深度剖析 ... [详细]
  • 数据结构与算法:HyperLogLog 统计、布隆过滤器应用、缓存机制挑战及解决方案、Redis 性能优化与监控、哨兵模式、版本控制工具 Git
    本文探讨了数据结构与算法在实际应用中的多个方面。首先介绍了HyperLogLog算法,用于高效地进行基数统计,能够准确估算大规模数据集中的唯一元素数量。接着讨论了布隆过滤器的应用,该过滤器在空间效率和查询速度上具有显著优势,适用于大数据场景下的快速成员检测。此外,文章分析了缓存机制面临的挑战及其解决方案,包括LRU和LFU等策略,并详细阐述了Redis的性能优化与监控方法,如使用哨兵模式实现高可用性。最后,介绍了版本控制工具Git的基本操作和最佳实践,帮助开发者有效管理代码版本。 ... [详细]
  • 利用Redis HyperLogLog高效统计微博日活跃和月活跃用户数
    本文探讨了如何利用Redis的HyperLogLog数据结构高效地统计微博平台的日活跃用户(DAU)和月活跃用户(MAU)数量。通过HyperLogLog的高精度和低内存消耗特性,可以实现对大规模用户数据的实时统计与分析,为平台运营提供有力的数据支持。 ... [详细]
  • 开发心得:利用 Redis 构建分布式系统的轻量级协调机制
    开发心得:利用 Redis 构建分布式系统的轻量级协调机制 ... [详细]
  • 在Windows命令行中,通过Conda工具可以高效地管理和操作虚拟环境。具体步骤包括:1. 列出现有虚拟环境:`conda env list`;2. 创建新虚拟环境:`conda create --name 环境名`;3. 删除虚拟环境:`conda env remove --name 环境名`。这些命令不仅简化了环境管理流程,还提高了开发效率。此外,Conda还支持环境文件导出和导入,方便在不同机器间迁移配置。 ... [详细]
author-avatar
mikewuhan_689
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有