SpringBoot整合NoSql--(三)Redis集群

来源:https://www.cnblogs.com/crazy-lc/archive/2020/02/23/12354146.html
-Advertisement-
Play Games

(1)集群原理 在Redis集群中,所有的Redis節點彼此互聯,節點內部使用二進位協議優化傳輸速度和帶寬。 當一個節點掛掉後,集群中超過半數的節點檢測失效時才認為該節點已失效。不同於Tomcat集群 需要使用反向代理伺服器,Redis 集群中的任意節點都可以直接和Java客戶端連接。Redis 集 ...


 

(1)集群原理

   在Redis集群中,所有的Redis節點彼此互聯,節點內部使用二進位協議優化傳輸速度和帶寬。 當一個節點掛掉後,集群中超過半數的節點檢測失效時才認為該節點已失效。不同於Tomcat集群 需要使用反向代理伺服器,Redis 集群中的任意節點都可以直接和Java客戶端連接。Redis 集群上 的數據分配則是採用哈希槽(HASH SLOT),Redis集群中內置了16384 個哈希槽,當有數據需要 存儲時,Redis會首先使用CRC16演算法對key進行計算,將計算獲得的結果對16384取餘,這樣每 一個key都會對應一個取值在0~16383之間的哈希槽,Redis則根據這個餘數將該條數據存儲到對 應的Redis節點上,開發者可根據每個Redis實例的性能來調整每個Redis實例上哈希槽的分佈範 圍。

(2)集群規劃

  本案例在同一臺伺服器上用不同的埠表示不同的Redis伺服器(偽分散式集群)。 主節點: 192.168.248.144:8001, 192. 168.248.144:8002, 192.1 68.248.144:8003。 從節點: 192.168.248.144:8004, 192. 168.248.144:8005, 192. 168.248.144:8006。

(3)集群配置

  Redis集群管理工具redis-trib.rb依賴Ruby環境,首先需要安裝Ruby環境。

  安裝步驟:

  1.導入公鑰

gpg --keyserver hkp://keys.gnupg.net --recv-keys 409B6B1796C275462A1703113804BB82D39DC0E3

    

 

 

   2.輸入下麵的命令來請求安裝

\curl -sSL https://get.rvm.io | bash -s stable

 

   3.shell環境更新一下,rvm -v 顯示版本

source ~/.bashrc
source ~/.bash_profile
source /usr/local/rvm/scripts/rvm

 

 

   4.列出已知的 Ruby 版本

rvm list known

 

 

 5.安裝rvm

rvm install 2.5.1

 

 

6.安裝 redis依賴

 

 

 7.將下載好的redis編譯安裝

mkdir redisCluster
CP -f ./redis-4.0.10.tar.gz ./redisCluster/
cd redisCluster
tar   -zxvf redis-4.0.10.tar.gz
cd redis-4.0.10
make MALLOClibc
make install

8 複製redis-trib.rb到redisCluster下

 

 

 9.在redisCluster下創建6個文件夾(8001-8006),並將redis.conf複製到8001-8006下,更改每一個redis.conf

8001為例:
port 8001
#bind 127.0.0.1
cluster-enabled yes
cluster-config-file node-8001.conf
protected-mode no
daemonize yes
requirepass 123456
masterauth 123456

10.進入redis-5.0.5啟動6個redis,回到redisCluster目錄下

 

 

 通過指令找到安裝的redis在ruby環境中的配置client.rb

打開client.rb並修改密碼

 

 

 11.創建集群

redis-cli --cluster create 192.168.205.100:8001 192.168.20
5.100:8002 192.168.205.100:8003 192.168.205.100:8004 192.168.205.100:8005 192.168.205.100:8006 --cluster-replicas 1 -a 123456

 

 

Can I set the above configuration? (type 'yes' to accept): yes,該處請輸入yes,不然好像分配不了哈希槽

這樣就行了

 

 

 測試:

[root@localhost redis-5.0.5]# redis-cli -p 8001 -a 123456 -c
Warning: Using a password with '-a' or '-u' option on the command line interface may not 
be safe.127.0.0.1:8001> auth 123456
OK
127.0.0.1:8001> CLUSTER nodes
4c3938eb52b31c3dab74d0edb878d6c42a711a7a 192.168.205.100:8003@18003 master - 0 1582461427
000 3 connected 10923-16383b4dfec3ff7490fd7207bdf7f48d0212d8596ba15 192.168.205.100:8001@18001 myself,master - 0 158
2461424000 1 connected 0-5460adb99416cc376b767198aa606042e98b904a1544 192.168.205.100:8002@18002 master - 0 1582461425
834 2 connected 5461-10922f83c3c955420221b4939617e1520d5ba9370b1d8 192.168.205.100:8004@18004 slave adb99416cc376b7
67198aa606042e98b904a1544 0 1582461426000 2 connected2bbfdf6085405753ef5931cb0a883db9043a2f22 192.168.205.100:8006@18006 slave b4dfec3ff7490fd
7207bdf7f48d0212d8596ba15 0 1582461426844 6 connected4603f708c2e106cd2c227a7c7eb6986ca62b293c 192.168.205.100:8005@18005 slave 4c3938eb52b31c3
dab74d0edb878d6c42a711a7a 0 1582461427859 5 connected127.0.0.1:8001> set k1 測試
-> Redirected to slot [12706] located at 192.168.205.100:8003
OK
192.168.205.100:8003> exit
[root@localhost redis-5.0.5]# redis-cli -p 8002 -a 123456 -c
Warning: Using a password with '-a' or '-u' option on the command line interface may not 
be safe.127.0.0.1:8002> auth 123456
OK
127.0.0.1:8002> get k1
-> Redirected to slot [12706

ok

 


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

-Advertisement-
Play Games
更多相關文章
  • Java構造函數 是特殊的方法(沒有返回類型),使您可以在應用程式內部的其他類使用對象之前完全初始化對象狀態。Java中的構造方法是使用 關鍵字調用的。下麵讓我們更深入地瞭解構造函數。 1.什麼是java構造函數 構造函數是一種特殊的方法,類似於(沒有確切的方法)構造,它可以幫助程式員在對象可被應用 ...
  • Java訪問修飾符–public, protected, private and default Java提供了 四個訪問修飾符 來設置類,變數,方法和構造函數的訪問級別,即 public , private , protected 和 default 。這些訪問級別修飾符確定其他類是否可以使用特定 ...
  • 在本 Java OOPs 概念教程中,我們將學習四種主要的面向對象原則 抽象、封裝、繼承和多態性。它們也被稱為面向對象編程範式的四大支柱。 1. _ 抽象 _是在不考慮無關細節的情況下公開實體基本細節的過程,以降低用戶的複雜性。 1. _ 封裝 _是將數據和對數據的操作捆綁到一個實體中的過程。 1. ...
  • 一、拋磚引玉 既然Java中支持以多線程的方式來執行相應的任務,但為什麼在JDK1.5中又提供了線程池技術呢?這個問題大家自行腦補,多動腦,肯定沒壞處,哈哈哈。。。 說起Java中的線程池技術,在很多框架和非同步處理中間件中都有涉及,而且性能經受起了長久的考驗。可以這樣說,Java的線程池技術是Jav ...
  • 我們知道多線程可以實現同時執行多個任務(只是看起來是同時,其實是CPU的時間片切換特別快我們沒感覺而已)。 現在假設一個做飯的場景,你沒有廚具也沒有食材。你可以去網上買一個廚具,但是這段時間,你不需要閑著啊,可以同時去超市買食材。 設想這是兩個線程,主線程去買食材,然後開啟一個子線程去買廚具。但是, ...
  • 各位小伙伴們,冷月今天給大家發一波福利。我們都知道markdown編輯器非常的好用,是我們寫作的好幫手。這樣的一款好用的文章編輯器,我們怎麼才能讓自己的博客也支持呢,冷月今天來教大家如何將Markdown編輯器搬進您的博客。 首先,我們來看一下效果圖: 那麼我們要怎麼做呢,冷月這邊幫大家找到一個開源 ...
  • 詳解CopyOnWrite容器及其源碼 在jave.util.concurrent包下有這樣兩個類:CopyOnWriteArrayList和CopyOnWriteArraySet。 其中利用到了CopyOnWrite機制,本篇就來聊聊CopyOnWrite技術與Java中的CopyOnWrite容... ...
  • python3-cookbook中每個小節以問題、解決方案和討論三個部分探討了Python3在某類問題中的最優解決方式,或者說是探討Python3本身的數據結構、函數、類等特性在某類問題上如何更好地使用。這本書對於加深Python3的理解和提升Python編程能力的都有顯著幫助,特別是對怎麼提高Py ...
一周排行
    -Advertisement-
    Play Games
  • Timer是什麼 Timer 是一種用於創建定期粒度行為的機制。 與標準的 .NET System.Threading.Timer 類相似,Orleans 的 Timer 允許在一段時間後執行特定的操作,或者在特定的時間間隔內重覆執行操作。 它在分散式系統中具有重要作用,特別是在處理需要周期性執行的 ...
  • 前言 相信很多做WPF開發的小伙伴都遇到過表格類的需求,雖然現有的Grid控制項也能實現,但是使用起來的體驗感並不好,比如要實現一個Excel中的表格效果,估計你能想到的第一個方法就是套Border控制項,用這種方法你需要控制每個Border的邊框,並且在一堆Bordr中找到Grid.Row,Grid. ...
  • .NET C#程式啟動閃退,目錄導致的問題 這是第2次踩這個坑了,很小的編程細節,容易忽略,所以寫個博客,分享給大家。 1.第一次坑:是windows 系統把程式運行成服務,找不到配置文件,原因是以服務運行它的工作目錄是在C:\Windows\System32 2.本次坑:WPF桌面程式通過註冊表設 ...
  • 在分散式系統中,數據的持久化是至關重要的一環。 Orleans 7 引入了強大的持久化功能,使得在分散式環境下管理數據變得更加輕鬆和可靠。 本文將介紹什麼是 Orleans 7 的持久化,如何設置它以及相應的代碼示例。 什麼是 Orleans 7 的持久化? Orleans 7 的持久化是指將 Or ...
  • 前言 .NET Feature Management 是一個用於管理應用程式功能的庫,它可以幫助開發人員在應用程式中輕鬆地添加、移除和管理功能。使用 Feature Management,開發人員可以根據不同用戶、環境或其他條件來動態地控制應用程式中的功能。這使得開發人員可以更靈活地管理應用程式的功 ...
  • 在 WPF 應用程式中,拖放操作是實現用戶交互的重要組成部分。通過拖放操作,用戶可以輕鬆地將數據從一個位置移動到另一個位置,或者將控制項從一個容器移動到另一個容器。然而,WPF 中預設的拖放操作可能並不是那麼好用。為瞭解決這個問題,我們可以自定義一個 Panel 來實現更簡單的拖拽操作。 自定義 Pa ...
  • 在實際使用中,由於涉及到不同編程語言之間互相調用,導致C++ 中的OpenCV與C#中的OpenCvSharp 圖像數據在不同編程語言之間難以有效傳遞。在本文中我們將結合OpenCvSharp源碼實現原理,探究兩種數據之間的通信方式。 ...
  • 一、前言 這是一篇搭建許可權管理系統的系列文章。 隨著網路的發展,信息安全對應任何企業來說都越發的重要,而本系列文章將和大家一起一步一步搭建一個全新的許可權管理系統。 說明:由於搭建一個全新的項目過於繁瑣,所有作者將挑選核心代碼和核心思路進行分享。 二、技術選擇 三、開始設計 1、自主搭建vue前端和. ...
  • Csharper中的表達式樹 這節課來瞭解一下表示式樹是什麼? 在C#中,表達式樹是一種數據結構,它可以表示一些代碼塊,如Lambda表達式或查詢表達式。表達式樹使你能夠查看和操作數據,就像你可以查看和操作代碼一樣。它們通常用於創建動態查詢和解析表達式。 一、認識表達式樹 為什麼要這樣說?它和委托有 ...
  • 在使用Django等框架來操作MySQL時,實際上底層還是通過Python來操作的,首先需要安裝一個驅動程式,在Python3中,驅動程式有多種選擇,比如有pymysql以及mysqlclient等。使用pip命令安裝mysqlclient失敗應如何解決? 安裝的python版本說明 機器同時安裝了 ...