解决方法:配置群集时# gem install redis 报错:Unable to require openssl, install OpenSSL and rebuild ruby

问题
前面已经在/usr/local/src安装了ruby-2.3.0.tar.gz、rubygems-2.4.2.tar.gz。
在配置 redis-3.1.1 群集中,使用gem install 安装 ruby redis 接口时报:

[plain] view plain copy

  1. # [[email protected] src]# gem install redis --version 3.0.0
  2. # # 由于源的原因,可能下载失败,就手动下载下来安装
  3. [[email protected] src]# gem install /usr/local/src/redis-3.2.1.gem
  4. ERROR: While executing gem ... (Gem::Exception)
  5. Unable to require openssl, install OpenSSL and rebuild ruby (preferred) or use non-HTTPS sources

原因
缺少openssl,需要安装openssl包,我现在这里来安装一个openssl-1.0.1s.tar.gz(下载链接:http://www.openssl.org/source/)

解决方法步骤
1.解压在/usr/local/src目录下,进入/usr/local/src/openssl-1.0.1s目录准备安装:

[plain] view plain copy

  1. [[email protected] src]# tar -xzvf openssl-1.0.1s.tar.gz
  2. [[email protected] src]# cd openssl-1.0.1s
  3. [[email protected] openssl-1.0.1s]# ./config -fPIC --prefix=/usr/local/openssl enable-shared
  4. [[email protected] openssl-1.0.1s]# ./config -t
  5. [[email protected] openssl-1.0.1s]# make && make install

openssl的配置文件必须要配置-fPIC参数,如果没有该参数下面的安装中会出现问题!
安装完成,可以检测一下是否安装成功:

[plain] view plain copy

  1. [[email protected] openssl-1.0.1s]# openssl version

2.进入ruby源码[/usr/local/src/ruby-2.3.0]目录下的ext/openssl 目录:

[plain] view plain copy

  1. [[email protected] openssl-1.0.1s]# cd ../ruby-2.3.0
  2. [[email protected] ruby-2.3.0]# cd ext/openssl
  3. [[email protected] openssl]# ruby extconf.rb
  4. checking for t_open() in -lnsl... no
  5. checking for socket() in -lsocket... no
  6. checking for assert.h... yes
  7. checking for openssl/ssl.h... no

提示没有找到ssl.h, 因为出现了错误:openssl/ssl.h:没有那个文件或目录

[plain] view plain copy

  1. [[email protected] openssl]# ruby extconf.rb --with-openssl-include=/usr/local/openssl/include/ --with-openssl-lib=/usr/local/openssl/lib
  2. checking for t_open() in -lnsl... no
  3. checking for socket() in -lsocket... no
  4. checking for assert.h... yes
  5. checking for openssl/ssl.h... yes
  6. .............................................中间略.............................................
  7. checking for EVP_CTRL_GCM_GET_TAG in openssl/evp.h... yes
  8. creating extconf.h
  9. creating Makefile

成功。

3.接下来并且将ruby 源码目录下的include目录软链接到 / 目录下:

[plain] view plain copy

  1. [[email protected] openssl]# ln -s /usr/local/src/ruby-2.2.3/include /

接着再执行make,如果在配置openssl时没有-fPIC参数时就会出现如下错误

[plain] view plain copy

  1. [[email protected] openssl]# make
  2. gcc -shared -o openssl.so ossl_x509.o ossl_x509cert.o ossl_x509crl.o ossl_pkcs7.o ossl_cipher.o ossl_pkey_dh.o ossl_ssl_session.o ossl_x509attr.o ossl_x509ext.o ossl_ocsp.o ossl_asn1.o ossl_x509name.o ossl_x509revoked.o ossl_rand.o ossl_pkcs12.o ossl_x509store.o ossl_ssl.o ossl.o ossl_digest.o ossl_config.o ossl_pkcs5.o ossl_bio.o ossl_pkey_dsa.o ossl_pkey.o ossl_x509req.o ossl_pkey_ec.o ossl_hmac.o openssl_missing.o ossl_ns_spki.o ossl_pkey_rsa.o ossl_engine.o ossl_bn.o -L. -L/usr/local/ruby/lib -Wl,-R/usr/local/ruby/lib -L/usr/local/ssl/lib -Wl,-R/usr/local/ssl/lib -L. -rdynamic -Wl,-export-dynamic -lssl -lcrypto -lrt -ldl -lcrypt -lm -lc
  3. /usr/bin/ld: /usr/local/ssl/lib/libssl.a(s2_meth.o): relocation R_X86_64_32 against `a local symbol‘
  4. can not be used when making a shared object; recompile with -fPIC
  5. /usr/local/ssl/lib/libssl.a: could not read symbols: Bad value
  6. collect2: ld returned 1 exit status
  7. make: *** [openssl.so] Error 1

有配置-fPIC参数时就继续走下去:

[plain] view plain copy

  1. [[email protected] openssl]# make
  2. compiling ossl_pkey_dsa.c
  3. compiling openssl_missing.c
  4. compiling ossl_x509name.c
  5. compiling ossl_pkey_rsa.c
  6. .............................................中间略.............................................
  7. compiling ossl_bn.c
  8. compiling ossl.c
  9. linking shared-object openssl.so

[plain] view plain copy

  1. [[email protected] openssl]# make install
  2. /usr/bin/install -c -m 0755 openssl.so /usr/local/ruby/lib/ruby/site_ruby/2.2.0/x86_64-linux
  3. installing default openssl libraries

成功。

4.回过头来,这时候我们已经把配置集群遇到的各种问题已经解决好了,再次使用gem install 安装 ruby redis 接口:

[plain] view plain copy

  1. # [[email protected] src]# gem install redis --version 3.0.0
  2. # # 由于源的原因,可能下载失败,就手动下载下来安装
  3. [[email protected] src]# gem install /usr/local/src/redis-3.2.1.gem
  4. Successfully installed redis-3.2.1
  5. Parsing documentation for redis-3.2.1
  6. Installing ri documentation for redis-3.2.1
  7. Done installing documentation for redis after 0 seconds
  8. WARNING:  Unable to pull data from ‘https://rubygems.org/‘: SSL_connect returned=1 errno=0 state=error: certificate verify failed (https://rubygems.org/specs.4.8.gz)
  9. 1 gem installed

可以看到这时ruby redis接口已经安装成功了;

当Redis也安装好,这时我们来做一个Redis集群测试,在一台服务器中创建了6个Redis实例,开启6个Redis服务。

[plain] view plain copy

  1. [[email protected] redis-cluster]# redis-trib.rb create --replicas 1 127.0.0.1:7001 127.0.0.1:7002 127.0.0.1:7003 127.0.0.1:7004 127.0.0.1:7005 127.0.0.1:7006
  2. >>> Creating cluster
  3. >>> Performing hash slots allocation on 6 nodes...
  4. Using 3 masters:
  5. 127.0.0.1:7001
  6. 127.0.0.1:7002
  7. 127.0.0.1:7003
  8. Adding replica 127.0.0.1:7004 to 127.0.0.1:7001
  9. Adding replica 127.0.0.1:7005 to 127.0.0.1:7002
  10. Adding replica 127.0.0.1:7006 to 127.0.0.1:7003
  11. M: e18c4d9b2a9c2b92b3695cb7236512bc3569349e 127.0.0.1:7001
  12. slots:0-5460 (5461 slots) master
  13. M: bfd2c5320bfa800713e18b8f57900fd63995d7cf 127.0.0.1:7002
  14. slots:5461-10922 (5462 slots) master
  15. M: 9d41b514413bcf348d55fe7239ce93b94fab7b01 127.0.0.1:7003
  16. slots:10923-16383 (5461 slots) master
  17. S: fef13f9a028d8a5de2442f562aa88941eb591ba5 127.0.0.1:7004
  18. replicates e18c4d9b2a9c2b92b3695cb7236512bc3569349e
  19. S: 7845903bdd01e2992877e27110bbbc7ff4036828 127.0.0.1:7005
  20. replicates bfd2c5320bfa800713e18b8f57900fd63995d7cf
  21. S: c0becb06b09e957fd34fad5ae85dec15d0b59cd8 127.0.0.1:7006
  22. replicates 9d41b514413bcf348d55fe7239ce93b94fab7b01
  23. Can I set the above configuration? (type ‘yes‘ to accept): yes
  24. >>> Nodes configuration updated
  25. >>> Assign a different config epoch to each node
  26. >>> Sending CLUSTER MEET messages to join the cluster
  27. Waiting for the cluster to join.....
  28. >>> Performing Cluster Check (using node 127.0.0.1:7001)
  29. M: e18c4d9b2a9c2b92b3695cb7236512bc3569349e 127.0.0.1:7001
  30. slots:0-5460 (5461 slots) master
  31. M: bfd2c5320bfa800713e18b8f57900fd63995d7cf 127.0.0.1:7002
  32. slots:5461-10922 (5462 slots) master
  33. M: 9d41b514413bcf348d55fe7239ce93b94fab7b01 127.0.0.1:7003
  34. slots:10923-16383 (5461 slots) master
  35. M: fef13f9a028d8a5de2442f562aa88941eb591ba5 127.0.0.1:7004
  36. slots: (0 slots) master
  37. replicates e18c4d9b2a9c2b92b3695cb7236512bc3569349e
  38. M: 7845903bdd01e2992877e27110bbbc7ff4036828 127.0.0.1:7005
  39. slots: (0 slots) master
  40. replicates bfd2c5320bfa800713e18b8f57900fd63995d7cf
  41. M: c0becb06b09e957fd34fad5ae85dec15d0b59cd8 127.0.0.1:7006
  42. slots: (0 slots) master
  43. replicates 9d41b514413bcf348d55fe7239ce93b94fab7b01
  44. [OK] All nodes agree about slots configuration.
  45. >>> Check for open slots...
  46. >>> Check slots coverage...
  47. [OK] All 16384 slots covered.
  48. [[email protected] redis-cluster]# redis-trib.rb check
  49. [ERR] Wrong number of arguments for specified sub command
  50. [[email protected] redis-cluster]# redis-trib.rb check 127.0.0.1:7001
  51. >>> Performing Cluster Check (using node 127.0.0.1:7001)
  52. M: e18c4d9b2a9c2b92b3695cb7236512bc3569349e 127.0.0.1:7001
  53. slots:0-5460 (5461 slots) master
  54. 1 additional replica(s)
  55. S: c0becb06b09e957fd34fad5ae85dec15d0b59cd8 127.0.0.1:7006
  56. slots: (0 slots) slave
  57. replicates 9d41b514413bcf348d55fe7239ce93b94fab7b01
  58. S: fef13f9a028d8a5de2442f562aa88941eb591ba5 127.0.0.1:7004
  59. slots: (0 slots) slave
  60. replicates e18c4d9b2a9c2b92b3695cb7236512bc3569349e
  61. S: 7845903bdd01e2992877e27110bbbc7ff4036828 127.0.0.1:7005
  62. slots: (0 slots) slave
  63. replicates bfd2c5320bfa800713e18b8f57900fd63995d7cf
  64. M: bfd2c5320bfa800713e18b8f57900fd63995d7cf 127.0.0.1:7002
  65. slots:5461-10922 (5462 slots) master
  66. 1 additional replica(s)
  67. M: 9d41b514413bcf348d55fe7239ce93b94fab7b01 127.0.0.1:7003
  68. slots:10923-16383 (5461 slots) master
  69. 1 additional replica(s)
  70. [OK] All nodes agree about slots configuration.
  71. >>> Check for open slots...
  72. >>> Check slots coverage...
  73. [OK] All 16384 slots covered.

这样就表示我们的集群(三主三从)创建成功了!

主节点:127.0.0.1:7001 127.0.0.1:7002 127.0.0.1:7003

从节点:127.0.0.1:7004 127.0.0.1:7005 127.0.0.1:7006

时间: 2024-08-26 19:52:49

解决方法:配置群集时# gem install redis 报错:Unable to require openssl, install OpenSSL and rebuild ruby的相关文章

mac brew install redis 报错

mac brew install redis 报错 /usr/local/opt/php55/bin/phpize /usr/local/opt/php55/bin/phpize: line 61: /usr/local/Library/ENV/4.3/sed: No such file or directory /usr/local/opt/php55/bin/phpize: line 62: /usr/local/Library/ENV/4.3/sed: No such file or di

QSqlDatabase: QMYSQL driver not loaded 解决方法(debug下正常,release下报错)

环境: QT 5.11 Mysql 5.5 MSVC 2015 编译器 以上全为64位 症状为: Debug下连接数据库正常,Release下连接数据库失败 提示如下: QSqlDatabase: QMYSQL driver not loaded QSqlDatabase: available drivers: QSQLITE QMYSQL QMYSQL3 QODBC QODBC3 QPSQL QPSQL7 注意,这种情况下根本就不需要手动编译Mysql driver,因为Qt已经自带了 按网上

解决ADT创建项目时出现appcompat_v7并且报错的问题

升级了SDK后,使用Eclipse新建Android项目的时候,伴随着产生了一个appcompat_v7项目,并且新建的项目和appcompat_v7都有报错,检查发现新建的项目是依赖于appcompat_v7的 网上搜了一下,说是appcompat_v7是为了让项目兼容低版本sdk而添加的类库项目,是用来被新项目引用的,从上面的图片看到,新建项目的时候,ADT自动帮选了比较低版本的一个Minimum Required SDk 从这个角度分析,如果新建项目的时候把Minimum Required

maven, install 时候报错“编码 gbk 的不可映射字符”的解决方法

myeclipse maven, install 时候报错"编码 gbk 的不可映射字符" 报错的原因是compiler采用了GBK编码,而源代码设置的是utf8编码导致编译的时候无法正确解析源码,解决方法很简单,在pom的compiler插件配置处加入<encoding>utf8</encoding> 即可,如下: <build>        <plugins>            <plugin>           

linux使用su切换用户提示 Authentication failure的解决方法&amp; 复制文件时,报cp: omitting directory `XXX&#39;

linux使用su切换用户提示 Authentication failure的解决方法:这个问题产生的原因是由于ubtun系统默认是没有激活root用户的,需要我们手工进行操作,在命令行界面下,或者在终端中输入如下命令: sudo passwd Password:你当前的密码 Enter new UNIX password:这个是root的密码Retype new UNIX password:重复root的密码然后会提示成功的信息. 在说明一点,使用su和sudo是有区别的,使用su切换用户需要

Linux--- MySQL中GRANT命令执行时发生root权限报错及解决方法

好不容易解决了root用户密码登录的问题,在给新建用户test1授权时出现了如下报错,提示root权限问题: mysql> GRANT ALL ON *.* TO 'test1'@'localhost' IDENTIFIED BY '123456';  ERROR 1045 (28000): Access denied for user 'root'@'localhost' (using password: YES) 查了网上很多方法说# mysqld_safe -u mysql --skip-

解决xtrabackup备份时出现的socket报错

今天为公司新建的uat数据库备份时,出现了报错,将解决方法整理.做一下备忘: 服务器系统: [[email protected] tmp]# cat /etc/redhat-release  CentOS Linux release 7.3.1611 (Core)  mysql版本号: 报错如下: [[email protected] tmp]# innobackupex  --defaults-file=/etc/my.cnf --user=backup --password=****** -

Spring集成JPA配置懒加载两个报错解决办法

一:报错no session 因为entitymanager对象在事物提交后就关闭了 报错的 no session相当于sql的session 解决办法:解决办法 在web.xmL配置一个过滤器 使其在这个session中的manager在结束后再关闭open <!--配置openmanager--> <filter> <filter-name>openEntity</filter-name> <filter-class>org.springfr

表空间正在热备份时关闭实例重启报错的重现和解决

最近一个客户的库在OPEN时报错需要恢复,发现原因为当时一个表空间正在热备份-->ALTER TABLESPACE TEST1 BEGIN BACKUP;  然后实例异常关闭(可能为ABORT或KILL SMON等进程,这里据说为存储直接关闭导致),然后重启时遇到此错误. 在ORACLE 10.2.0.1及11.2.0.4版本中重现了此错误,在这两个版本中同样的情况但是报错信息不太一样,具体情况如下: 10.2.0.1.0 版本表空间正在热备份时关闭实例重启报错的重现和解决: SQL> sel