搭建redis集群

本文涉及的产品
Redis 开源版,标准版 2GB
推荐场景:
搭建游戏排行榜
云数据库 Tair(兼容Redis),内存型 2GB
简介: docker-compose 搭建redis集群

一、基础概览

1、redis集群最少需要6个节点,且redis集群下只有db0,不支持多db。

2、开放端口

节点访问:6391-6393

集群连接:16391-16393


二、准备容器挂载的目录

1.创建根目录

mkdir /server
cd /server

2.创建容器目录。然后给每个节点创建对应的目录和配置文件

服务器1 192.168.79.131 init.sh

for port in$(seq 6391 6393); \
do \
mkdir-p /server/redis-cluster/redis-node-${port}/{conf,data}
touch /server/redis-cluster/redis-node-${port}/conf/redis.conf
cat << EOF >/server/redis-cluster/redis-node-${port}/conf/redis.conf
#端口port ${port}bind 0.0.0.0
#启用集群模式cluster-enabled yescluster-config-file nodes.conf
#超时时间cluster-node-timeout 5000# 集群连接地址及端口cluster-announce-ip 192.168.79.131
cluster-announce-port ${port}cluster-announce-bus-port 1${port}appendonly yes#集群加密masterauth 123456requirepass 123456EOF
done

服务器2 192.168.79.132 init.sh

for port in$(seq 6391 6393); \
do \
mkdir-p /server/redis-cluster/redis-node-${port}/{conf,data}
touch /server/redis-cluster/redis-node-${port}/conf/redis.conf
cat << EOF >/server/redis-cluster/redis-node-${port}/conf/redis.conf
#端口port ${port}bind 0.0.0.0
#启用集群模式cluster-enabled yescluster-config-file nodes.conf
#超时时间cluster-node-timeout 5000# 集群连接地址及端口cluster-announce-ip 192.168.79.132
cluster-announce-port ${port}cluster-announce-bus-port 1${port}protected-mode no
appendonly yes#集群加密masterauth 123456requirepass 123456EOF
done

三、使用 docker-compose.yml 运行 redis 容器

version: '3'services:
 redis1:
  container_name: redis1
  image: redis:7.0.5
  network_mode: host
restart: always  
  volumes:
- /server/redis-cluster/redis-node-6391/conf/redis.conf:/etc/redis/redis.conf
- /server/redis-cluster/redis-node-6391/data:/data
  environment:
-TZ=Asia/Shanghai
-LANG=en_US.UTF-8
  ports:
-'6391:6379'#服务端口-'16391:16379'#集群端口  command: ["redis-server", "/etc/redis/redis.conf"]
  privileged: true#环境变量 redis2:
  container_name: redis2
  image: redis:7.0.5
  network_mode: host
restart: always
  volumes:
-  /server/redis-cluster/redis-node-6392/conf/redis.conf:/etc/redis/redis.conf
-  /server/redis-cluster/redis-node-6392/data:/data
  environment:
-TZ=Asia/Shanghai
-LANG=en_US.UTF-8
  ports:
-'6392:6379'#服务端口-'16392:16379'#集群端口  command: ["redis-server", "/etc/redis/redis.conf"]
  privileged: true#环境变量 redis3:
  container_name: redis3
  image: redis:7.0.5
  network_mode: host
restart: always
  volumes:
- /server/redis-cluster/redis-node-6393/conf/redis.conf:/etc/redis/redis.conf
- /server/redis-cluster/redis-node-6393/data:/data
  environment:
-TZ=Asia/Shanghai
-LANG=en_US.UTF-8
  ports:
-'6393:6379'#服务端口-'16393:16379'#集群端口  command: ["redis-server", "/etc/redis/redis.conf"]
  privileged: true#环境变量

分别在两台服务器上执行

docker-compose up -d

四、组建 redis 集群

随便进一台服务器进行配置

进入某一个容器

docker exec -it redis1 /bin/bash

组建集群

redis-cli -p6391-a123456--cluster create 192.168.79.131:6391 192.168.79.131:6392 192.168.79.131:6393 192.168.79.132:6391 192.168.79.132:6392 192.168.79.132:6393 --cluster-replicas1

image.png

输入yes即可

五、查看集群信息

主从关系

redis-cli -p6391-a123456#查看节点cluster nodes

image.png

相关实践学习
基于Redis实现在线游戏积分排行榜
本场景将介绍如何基于Redis数据库实现在线游戏中的游戏玩家积分排行榜功能。
云数据库 Redis 版使用教程
云数据库Redis版是兼容Redis协议标准的、提供持久化的内存数据库服务,基于高可靠双机热备架构及可无缝扩展的集群架构,满足高读写性能场景及容量需弹性变配的业务需求。 产品详情:https://www.aliyun.com/product/kvstore &nbsp; &nbsp; ------------------------------------------------------------------------- 阿里云数据库体验:数据库上云实战 开发者云会免费提供一台带自建MySQL的源数据库&nbsp;ECS 实例和一台目标数据库&nbsp;RDS实例。跟着指引,您可以一步步实现将ECS自建数据库迁移到目标数据库RDS。 点击下方链接,领取免费ECS&amp;RDS资源,30分钟完成数据库上云实战!https://developer.aliyun.com/adc/scenario/51eefbd1894e42f6bb9acacadd3f9121?spm=a2c6h.13788135.J_3257954370.9.4ba85f24utseFl
目录
相关文章
|
3月前
|
存储 缓存 NoSQL
Redis常见面试题(二):redis分布式锁、redisson、主从一致性、Redlock红锁;Redis集群、主从复制,哨兵模式,分片集群;Redis为什么这么快,I/O多路复用模型
redis分布式锁、redisson、可重入、主从一致性、WatchDog、Redlock红锁、zookeeper;Redis集群、主从复制,全量同步、增量同步;哨兵,分片集群,Redis为什么这么快,I/O多路复用模型——用户空间和内核空间、阻塞IO、非阻塞IO、IO多路复用,Redis网络模型
Redis常见面试题(二):redis分布式锁、redisson、主从一致性、Redlock红锁;Redis集群、主从复制,哨兵模式,分片集群;Redis为什么这么快,I/O多路复用模型
|
2月前
|
监控 NoSQL Redis
看完这篇就能弄懂Redis的集群的原理了
看完这篇就能弄懂Redis的集群的原理了
79 0
|
3月前
|
存储 NoSQL 算法
Redis 集群模式搭建
Redis 集群模式搭建
83 5
|
3月前
|
存储 缓存 NoSQL
高并发架构设计三大利器:缓存、限流和降级问题之Redis用于搭建分布式缓存集群问题如何解决
高并发架构设计三大利器:缓存、限流和降级问题之Redis用于搭建分布式缓存集群问题如何解决
|
2月前
|
NoSQL Redis
Redis——单机迁移cluster集群如何快速迁移
Redis——单机迁移cluster集群如何快速迁移
80 0
|
3月前
|
缓存 NoSQL Java
Redis Spring配置集群
【7月更文挑战第5天】
71 10
|
2月前
|
NoSQL Linux Redis
使用docker-compose搭建redis-cluster集群
使用docker-compose搭建redis-cluster集群
405 0
|
2月前
|
NoSQL Linux Redis
基于redis6搭建集群
基于redis6搭建集群
|
3月前
|
消息中间件 监控 NoSQL
Redis哨兵改集群
【7月更文挑战第7天】