Redis集群方案及实战(五)

本文涉及的产品
云数据库 Redis 版,社区版 2GB
推荐场景:
搭建游戏排行榜
简介: Redis集群方案及实战

五.RedisCluster-Linux搭建

1.概述

  • 本文以windows中使用Linux虚拟机,并在虚拟机中使用Docker,Docker通过容器编排搭建Redis集群,如果使用云服务器那么部分配置需要修改,请另行百度
  • 需要先在windows上安装Linux系统,并在Linux系统中安装Docker

2.实战

  • 第一步:先下载一个SSH连接工具并连接到Linux,也可以使用IDEA连接,傻瓜式安装即可
  • FinalShell下载地址:www.hostbuf.com/t/988.html

  • 第二步:创建节点配置文件夹
# 返回上一级
cd ..
# 进入home目录
cd home
# 创建RedisCluster文件夹
mkdir RedisCluster
# 进入RedisCluster文件夹
cd RedisCluster
# 创建六个文件夹并创建出6个配置文件
mkdir 7901 7902 7903 7904 7905 7906
# 进入到创建好的7901文件夹中
ls
cd 7901

  • 第三步:创建节点配置文件
# 1.创建并编辑配置文件
vi redis.conf
# 2.点击i进入编辑状态,然后将下面的配置文件粘贴到redis.conf文件中,注意修改端口号
# 3.点击Esc退出输入
# 4.输入命令保存并退出注意有冒号::wq
# 5.执行 ls 查看是否创建成功
# 是否开启保护模式,yes时外部访问redis需要配置bind ip或访问密码,线上建议开启
protected-mode no
# 主节点连接密码,用于保护集群,保持与requirepass一致即可
masterauth 123456
# 每个redis的端口都需要不同
port 7901
# 是否开启集群
cluster-enabled yes
# 该参数指定了集群配置文件的位置。每个节点在运行过程中,会维护一份集群配置文件
# 每当集群信息发生变化时比如增删节点,集群内所有节点会将最新信息更新到该配置文件
# 当节点重启后,会重新读取该配置文件,获取集群信息,可以方便的重新加入到集群中
# 此集群配置文件redis节点会自行维护,注意修改端口号
cluster-config-file nodes-7901.conf
# 集群节点不可用的最大时间,单位是毫秒,如果主节点在指定时间内不可达,那么会进行故障转移
cluster-node-timeout 15000
# 云服务器上部署需指定公网ip,此处设置Linux服务器Ip
cluster-announce-ip 192.168.2.79
# 集群节点映射端口
cluster-announce-port 7901
# 集群节点通信端口
cluster-announce-bus-port 17901
# 开启AOF持久化
appendonly yes
# AOF持久化文件名称
appendfilename "appendonly.aof"
# 设置节点密码,注意所有节点密码必须一致
requirepass 123456
# Redis后台运行,在docker中无需开启
daemonize no

  • 第四步:拷贝配置文件到其他节点文件夹中
[root@localhost 7901]# cp redis.conf ../7902
[root@localhost 7901]# cp redis.conf ../7903
[root@localhost 7901]# cp redis.conf ../7904
[root@localhost 7901]# cp redis.conf ../7905
[root@localhost 7901]# cp redis.conf ../7906

  • 第五步:修改所有节点配置文件
# 进入到其他五个节点文件夹中修改配置的端口
vi redis.conf
# 点击Esc 输入 :wq保存并退出
# 返回上一级编辑指定文件夹:vi ../7902/redis.conf 

  • 第六步:编写docker-compose.yml文件
  • 注意:要在RedisCluster文件夹下创建

version: "3"
# 定义服务可以多个
services:
  redis-cluster:
    image: redis:latest
    command: redis-cli --cluster create  192.168.2.79:7901 192.168.2.79:7902 192.168.2.79:7903 192.168.2.79:7904 192.168.2.79:7905 192.168.2.79:7906 --cluster-replicas 1 --cluster-yes -a 123456
    depends_on:
      - redis-7901
      - redis-7902
      - redis-7903
      - redis-7904
      - redis-7905
      - redis-7906                  
  redis-7901: # 服务名称
    image: redis:latest # 创建容器时所需的镜像
    container_name: redis-7901 # 容器名称
    restart: always # 容器总是重新启动
    ports:
      - 7901:7901
      - 17901:17901
    volumes: # 数据卷,目录挂载
      - ./etc_rc.local:/etc/rc.local
      - ./7901/redis.conf:/etc/redis/redis.conf
      - ./7901/data:/data
    command: ["redis-server", "/etc/redis/redis.conf"] # 覆盖容器启动后默认执行的命令
  redis-7902: # 服务名称
    image: redis:latest # 创建容器时所需的镜像
    container_name: redis-7902 # 容器名称
    restart: always # 容器总是重新启动
    ports:
      - 7902:7902
      - 17902:17902
    volumes: # 数据卷,目录挂载
      - ./etc_rc.local:/etc/rc.local
      - ./7902/redis.conf:/etc/redis/redis.conf
      - ./7902/data:/data
    command: ["redis-server", "/etc/redis/redis.conf"] # 覆盖容器启动后默认执行的命令
  redis-7903: # 服务名称
    image: redis:latest # 创建容器时所需的镜像
    container_name: redis-7903 # 容器名称
    restart: always # 容器总是重新启动
    ports:
      - 7903:7903
      - 17903:17903
    volumes: # 数据卷,目录挂载
      - ./etc_rc.local:/etc/rc.local
      - ./7903/redis.conf:/etc/redis/redis.conf
      - ./7903/data:/data
    command: ["redis-server", "/etc/redis/redis.conf"] # 覆盖容器启动后默认执行的命令
  redis-7904: # 服务名称
    image: redis:latest # 创建容器时所需的镜像
    container_name: redis-7904 # 容器名称
    restart: always # 容器总是重新启动
    ports:
      - 7904:7904
      - 17904:17904
    volumes: # 数据卷,目录挂载
      - ./etc_rc.local:/etc/rc.local
      - ./7904/redis.conf:/etc/redis/redis.conf
      - ./7904/data:/data
    command: ["redis-server", "/etc/redis/redis.conf"] # 覆盖容器启动后默认执行的命令
  redis-7905: # 服务名称
    image: redis:latest # 创建容器时所需的镜像
    container_name: redis-7905 # 容器名称
    restart: always # 容器总是重新启动
    ports:
      - 7905:7905
      - 17905:17905
    volumes: # 数据卷,目录挂载
      - ./etc_rc.local:/etc/rc.local
      - ./7905/redis.conf:/etc/redis/redis.conf
      - ./7905/data:/data
    command: ["redis-server", "/etc/redis/redis.conf"] # 覆盖容器启动后默认执行的命令
  redis-7906: # 服务名称
    image: redis:latest # 创建容器时所需的镜像
    container_name: redis-7906 # 容器名称
    restart: always # 容器总是重新启动
    ports:
      - 7906:7906
      - 17906:17906
    volumes: # 数据卷,目录挂载
      - ./etc_rc.local:/etc/rc.local
      - ./7906/redis.conf:/etc/redis/redis.conf
      - ./7906/data:/data
    command: ["redis-server", "/etc/redis/redis.conf"] # 覆盖容器启动后默认执行的命令


相关实践学习
基于Redis实现在线游戏积分排行榜
本场景将介绍如何基于Redis数据库实现在线游戏中的游戏玩家积分排行榜功能。
云数据库 Redis 版使用教程
云数据库Redis版是兼容Redis协议标准的、提供持久化的内存数据库服务,基于高可靠双机热备架构及可无缝扩展的集群架构,满足高读写性能场景及容量需弹性变配的业务需求。 产品详情:https://www.aliyun.com/product/kvstore     ------------------------------------------------------------------------- 阿里云数据库体验:数据库上云实战 开发者云会免费提供一台带自建MySQL的源数据库 ECS 实例和一台目标数据库 RDS实例。跟着指引,您可以一步步实现将ECS自建数据库迁移到目标数据库RDS。 点击下方链接,领取免费ECS&RDS资源,30分钟完成数据库上云实战!https://developer.aliyun.com/adc/scenario/51eefbd1894e42f6bb9acacadd3f9121?spm=a2c6h.13788135.J_3257954370.9.4ba85f24utseFl
相关文章
|
1天前
|
NoSQL 算法 Java
深入浅出Redis(八):Redis的集群模式
深入浅出Redis(八):Redis的集群模式
|
7天前
|
NoSQL Redis
透视Redis集群:心跳检测如何维护高可用性
Redis心跳检测保障集群可靠性,通过PING命令检测主从连接状态,预防数据丢失。当连接异常时,自动触发主从切换。此外,心跳检测辅助实现`min-slaves-to-write`和`min-slaves-max-lag`策略,避免不安全写操作。还有重传机制,确保命令无丢失,维持数据一致性。合理配置心跳检测,能有效防止数据问题,提升Redis集群的高可用性。关注“软件求生”获取更多Redis知识!
107 10
透视Redis集群:心跳检测如何维护高可用性
|
8天前
|
监控 NoSQL 算法
探秘Redis分布式锁:实战与注意事项
本文介绍了Redis分区容错中的分布式锁概念,包括利用Watch实现乐观锁和使用setnx防止库存超卖。乐观锁通过Watch命令监控键值变化,在事务中执行修改,若键值被改变则事务失败。Java代码示例展示了具体实现。setnx命令用于库存操作,确保无超卖,通过设置锁并检查库存来更新。文章还讨论了分布式锁存在的问题,如客户端阻塞、时钟漂移和单点故障,并提出了RedLock算法来提高可靠性。Redisson作为生产环境的分布式锁实现,提供了可重入锁、读写锁等高级功能。最后,文章对比了Redis、Zookeeper和etcd的分布式锁特性。
108 16
探秘Redis分布式锁:实战与注意事项
|
9天前
|
监控 NoSQL 算法
Redis集群模式:高可用性与性能的完美结合!
小米探讨Redis集群模式,通过一致性哈希分散负载,主从节点确保高可用性。节点间健康检测、主备切换、数据复制与同步、分区策略和Majority选举机制保证服务可靠性。适合高可用性及性能需求场景,哨兵模式则适用于简单需求。一起学习技术的乐趣!关注小米微信公众号“软件求生”获取更多内容。
41 11
Redis集群模式:高可用性与性能的完美结合!
|
10天前
|
监控 NoSQL Redis
|
11天前
|
存储 NoSQL Java
Spring Boot与Redis:整合与实战
【4月更文挑战第29天】Redis,作为一个高性能的键值存储数据库,广泛应用于缓存、消息队列、会话存储等多种场景中。在Spring Boot应用中整合Redis可以显著提高数据处理的效率和应用的响应速度。
26 0
|
14天前
|
存储 缓存 NoSQL
node实战——koa给邮件发送验证码并缓存到redis服务(node后端储备知识)
node实战——koa给邮件发送验证码并缓存到redis服务(node后端储备知识)
19 0
|
15天前
|
NoSQL Redis Docker
使用Docker搭建Redis主从集群
使用Docker搭建Redis主从集群
32 1
|
15天前
|
存储 缓存 NoSQL
Redis入门到通关之Redis缓存数据实战
Redis入门到通关之Redis缓存数据实战
21 0
|
15天前
|
存储 缓存 NoSQL
Redis实现延迟任务的几种方案
Redis实现延迟任务的几种方案