【Redis】集群教程(Windows)

来源:https://www.cnblogs.com/WilsonPan/archive/2020/04/08/12643221.html
-Advertisement-
Play Games

Redis配置集群教程,介紹Redis集群數據分片,節點通訊,然後準備環境,搭建集群,測試集群使用 ...


  1. 概述
  2. Redis集群數據分片
  3. Redis集群節點通訊
  4. 環境準備
  5. 搭建Redis集群
  6. 測試Redis集群

概述

Redis Cluster provides a way to run a Redis installation where data is automatically sharded across multiple Redis nodes

Redis集群提供一個在多個Redis節點數據自動共用的方式,簡單來說就是添加伺服器的數量,達到

  • 高可用,讓Redis服務長時間有效運行,不會因為硬體/軟體問題導致不可用
  • 可擴展性,動態添加節點/刪除節點,達到增加性能/減少伺服器資源
  • 分散式,節點可以不是
  • 容錯,若其中一臺伺服器故障掛了Redis也能繼續使用(前提是有從節點並且可用)

 

Redis集群數據分片

Redis 集群沒有使用一致性hash, 而是引入了 哈希槽的概念.

Redis 集群有16384個哈希槽,每個key通過CRC16校驗後對16384取模來決定放置哪個槽.集群的每個節點負責一部分hash槽,舉個例子,比如當前集群有3個節點,那麼:

  • 節點 A 包含 0 到 5500號哈希槽.
  • 節點 B 包含5501 到 11000 號哈希槽.
  • 節點 C 包含11001 到 16384號哈希槽

這種結構的好處就是非常容易增加/刪除節點,並且不會影響集群的使用

  • 增加節點,將原來節點的分配部分哈希槽給新節點
  • 刪除節點,將刪除的節點哈希槽分配給現有的節點上即可

 

Redis集群節點通訊

因為Redis集群是把數據分佈存放在不同客戶端,這樣做的好處就是減少每台機器的壓力,提高併發處理能力,因為我們只要進入任一節點,即可使用整個集群,這就需要節點之間互相通訊,這個是Redis內部處理。

Every Redis Cluster node requires two TCP connections open. The normal Redis TCP port used to serve clients, for example 6379, plus the port obtained by adding 10000 to the data port, so 16379 in the example

每一個Redis集群節點都是需要兩個埠,一個用於客戶端連接,一個用於節點數據傳輸(Ping-Pong機制),數據埠是在客戶埠的基礎上加10000,例如,埠6379,數據埠16379,所以在多台機器部署集群需要註意防火牆是否把數據屏蔽 。

 

環境準備

1.安裝Redis  下載地址

2. 安裝Ruby,因為Redis集群管理是用ruby開發  下載地址

3. 下載edis-trib.rb文件,放在Redis安裝文件夾內   下載地址

4. 安裝Ruby的Redis驅動,直接在cmd執行(安裝的時候把Ruby放在環境變數,否則進到Bin執行)    

gem install redis

出現Successfully installed 代表安裝成功

 

 

 

搭建Redis集群

Redis集群至少需要3個節點,就按最少的3個節點搭建一個集群

1. 準備3個配置文件,修改各自的埠和appendfilename,當然如果在3台機器上運行,什麼都不需要修改

port 6379
cluster-enabled yes
cluster-config-file nodes.6379.conf  
cluster-node-timeout 5000
appendonly yes
appendfilename "appendonly.6379.aof"

 

2. 準備bat文件啟動3個redis節點(非必須,可以手動cmd啟動,配置相應配置文件),bat文件需要在redis安裝目錄執行

title redis-cluster
start redis-server.exe redis.6379.conf
start redis-server.exe redis.6380.conf
start redis-server.exe redis.6381.conf

 

3. 用redis-trib創建集群,在cmd執行

redis-trib.rb create 127.0.0.1:6379 127.0.0.1:6380 127.0.0.1:6381

執行完成,輸入yes更新配置文件,最終輸出各個節點信息,哈希槽分配情況。

 

 

至此,Redis集群已經搭建好,這裡只有3個主節點,若想從節點,只需多加3個Redis節點,命令加上--replicas參數就可以。

 

測試Redis集群

進入redis-cli集群模式

redis-cli -c

可以看出,寫入讀取,Redis根據Key計算的hash值在各個節點自動重定向

打開剛剛開啟的幾個Redis實例,可以看出他們之前一直在不斷通訊

 

轉發請標明出處:https://www.cnblogs.com/WilsonPan/p/12643221.html

參考文章

Redis cluster tutorial – Redis


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

-Advertisement-
Play Games
更多相關文章
  • 更多電腦使用技巧可以訪問 "https://xiaoheidiannao.com" 查看哦! "Vim" 是Linux上的文本編輯工具,對於用習慣了 "Vim" 的人來說,肯定也想在Windows上使用 "Vim" ,至少我是這麼想的。雖然也有Windows版的 "Vim" ,但是在 "Word" ...
  • 本文分成入門篇和基礎篇。基礎篇包括變數、字元串處理、數學運算三部分。基礎篇包括流控制、函數和函數庫三部分。主要是基於例子進行講解,其中有 4 個複雜一點的腳本,看懂了也就入門了。 ...
  • 1. 讓外設工作起來 只要給相應的控制器中的寄存器發一個指令 向設備控制器的寄存器寫不就可以了嗎? 需要查寄存器地址、內容的格式和語義、操作系統需要給用戶提供一個簡單視圖 文件視圖 ,這樣方便 總的來說就是: 1. 形成文件視圖 2. 發出out指令 3. 形成中斷處理 中斷處理:當CPU(中央處理 ...
  • 補充 /etc/hostname :CenOS7主機名配置文件 /etc/sysconfig/network C6主機名配置文件 修改主機名 永久生效 臨時改一下 /etc/sysctl.conf Linux內核參數信息文件※※※※※ 調整Linux系統、優化需要配置這個文件 sysctl p 讓修 ...
  • 隨著互聯網+物聯網進程的加快,視頻監控應用領域變得越來越廣泛,其中海康威視 大華等品牌的攝像頭頻繁出現在視野中。由於去年也實現過智慧工地項目上的視頻監控方案,加上當今直播趨勢不減。現在總結一下: 緣由:是1對N 點對多的直播方式, 一般都是採用伺服器轉發,所以此處不考慮WebRTC這種端對端的方式, ...
  • pc開機時,在進入系統之前,要先進入的磁碟里安裝了grub開機引導的區域,如果是單系統一般不會有問題,但若是多系統像win+ubuntu或者ubuntu+ubuntu等,有時會出現grub引導程式損壞,或者其主引導所依賴的邏輯順序不是你想要的 這裡舉個極端一些的慄子:一開始在本地磁碟安裝了win+u ...
  • 一 資源管理 1.1 資源調度機制 對於Kubernetes資源,有兩個重要參數:CPU Request與Memory Request。 通常在定義Pod時並沒有定義這兩個參數,此時Kubernetes會認為該Pod所需的資源很少,並可以將其調度到任何可用的Node上。因此,當集群中的計算資源不很充 ...
  • 我們已經瞭解了 Nginx 的基本命令和架構原理,下麵該到最讓人頭疼也是最不容易理解的部分了,那就是 nginx.conf 這個配置文件,下麵從 Nginx 的指令開始,一步步來講解 Nginx 的配置。 Nginx 指令 先來看一個典型的 Nginx 配置文件示例。 從上面可以看到,這個配置文件中 ...
一周排行
    -Advertisement-
    Play Games
  • 示例項目結構 在 Visual Studio 中創建一個 WinForms 應用程式後,項目結構如下所示: MyWinFormsApp/ │ ├───Properties/ │ └───Settings.settings │ ├───bin/ │ ├───Debug/ │ └───Release/ ...
  • [STAThread] 特性用於需要與 COM 組件交互的應用程式,尤其是依賴單線程模型(如 Windows Forms 應用程式)的組件。在 STA 模式下,線程擁有自己的消息迴圈,這對於處理用戶界面和某些 COM 組件是必要的。 [STAThread] static void Main(stri ...
  • 在WinForm中使用全局異常捕獲處理 在WinForm應用程式中,全局異常捕獲是確保程式穩定性的關鍵。通過在Program類的Main方法中設置全局異常處理,可以有效地捕獲並處理未預見的異常,從而避免程式崩潰。 註冊全局異常事件 [STAThread] static void Main() { / ...
  • 前言 給大家推薦一款開源的 Winform 控制項庫,可以幫助我們開發更加美觀、漂亮的 WinForm 界面。 項目介紹 SunnyUI.NET 是一個基於 .NET Framework 4.0+、.NET 6、.NET 7 和 .NET 8 的 WinForm 開源控制項庫,同時也提供了工具類庫、擴展 ...
  • 說明 該文章是屬於OverallAuth2.0系列文章,每周更新一篇該系列文章(從0到1完成系統開發)。 該系統文章,我會儘量說的非常詳細,做到不管新手、老手都能看懂。 說明:OverallAuth2.0 是一個簡單、易懂、功能強大的許可權+可視化流程管理系統。 有興趣的朋友,請關註我吧(*^▽^*) ...
  • 一、下載安裝 1.下載git 必須先下載並安裝git,再TortoiseGit下載安裝 git安裝參考教程:https://blog.csdn.net/mukes/article/details/115693833 2.TortoiseGit下載與安裝 TortoiseGit,Git客戶端,32/6 ...
  • 前言 在項目開發過程中,理解數據結構和演算法如同掌握蓋房子的秘訣。演算法不僅能幫助我們編寫高效、優質的代碼,還能解決項目中遇到的各種難題。 給大家推薦一個支持C#的開源免費、新手友好的數據結構與演算法入門教程:Hello演算法。 項目介紹 《Hello Algo》是一本開源免費、新手友好的數據結構與演算法入門 ...
  • 1.生成單個Proto.bat內容 @rem Copyright 2016, Google Inc. @rem All rights reserved. @rem @rem Redistribution and use in source and binary forms, with or with ...
  • 一:背景 1. 講故事 前段時間有位朋友找到我,說他的窗體程式在客戶這邊出現了卡死,讓我幫忙看下怎麼回事?dump也生成了,既然有dump了那就上 windbg 分析吧。 二:WinDbg 分析 1. 為什麼會卡死 窗體程式的卡死,入口門檻很低,後續往下分析就不一定了,不管怎麼說先用 !clrsta ...
  • 前言 人工智慧時代,人臉識別技術已成為安全驗證、身份識別和用戶交互的關鍵工具。 給大家推薦一款.NET 開源提供了強大的人臉識別 API,工具不僅易於集成,還具備高效處理能力。 本文將介紹一款如何利用這些API,為我們的項目添加智能識別的亮點。 項目介紹 GitHub 上擁有 1.2k 星標的 C# ...