【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
  • 移動開發(一):使用.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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...