docker-compose快速搭建redis集群

目錄結構

redis-cluster/
├── config/
│   ├── master.conf
│   ├── slave1.conf
│   └── slave2.conf
└── docker-compose.yml

配置文件內容

1. config/master.conf
# Redis主節點配置
port 6379
bind 0.0.0.0
protected-mode no
logfile "redis-master.log"
dir /data
save 900 1
save 300 10
save 60 10000
2. config/slave1.conf
# Redis從節點1配置
port 6380
bind 0.0.0.0
protected-mode no
logfile "redis-slave1.log"
dir /data
slaveof redis-master 6379
3. config/slave2.conf
# Redis從節點2配置
port 6381
bind 0.0.0.0
protected-mode no
logfile "redis-slave2.log"
dir /data
slaveof redis-master 6379

docker-compose.yml

version: '3.8'services:# Redis主節點redis-master:image: redis:7.0container_name: redis-masterports:- "6379:6379"volumes:- ./config/master.conf:/usr/local/etc/redis/redis.conf- redis-data-master:/datacommand: ["redis-server", "/usr/local/etc/redis/redis.conf"]healthcheck:test: ["CMD", "redis-cli", "ping"]interval: 5stimeout: 5sretries: 5networks:- redis-network# Redis從節點1redis-slave1:image: redis:7.0container_name: redis-slave1ports:- "6380:6380"volumes:- ./config/slave1.conf:/usr/local/etc/redis/redis.conf- redis-data-slave1:/datacommand: ["redis-server", "/usr/local/etc/redis/redis.conf"]healthcheck:test: ["CMD", "redis-cli", "-p", "6380", "ping"]interval: 5stimeout: 5sretries: 5depends_on:- redis-masternetworks:- redis-network# Redis從節點2redis-slave2:image: redis:7.0container_name: redis-slave2ports:- "6381:6381"volumes:- ./config/slave2.conf:/usr/local/etc/redis/redis.conf- redis-data-slave2:/datacommand: ["redis-server", "/usr/local/etc/redis/redis.conf"]healthcheck:test: ["CMD", "redis-cli", "-p", "6381", "ping"]interval: 5stimeout: 5sretries: 5depends_on:- redis-masternetworks:- redis-networkvolumes:redis-data-master:redis-data-slave1:redis-data-slave2:networks:redis-network:driver: bridge

部署步驟

  1. 創建目錄結構并添加上述配置文件

  2. 設置正確的文件權限(避免之前的權限問題)

chmod -R 644 config/
  1. 啟動容器
docker-compose up -d
  1. 驗證部署
# 檢查容器狀態
docker-compose ps# 連接到主節點查看信息
docker exec -it redis-master redis-cli info replication# 連接到從節點1查看信息
docker exec -it redis-slave1 redis-cli -p 6380 info replication# 連接到從節點2查看信息
docker exec -it redis-slave2 redis-cli -p 6381 info replication

測試主從復制

  1. 在主節點設置一個鍵值
docker exec -it redis-master redis-cli
127.0.0.1:6379> SET mykey "Hello from master"
OK
  1. 在從節點讀取該鍵值
# 從節點1
docker exec -it redis-slave1 redis-cli -p 6380
127.0.0.1:6380> GET mykey
"Hello from master"# 從節點2
docker exec -it redis-slave2 redis-cli -p 6381
127.0.0.1:6381> GET mykey
"Hello from master"

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/bicheng/87327.shtml
繁體地址,請注明出處:http://hk.pswp.cn/bicheng/87327.shtml
英文地址,請注明出處:http://en.pswp.cn/bicheng/87327.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

SpringCloud系列(39)--SpringCloud Gateway常用的Route Predicate

前言:在上一節中我們實現了SpringCloud Gateway的動態路由 ,而在本節中我們將著重介紹各種Route Predicate的作用。 1、可以到官方文檔里查看常用的Route Predicate的種類 https://cloud.spring.io/spring-cloud-static/spring-cloud-gateway/2.2.1.REL…

漸變色的進度條控件

近日,用VB.net2003重寫了一個漸變色的進度條控件。主要有以下功能: 支持自定義進度條分段數量,可拆分為多個步驟;每個步驟可獨立顯示完成百分比及漸變色效果。 每個步驟均可配置任務名稱和描述;運行時能實時顯示當前執…

【DICOM后處理】qt+vs 實現DICOM數據四視圖顯示

目錄 1、DICOM四視圖2、vtkImageViewer2 實現二維平面圖顯示3、vtkVolume實現三維體數據顯示4、實現界面圖 1、DICOM四視圖 DICOM四視圖通常指同時顯示醫學影像的四個不同平面或視角,用于全面分析三維數據(如CT、MRI等)。 標準四視圖布局&a…

Google Maps 安裝使用教程

一、Google Maps 簡介 Google Maps 是谷歌提供的地圖服務,通過其 JavaScript API,開發者可以在網頁中嵌入地圖,添加標記、路徑、地理編碼、路線導航等功能,適用于位置展示、物流追蹤、LBS 應用等場景。 二、獲取 Google Maps API…

Nginx+Keepalived實現前臺服務高可用

現階段項目開發往往采用前后臺分離,前臺常用的技術有vue、react等,前臺代碼部署在nginx中,代碼中配置了后臺服務的網關地址,由網關向后臺分發服務請求,架構示意圖如下: 在上述架構圖中,如果Ngin…

Gradio全解13——MCP協議詳解(5)——Python包命令:uv與uvx實戰

Gradio全解13——MCP協議詳解(5)——Python包命令:uv與uvx實戰 第13章 MCP協議詳解13.5 Python包命令:uv與uvx實戰13.5.1 uv核心亮點與常用命令1. uv介紹2. 安裝與項目管理3. 腳本與工具4. Python版本與pip接口 13.5.2 uv核心指令…

OD 算法題 B卷【求最小步數】

文章目錄 求最小步數 求最小步數 求從坐標零點到坐標點n的最小步數,一次只能沿著橫坐標軸向左或向右移動2或3;途經的坐標點可以為負數; 輸入描述: 坐標點n 輸出描述: 從坐標零點移動到坐標點n的最小步數 n在【1,10^9】 示例1 輸入&#xf…

Elasticsearch 集群升級實戰指引—7.x 升級到 8.x

升級Elasticsearch集群從7.x到8.x是一項復雜且關鍵的任務,涉及重大版本變更(如API調整、配置變更、安全功能強制啟用等),可能影響集群的性能和穩定性。結合您提到的業務量增長導致索引寫入變慢的問題,本指引不僅提供詳…

JWT學習總結

文章目錄 前置知識Authorization頭部和 CookieCRSF攻擊 JWT概念JWT認證流程使用Springboot整合JWTJwtUtil JWT案例控制器JWT攔截器注冊攔截器結果 session VS Jwt 前置知識 Authorization頭部和 Cookie Authorization 頭部和 Cookie 是 HTTP 協議中兩種不同的身份認證 / 信息…

阿里云消息隊列 Apache RocketMQ 創新論文入選頂會 ACM FSE 2025

近日,由阿里云消息團隊發表的 Apache RocketMQ 創新論文被 CCF-A 類軟件工程頂級會議 FSE 2025 Industry Track 錄用。 ACM FSE(The ACM International Conference on the Foundations of Software Engineering)是享有盛譽的國際學術會議&…

定制WordPress管理后臺

WordPress作為全球最流行的建站工具,因其靈活性和易用性受到廣泛歡迎。許多服務器提供商都支持一鍵安裝WordPress,例如Hostease,使新手用戶也能輕松搭建屬于自己的網站。然而,后臺的默認設置可能無法完全滿足不同用戶的需求。定制…

REST API設計與Swagger:構建高效、易用的Web服務

引言 在現代Web開發中,REST API已成為不同系統間通信的標準方式。一個設計良好的REST API不僅能提高開發效率,還能改善用戶體驗。而Swagger(現稱為OpenAPI)作為API文檔和測試的強大工具,已經成為API開發中不可或缺的一…

一個非對齊訪問的問題

1、引言 最近在編寫代碼時,出現了這樣一個 bug。程序一跑,系統就崩潰了,報錯是 bus error。 目標平臺:ARM32 最終定位到出錯的代碼片段: *((uint32_t *)ptr) id;這里的 ptr 是一個非 4 字節對齊的地址!&a…

【構造】P8976 「DTOI-4」排列|普及+

本文涉及知識點 構造 P8976 「DTOI-4」排列 題目背景 Update on 2023.2.1:新增一組針對 yuanjiabao 的 Hack 數據,放置于 #21。 Update on 2023.2.2:新增一組針對 CourtesyWei 和 bizhidaojiaosha 的 Hack 數據,放置于 #22。…

多路I/O轉接服務器(select、poll、epoll)

多路IO轉接服務器也叫做多任務IO服務器。該類服務器實現的主旨思想是,不再由應用程序自己監視客戶端連接,取而代之由內核替應用程序監視文件。 IO 多路轉接方式比較: 常見的 IO 多路轉接方式有:select、poll、epoll,他…

最新臨時文件快傳系統源碼 輕量化 帶后臺

簡介: 最新臨時文件快傳系統源碼 輕量化 帶后臺 首發 輕松上傳文件并生成提取碼分享給他人,無需注冊,方便快捷。 圖片:

MyBatis多數據源動態連接工具類實現

這個DatabaseService工具類提供了動態創建MyBatis SqlSession的能力,可以靈活地連接到不同的數據庫,非常適合需要動態切換數據源的場景。 package com.cmes.immp.device.utils;import lombok.SneakyThrows; import org.apache.commons.dbcp2.BasicDataS…

用亮數據 MCP 驅動 Trae 智能體:打造高效亞馬遜商品采集與分析助手

本文適合希望快速構建數據驅動型智能體的開發者、數據工程師及 AI 產品設計者閱讀 并非廣告,希望本文可以幫助有需求的同學,祝大家天天開心 在數字時代,數據是決策與洞察趨勢的關鍵。但移動互聯網數據獲取不易,傳統爬蟲技術面對復…

如何降低AIGC生成內容的重復率?五種免費降AI率的方法 (25年更新)

隨著AI生成內容(AIGC)的普及,越來越多的學術寫作依賴AI工具來生成論文和文章。然而,AI生成內容的查重率常常偏高,導致很多論文無法通過學術查重系統。為了解決這一問題,以下是五種有效的免費降AIGC率的方法…

小米YU7使用UWB技術,厘米級定位精準迎賓,安全防破解無感控車

當您雙手抱著快遞走向愛車時,車門自動解鎖;當您站在前備箱前稍作停留,箱蓋優雅升起——這不是科幻電影,而是小米YU7搭載UWB技術帶來的真實體驗。在2025年5月的小米15周年戰略新品發布會上,雷軍揭曉了這項革命性技術&am…