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

引用:https://blog.csdn.net/huang930528/article/details/51027915

问题:

前面已经在/usr/local/src安装了ruby-2.3.0.tar.gz、rubygems-2.4.2.tar.gz。

在配置 redis-3.1.1 群集中,使用gem install 安装 ruby redis 接口时报:

# [root@localhost src]# gem install redis --version 3.0.0

# # 由于源的原因,可能下载失败,就手动下载下来安装

[root@localhost src]# gem install /usr/local/src/redis-3.2.1.gem

ERROR: While executing gem ... (Gem::Exception)

    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目录准备安装:

[root@localhost src]# tar -xzvf openssl-1.0.1s.tar.gz

[root@localhost src]# cd openssl-1.0.1s

[root@localhost openssl-1.0.1s]# ./config -fPIC --prefix=/usr/local/openssl enable-shared

[root@localhost openssl-1.0.1s]# ./config -t

[root@localhost openssl-1.0.1s]# make && make install

openssl的配置文件必须要配置-fPIC参数,如果没有该参数下面的安装中会出现问题!

安装完成,可以检测一下是否安装成功:

[root@localhost openssl-1.0.1s]# openssl version

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

[root@localhost openssl-1.0.1s]# cd ../ruby-2.3.0

[root@localhost ruby-2.3.0]# cd ext/openssl

[root@localhost openssl]# ruby extconf.rb

checking for t_open() in -lnsl... no

checking for socket() in -lsocket... no

checking for assert.h... yes

checking for openssl/ssl.h... no

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

[root@localhost openssl]# ruby extconf.rb --with-openssl-include=/usr/local/openssl/include/ --with-openssl-lib=/usr/local/openssl/lib

checking for t_open() in -lnsl... no

checking for socket() in -lsocket... no

checking for assert.h... yes

checking for openssl/ssl.h... yes

.............................................中间略.............................................

checking for EVP_CTRL_GCM_GET_TAG in openssl/evp.h... yes

creating extconf.h

creating Makefile

成功。

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

[root@localhost openssl]# ln -s /usr/local/src/ruby-2.2.3/include /

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

[root@localhost openssl]# make

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

/usr/bin/ld: /usr/local/ssl/lib/libssl.a(s2_meth.o): relocation R_X86_64_32 against `a local symbol'

can not be used when making a shared object; recompile with -fPIC

/usr/local/ssl/lib/libssl.a: could not read symbols: Bad value

collect2: ld returned 1 exit status

make: *** [openssl.so] Error 1

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

[root@localhost openssl]# make

compiling ossl_pkey_dsa.c

compiling openssl_missing.c

compiling ossl_x509name.c

compiling ossl_pkey_rsa.c

.............................................中间略.............................................

compiling ossl_bn.c

compiling ossl.c

linking shared-object openssl.so

[root@localhost openssl]# make install

/usr/bin/install -c -m 0755 openssl.so /usr/local/ruby/lib/ruby/site_ruby/2.2.0/x86_64-linux

installing default openssl libraries

成功。

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

# [root@localhost src]# gem install redis --version 3.0.0

# # 由于源的原因,可能下载失败,就手动下载下来安装

[root@localhost src]# gem install /usr/local/src/redis-3.2.1.gem

Successfully installed redis-3.2.1

Parsing documentation for redis-3.2.1

Installing ri documentation for redis-3.2.1

Done installing documentation for redis after 0 seconds

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)

1 gem installed

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

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

[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

>>> Creating cluster

>>> Performing hash slots allocation on 6 nodes...

Using 3 masters:

127.0.0.1:7001

127.0.0.1:7002

127.0.0.1:7003

Adding replica 127.0.0.1:7004 to 127.0.0.1:7001

Adding replica 127.0.0.1:7005 to 127.0.0.1:7002

Adding replica 127.0.0.1:7006 to 127.0.0.1:7003

M: e18c4d9b2a9c2b92b3695cb7236512bc3569349e 127.0.0.1:7001

  slots:0-5460 (5461 slots) master

M: bfd2c5320bfa800713e18b8f57900fd63995d7cf 127.0.0.1:7002

  slots:5461-10922 (5462 slots) master

M: 9d41b514413bcf348d55fe7239ce93b94fab7b01 127.0.0.1:7003

  slots:10923-16383 (5461 slots) master

S: fef13f9a028d8a5de2442f562aa88941eb591ba5 127.0.0.1:7004

  replicates e18c4d9b2a9c2b92b3695cb7236512bc3569349e

S: 7845903bdd01e2992877e27110bbbc7ff4036828 127.0.0.1:7005

  replicates bfd2c5320bfa800713e18b8f57900fd63995d7cf

S: c0becb06b09e957fd34fad5ae85dec15d0b59cd8 127.0.0.1:7006

  replicates 9d41b514413bcf348d55fe7239ce93b94fab7b01

Can I set the above configuration? (type 'yes' to accept): yes

>>> Nodes configuration updated

>>> Assign a different config epoch to each node

>>> Sending CLUSTER MEET messages to join the cluster

Waiting for the cluster to join.....

>>> Performing Cluster Check (using node 127.0.0.1:7001)

M: e18c4d9b2a9c2b92b3695cb7236512bc3569349e 127.0.0.1:7001

  slots:0-5460 (5461 slots) master

M: bfd2c5320bfa800713e18b8f57900fd63995d7cf 127.0.0.1:7002

  slots:5461-10922 (5462 slots) master

M: 9d41b514413bcf348d55fe7239ce93b94fab7b01 127.0.0.1:7003

  slots:10923-16383 (5461 slots) master

M: fef13f9a028d8a5de2442f562aa88941eb591ba5 127.0.0.1:7004

  slots: (0 slots) master

  replicates e18c4d9b2a9c2b92b3695cb7236512bc3569349e

M: 7845903bdd01e2992877e27110bbbc7ff4036828 127.0.0.1:7005

  slots: (0 slots) master

  replicates bfd2c5320bfa800713e18b8f57900fd63995d7cf

M: c0becb06b09e957fd34fad5ae85dec15d0b59cd8 127.0.0.1:7006

  slots: (0 slots) master

  replicates 9d41b514413bcf348d55fe7239ce93b94fab7b01

[OK] All nodes agree about slots configuration.

>>> Check for open slots...

>>> Check slots coverage...

[OK] All 16384 slots covered.

[root@localhost redis-cluster]# redis-trib.rb check

[ERR] Wrong number of arguments for specified sub command

[root@localhost redis-cluster]# redis-trib.rb check 127.0.0.1:7001

>>> Performing Cluster Check (using node 127.0.0.1:7001)

M: e18c4d9b2a9c2b92b3695cb7236512bc3569349e 127.0.0.1:7001

  slots:0-5460 (5461 slots) master

  1 additional replica(s)

S: c0becb06b09e957fd34fad5ae85dec15d0b59cd8 127.0.0.1:7006

  slots: (0 slots) slave

  replicates 9d41b514413bcf348d55fe7239ce93b94fab7b01

S: fef13f9a028d8a5de2442f562aa88941eb591ba5 127.0.0.1:7004

  slots: (0 slots) slave

  replicates e18c4d9b2a9c2b92b3695cb7236512bc3569349e

S: 7845903bdd01e2992877e27110bbbc7ff4036828 127.0.0.1:7005

  slots: (0 slots) slave

  replicates bfd2c5320bfa800713e18b8f57900fd63995d7cf

M: bfd2c5320bfa800713e18b8f57900fd63995d7cf 127.0.0.1:7002

  slots:5461-10922 (5462 slots) master

  1 additional replica(s)

M: 9d41b514413bcf348d55fe7239ce93b94fab7b01 127.0.0.1:7003

  slots:10923-16383 (5461 slots) master

  1 additional replica(s)

[OK] All nodes agree about slots configuration.

>>> Check for open slots...

>>> Check slots coverage...

[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

---------------------

作者:Giraffe8

来源:CSDN

原文:https://blog.csdn.net/huang930528/article/details/51027915

版权声明:本文为博主原创文章,转载请附上博文链接!

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 217,907评论 6 506
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,987评论 3 395
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 164,298评论 0 354
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,586评论 1 293
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,633评论 6 392
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,488评论 1 302
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,275评论 3 418
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 39,176评论 0 276
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,619评论 1 314
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,819评论 3 336
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,932评论 1 348
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,655评论 5 346
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,265评论 3 329
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,871评论 0 22
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,994评论 1 269
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 48,095评论 3 370
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,884评论 2 354

推荐阅读更多精彩内容