Java自学者论坛

 找回密码
 立即注册

手机号码,快捷登录

恭喜Java自学者论坛(https://www.javazxz.com)已经为数万Java学习者服务超过8年了!积累会员资料超过10000G+
成为本站VIP会员,下载本站10000G+会员资源,会员资料板块,购买链接:点击进入购买VIP会员

JAVA高级面试进阶训练营视频教程

Java架构师系统进阶VIP课程

分布式高可用全栈开发微服务教程Go语言视频零基础入门到精通Java架构师3期(课件+源码)
Java开发全终端实战租房项目视频教程SpringBoot2.X入门到高级使用教程大数据培训第六期全套视频教程深度学习(CNN RNN GAN)算法原理Java亿级流量电商系统视频教程
互联网架构师视频教程年薪50万Spark2.0从入门到精通年薪50万!人工智能学习路线教程年薪50万大数据入门到精通学习路线年薪50万机器学习入门到精通教程
仿小米商城类app和小程序视频教程深度学习数据分析基础到实战最新黑马javaEE2.1就业课程从 0到JVM实战高手教程MySQL入门到精通教程
查看: 569|回复: 0

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

[复制链接]
  • TA的每日心情
    奋斗
    2024-11-24 15:47
  • 签到天数: 804 天

    [LV.10]以坛为家III

    2053

    主题

    2111

    帖子

    72万

    积分

    管理员

    Rank: 9Rank: 9Rank: 9

    积分
    726782
    发表于 2021-4-26 17:33:57 | 显示全部楼层 |阅读模式

    问题
    前面已经在/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. # [root@localhost src]# gem install redis --version 3.0.0  
    2. # # 由于源的原因,可能下载失败,就手动下载下来安装  
    3. [root@localhost 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. [root@localhost src]# tar -xzvf openssl-1.0.1s.tar.gz  
    2. [root@localhost src]# cd openssl-1.0.1s  
    3. [root@localhost openssl-1.0.1s]# ./config -fPIC --prefix=/usr/local/openssl enable-shared  
    4. [root@localhost openssl-1.0.1s]# ./config -t  
    5. [root@localhost openssl-1.0.1s]# make && make install  


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

    [plain]  view plain  copy
     
    1. [root@localhost openssl-1.0.1s]# openssl version  


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

    [plain]  view plain  copy
     
    1. [root@localhost openssl-1.0.1s]# cd ../ruby-2.3.0  
    2. [root@localhost ruby-2.3.0]# cd ext/openssl  
    3. [root@localhost 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. [root@localhost 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. [root@localhost openssl]# ln -s /usr/local/src/ruby-2.2.3/include /  


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

    [plain]  view plain  copy
     
    1. [root@localhost 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. [root@localhost 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. [root@localhost 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. # [root@localhost src]# gem install redis --version 3.0.0  
    2. # # 由于源的原因,可能下载失败,就手动下载下来安装  
    3. [root@localhost 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. [root@localhost 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. [root@localhost redis-cluster]# redis-trib.rb check  
    49. [ERR] Wrong number of arguments for specified sub command  
    50. [root@localhost 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

    哎...今天够累的,签到来了1...
    回复

    使用道具 举报

    您需要登录后才可以回帖 登录 | 立即注册

    本版积分规则

    QQ|手机版|小黑屋|Java自学者论坛 ( 声明:本站文章及资料整理自互联网,用于Java自学者交流学习使用,对资料版权不负任何法律责任,若有侵权请及时联系客服屏蔽删除 )

    GMT+8, 2025-1-22 20:57 , Processed in 0.172832 second(s), 29 queries .

    Powered by Discuz! X3.4

    Copyright © 2001-2021, Tencent Cloud.

    快速回复 返回顶部 返回列表