Redis結合 Docker 搭建集群并整合SpringBoot的詳細過程
軟件版本
Redis 7.2.5
Docker 26.1.3
準備工作
由于docker直接拉取運行了,所以需要提前準備配置文件
Index of /releases/ (redis.io)
下載后,把redis-7.2.5.tar.gz\redis-7.2.5.tar\redis-7.2.5\里的
redis.conf
復制出來
概覽

結構如上圖所示,準備6個服務器。
配置各節(jié)點
1.創(chuàng)建 redis-cluster 目錄
2.創(chuàng)建 redis-cluster/docker-compose.yml 文件
services:
redis-cluster:
image: redis:7.2.5
ports:
- "6379:6379"
- "16379:16379"
volumes:
- ./data:/data
restart: always
command: redis-server /data/redis.conf3.創(chuàng)建 redis-cluster/data 目錄
4.配置文件復制到 redis-cluster/data/redis.conf
5.添加/覆蓋配置項
#注釋掉這項: #bind 127.0.0.1 -::1 logfile "/data/redis.log" appendonly yes cluster-enabled yes cluster-config-file nodes.conf cluster-node-timeout 5000 #這個是 Docker 關鍵配置,不然發(fā)給其他節(jié)點的是容器內(nèi)部ip: cluster-announce-ip <當前節(jié)點IP>
6.在六個節(jié)點分別執(zhí)行上述5個步驟
啟動集群
1.啟動所有節(jié)點
cd 到 redis-cluster 目錄,執(zhí)行 docker compose up -d
2.創(chuàng)建集群
進入任意節(jié)點的 redis 容器內(nèi),執(zhí)行如下命令:
redis-cli --cluster create \ <節(jié)點1的IP>:6379 \ <節(jié)點2的IP>:6379 \ <節(jié)點3的IP>:6379 \ <節(jié)點4的IP>:6379 \ <節(jié)點5的IP>:6379 \ <節(jié)點6的IP>:6379 \ --cluster-replicas 1
按提示輸入yes:
![]()
創(chuàng)建成功提示如下:
![]()
整合SpringBoot
1.添加依賴
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-data-redis</artifactId>
</dependency>2.添加配置
spring:
data:
redis:
cluster:
nodes:
- <哨兵1節(jié)點IP>:6379
- <哨兵2節(jié)點IP>:6379
- <哨兵3節(jié)點IP>:6379
- <哨兵4節(jié)點IP>:6379
- <哨兵5節(jié)點IP>:6379
- <哨兵6節(jié)點IP>:6379
lettuce:
cluster:
refresh:
adaptive: true3.配置讀寫分離
不建議配,除非主節(jié)點壓力很大,主節(jié)點新數(shù)據(jù)更新到從節(jié)點需要時間,這段時間會出現(xiàn)數(shù)據(jù)不一致。
@Configuration
public class RedisConfig {
@Bean
public LettuceClientConfigurationBuilderCustomizer clientConfigurationBuilderCustomizer() {
return builder -> builder.readFrom(ReadFrom.REPLICA_PREFERRED);
}
}4.完成,可直接使用 RedisTemplate
擴展重新分配哈希槽
執(zhí)行:
redis-cli --cluster reshard <任意節(jié)點IP>:6379
輸入分配的哈希槽數(shù)量:

輸入分配給的節(jié)點ID:

輸入用于分配哈希槽的節(jié)點,可以直接輸入all:

確認分配計劃輸入yes:

完畢。
節(jié)點管理
# 添加新主節(jié)點 redis-cli --cluster add-node <新節(jié)點IP>:6379 <任意節(jié)點IP>:6379 # 添加新從節(jié)點 # 由于沒指定主節(jié)點,新添加的從節(jié)點會分配給副本最少的主節(jié)點 redis-cli --cluster add-node <新節(jié)點IP>:6379 <任意節(jié)點IP>:6379 --cluster-slave # 添加新從節(jié)點,并指定主節(jié)點 redis-cli --cluster add-node <新節(jié)點IP>:6379 <任意節(jié)點IP>:6379 --cluster-slave --cluster-master-id <主節(jié)點ID> # 刪除節(jié)點 # 從節(jié)點可直接刪除,主節(jié)點必須先轉移哈希槽 redis-cli --cluster del-node <任意節(jié)點IP>:6379 <待刪節(jié)點ID> # 查看所有集群節(jié)點信息 redis-cli --cluster check <任意節(jié)點IP>:6379
參考資料
Scale with Redis Cluster | Docs
99_springboot整合redis之連接集群-下集_嗶哩嗶哩_bilibili
到此這篇關于Redis 結合 Docker 搭建集群并整合SpringBoot的文章就介紹到這了,更多相關Redis Docker 集群整合SpringBoot內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
Redis?中使用?list,streams,pub/sub?幾種方式實現(xiàn)消息隊列的問題
這篇文章主要介紹了Redis?中使用?list,streams,pub/sub?幾種方式實現(xiàn)消息隊列,本文通過實例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2022-03-03
關于redis狀態(tài)監(jiān)控和性能調(diào)優(yōu)詳解
Redis是一種高級key-value數(shù)據(jù)庫。它跟memcached類似,不過數(shù)據(jù)可以持久化,而且支持的數(shù)據(jù)類型很豐富。有字符串,鏈表、哈希、集合和有序集合5種。下面這篇文章主要給大家介紹了關于redis狀態(tài)監(jiān)控和性能調(diào)優(yōu)的相關資料,需要的朋友可以參考下。2017-09-09

