linux 部署redis集群 碰到的坑

来源:https://www.cnblogs.com/zhuanxin/archive/2018/05/16/9048226.html
-Advertisement-
Play Games

1:/usr/lib/ruby/gems/1.8/gems/redis-3.0.7/lib/redis/client.rb:97:in `call': ERR Slot 16011 is already busy (Redis::CommandError)這是由於上一次配置集群失敗時留下的配置信息導 ...


1:
/usr/lib/ruby/gems/1.8/gems/redis-3.0.7/lib/redis/client.rb:97:in `call': ERR Slot 16011 is already busy (Redis::CommandError)
這是由於上一次配置集群失敗時留下的配置信息導致的。只要把redis.conf中定義的 cluster-config-file 所在的文件刪除,重新啟動redis-server及運行redis-trib即可。

2:
/usr/share/rubygems/rubygems/core_ext/kernel_require.rb:55:in `require': cannot load such file -- redis (LoadError)
from /usr/share/rubygems/rubygems/core_ext/kernel_require.rb:55:in `require'
from /usr/local/bin/redis-trib.rb:25:in `<main>'

碰到這個問題我們需要通過gem在ruby中安裝redis軟體包
gem install redis(Gem是一個管理Ruby庫和程式的標準包,它通過Ruby Gem(如 http://rubygems.org/ )源來查找、安裝、升級和卸載軟體包,非常的便捷。)

3:
/usr/local/lib/ruby/gems/2.3.0/gems/redis-3.3.2/lib/redis/connection/ruby.rb:111:in `rescue in _write_to_socket': Connection timed out (Redis::TimeoutError) 
gem list
gem uninstall redis --version 3.3.2
gem install redis --version 3.0.0
gem list

檢查ruby中的redis版本是不是和你的redis版本一致

4:

redis集群搭建好以後測試集群是否成功,

redis01/redis-cli -h ip -p 7001 –c
說明:-h+host –p+埠號 –c 是要連接集群,
可以看到連接的是7001的節點,set  name的時候計算了存在哪個hash槽上,會跳轉到那個槽對應的節點。註意一定要加(-c)不然的話集群的其他機器連接的話會報錯

下麵是在linux中安裝ruby的方式:(由於linux的集群啟動需要通過redis-trib.rb啟動)註意redis集群需要redis的版本在3.0+以上版本
yum -y install ruby ruby-devel rubygems rpm-build
使用ruby -v查看發現版本是2.0.0,還是搭建redis集群
ruby -v
ruby 2.0.0p648 (2015-12-16) [x86_64-linux]
暫時沒有查到如何直接升級,只能使用源碼包方式進行安裝
1.下載源碼包
wget https://cache.ruby-lang.org/pub/ruby/2.2/ruby-2.2.7.tar.gz
下載失敗提示Unable to establish SSL connection.
curl -O -L https://cache.ruby-lang.org/pub/ruby/2.2/ruby-2.2.7.tar.gz
2.解壓並編譯安裝
tar xf ruby-2.2.7.tar.gz
cd ruby-2.2.7
./configure --prefix=/usr/local/ruby-2.2.7
make && make install
3.創建快捷鍵
需要先刪除舊的快捷方式重新創建
ln -s /usr/local/ruby-2.2.7/bin/ruby /usr/bin/ruby
ruby -v
ruby 2.2.7p470 (2017-03-28 revision 58194) [x86_64-linux]


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 輸出學習時的筆記(其實也沒什麼用,留著給自己看的) printf 用於輸出內容 控制台黑視窗printf("要輸出的內容"); //可以是任意內容-->如果要輸出變數 1、格式占位符(格式占位字元串)%d 接收int型 輸出有符號的10進位%f 接收float型 輸出的時候 用%f或者%lf是一樣的 ...
  • 類:(是一個獨立存放變數(屬性/方法)的空間) class 類名:(類名,每個單詞的首字母大寫) pass 實例 = 類 (類是一類事物的抽象,不是真的存在的。實例是某類事物的具體個體) 類的私有屬性: _x:(一個下劃線的私有屬性類和子類可以訪問) __x:(兩個前置下劃線的私有屬性,無法在外部直 ...
  • 索引: 開源Spring解決方案--lm.solution 參看代碼 GitHub: pom.xml WebConfig.java index.jsp upload.jsp FileUploadController.java Files_Utils_DG.java 一、要點講解 1.引入文件上傳下載 ...
  • 在項目開發過程中或者是性能優化中,經常會有要查看執行sql的情況,然而Laravel日誌預設不記錄執行sql。好在留有相關介面,我們可以很方便的就是想SQl日誌功能。 2.創建SqlListener監聽器 1 > php artisan event:generate 在handle方法中編寫記錄sq ...
  • 爬蟲的原理 現在,讓我們踩下油門,開始飆車!!! 既然我們要基於面向對象的思想寫這個爬蟲,那麼我們就需要把這個爬蟲寫成一個類。 註意力不要放在妹子上!!! 我們定位到妹子的url,我們可以很容易的寫出妹子url的xpath。 調出開發者工具(註意力不要放在妹子上!!!) 兩種解決辦法: 下麵我們使用 ...
  • 筆者也是一個linux新手,最近在學習linux相關的東西,本人是一個node愛好者,想在linux上寫一個linux服務,我的環境是centeros7,用putty鏈接遠端的伺服器,要想讓服務在服務端運行 常用的方法是: 運用nohup命令將服務重定向到output.log文件中,這樣就可以實現l ...
  • __new__ : 這個方法的作用主要是創建一個實例,在創建實例時首先會調用 __new__方法 ,然後調用__init__對實例進行初始化, 如果想修改 __new__ 這個方法,那麼最後要 return 調用一下父類的 __new__ 方法,因為裡面有創建實例的過程,除非你在自定義的 __new ...
  • final final在Java中是一個保留的關鍵字,可以聲明成員變數、方法、類以及本地變數。一旦你將引用聲明作final,你將不能改變這個引用了,編譯器會檢查代碼,如果你試圖將變數再次初始化的話,編譯器會報編譯錯誤。 修飾變數(例如Math類的PI=3.1415926就是變數不可修改) 用fina ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...