Redis三主三从集群搭建(docker版)

news2025/1/11 5:57:48

文章目录

    • 1.分布式存储算法
        • 1.哈希取余算法
        • 2.一致性哈希算法
          • 1.基本介绍
          • 2.优点
            • 1.容错性
            • 2.扩展性
          • 3.缺点:数据倾斜问题
        • 3.哈希槽分区(大厂常用)
    • 2.基础环境搭建
        • 1.给六台机器都安装docker
          • 1.卸载旧版本的docker
          • 2.安装 gcc相关
          • 3.安装`yum-utils`软件包
          • 4.docker设置阿里云的镜像仓库,最好不要设置国外的
          • 5.更新yum包的索引(linux基础,以后使用yum会快一些)
          • 6.安装最新版的docker
          • 7.启动docker进程并查看docker是否成功启动
          • 8.运行docker
          • 9.停止docker
          • 10.设置docker自启动并确认是否设置成功!
          • 11.阿里云镜像加速器配置
            • 1.找到容器镜像服务
            • 2.得到镜像加速器地址
            • 3.创建目录,并通过修改daemon配置文件/etc/docker/daemon.json来使用加速器
            • 4.重启daemon
            • 5.重启docker
        • 2.部署规划图
        • 3.配置一个基础的Redis容器
          • 1.拉取redis:6.0.8到本地
          • 2.在宿主机新建目录 /app/redis,存放redis的配置文件
          • 3.从redis6.0.8中得到一份redis.conf的配置文件
            • 1.将压缩包上传到/opt目录下
            • 2.进入/opt目录然后解压
            • 3.复制一份redis.conf到/app/redis目录下
            • 4.查看配置文件
          • 4.对配置文件进行修改
            • 1.编辑配置文件
            • 2.设置redis密码 requirepass foobared
            • 3.使redis支持远程访问 bind 127.0.0.1 和 protected-mode
            • 4.设置daemonize no,如果是yes会与docker的-d方式冲突
          • 5.启动Redis
          • 6.连接Redis
            • 1.使用exec命令进入redis容器
            • 2.连接redis-cli
            • 3.进行操作测试
          • 7.开放6480端口
            • 1.宝塔开启
            • 2.腾讯云开启
          • 8.使用Jedis连接Redis测试
        • 4.使用阿里云镜像仓库,将Redis容器制作为镜像发布(暂时使用不了)
          • 1.访问阿里云的容器镜像服务
          • 2.创建一个命名空间sunxiansheng,设置公开
          • 3.创建镜像仓库,记得选择命名空间
            • 1.创建仓库
            • 2.进行配置,选择命名空间和仓库名称
            • 3.选择本地仓库
            • 4.创建成功!
          • 4.将redis容器commit到我们的新镜像(在容器外执行)
            • 1.命令格式
            • 2.查看redis容器的ImageId,并执行命令,构建新镜像 redis-cluster:1.0
          • 5.将本地镜像发布到阿里云镜像仓库(根据阿里云提供的指令即可)
            • 1.首先登录阿里云镜像仓库
            • 2.根据要求设置要推送的本地镜像
            • 3.发布镜像到阿里云镜像仓库
          • 6.测试拉取镜像直接执行
            • 1.首先删除本地的镜像
            • 2.拉取镜像到本地
            • 3.删除之前进行目录挂载的/app/redis目录,为了测试启动镜像时会不会保留之前的配置
            • 4.还要删除本地的redis-cluster容器(保持环境干净)
            • 5.由于挂载的时候挂载了一个宿主机的/app/redis/redis.conf文件,所以需要手动创建,否则启动会失败
            • 6.启动Redis
            • 7.自定义镜像需要Dockerfile,等学了之后再来补充
        • 5.配置另外五台机器(方式类似以49.232.227.185为例)
          • 1.拉取redis:6.0.8到本地
          • 2.在宿主机新建目录 /app/redis,存放redis的配置文件
          • 3.从最初的机器上得到配置好的redis.conf
            • 1.源服务器使用scp发送文件redis.conf到本服务器的/app/redis下
          • 3.启动Redis
          • 6.连接Redis
            • 1.使用exec命令进入redis容器
            • 2.连接redis-cli
            • 3.进行操作测试
          • 7.开放6480端口
            • 1.宝塔开启
            • 2.腾讯云开启
          • 8.使用Jedis连接Redis测试
    • 3.集群搭建
        • 1.六台服务器都要配置
          • 1.修改redis.conf配置文件
            • 1.编辑配置文件
            • 2.设置redis节点连接其他redis的密码 masterauth(与requirepass 一致即可)
            • 3.重启redis容器
          • 2.开启总线端口10000 + port
            • 1.宝塔开启16480端口
            • 2.腾讯云开启16480端口
          • 3.删除容器,更换为集群模式的启动命令
            • 1.删除原来的容器
            • 2.以集群模式启动的docker命令
            • 3.查看目录/app/redis/data,持久化文件以及节点文件都同步过来了!
        • 2.构建主从关系
          • 1.进入一台机器
          • 2.测试连接redis-cli(注意此时的ip已经在启动时指定了6480)
          • 3.退出redis-cli进行集群构建
          • 4.构建成功!
          • 5.如果发现一直在构建,原因是需要开启总线的端口也就是10000 + 6480
        • 3.常用命令
          • 1.首先进入redis容器的redis-cli
          • 2.查看集群信息
          • 3.查看集群节点
        • 4.SpringBoot测试连接
          • 1.pom.xml
          • 2.application.yml
          • 3.Redis配置类
          • 4.测试的controller
          • 5.启动测试
        • 5.报错 Unable to connect to [10.2.8.11:6480]: connection timed out: /10.2.8.11:6480
          • 1.这个显示的是连接的内网地址,所以需要配置redis.conf的cluster-announce-ip来暴露服务器外网ip
          • 2.编辑配置文件
          • 3.配置 cluster-announce-ip 为每台服务器的外网ip
          • 4.重启redis容器
          • 5.此时就不会再出现连接内网超时的问题了
    • 4.主从扩容和主从缩容
        • 1.主从扩容
          • 1.启动一台主机
            • 1.使用配置好的 redis.conf 启动容器
            • 2.查看配置data目录是否同步
            • 3.开启端口6481和16481
            • 4.jedis测试连接
          • 2.启动一台从机
            • 1.使用配置好的 redis.conf 启动容器
            • 2.开启端口6482和16482
            • 3.jedis测试连接
          • 3.将新增的7号节点作为master节点加入原集群
            • 1.进入七号容器内部
            • 2.添加七号节点到集群(选择任意一个节点即可)
            • 3.检查集群情况,可以看到6481已经作为一个master加入了
          • 4.重新分配槽位
            • 1.执行指令,重新分配槽位
            • 2.计算平均槽位并分配给新机器
            • 3.选择all + yes,意思就是,从其他三台机器共提取4096个槽位给新机器
            • 4.检查集群情况,发现分配规则是前几个机器匀了槽位给新机器
          • 5.添加8号从机到7号主机下面
            • 1.执行指令添加
            • 2.检查集群情况
          • 6.SpringBoot测试连接
            • 1.测试是否可以设置key
            • 2.检查集群情况,观察是否四个机器都能插入

1.分布式存储算法

1.哈希取余算法

image-20240518211701604

image-20240518211807592

2.一致性哈希算法
1.基本介绍

image-20240518212126138

image-20240518212219010

image-20240518212402306

2.优点
1.容错性

image-20240518212904846

2.扩展性

image-20240518212628037

3.缺点:数据倾斜问题

image-20240518212832069

3.哈希槽分区(大厂常用)

image-20240518213334786

image-20240518213434641

2.基础环境搭建

1.给六台机器都安装docker
1.卸载旧版本的docker
sudo yum remove docker \
                  docker-client \
                  docker-client-latest \
                  docker-common \
                  docker-latest \
                  docker-latest-logrotate \
                  docker-logrotate \
                  docker-engine

image-20240517154553368

2.安装 gcc相关
yum -y install gcc && yum -y install gcc-c++

image-20240518195238121

3.安装yum-utils软件包
yum install -y yum-utils

image-20240517155524244

4.docker设置阿里云的镜像仓库,最好不要设置国外的

image-20240517155332913

yum-config-manager --add-repo http://mirrors.aliyun.com/docker-ce/linux/centos/docker-ce.repo

image-20240517155823043

5.更新yum包的索引(linux基础,以后使用yum会快一些)
yum makecache fast

image-20240517155949744

6.安装最新版的docker
yum install docker-ce docker-ce-cli containerd.io docker-buildx-plugin docker-compose-plugin

image-20240517160300623

7.启动docker进程并查看docker是否成功启动
systemctl start docker && ps -aux | grep docker

image-20240517160628449

8.运行docker

在本地找不到,会到远程仓库查找镜像

docker run hello-world

image-20240517160742958

9.停止docker
systemctl stop docker && ps -aux | grep docker

image-20240517161145268

10.设置docker自启动并确认是否设置成功!
systemctl enable docker && systemctl is-enabled docker

image-20240517161257256

11.阿里云镜像加速器配置
1.找到容器镜像服务

https://cr.console.aliyun.com/cn-beijing/instances

image-20240517161923588

2.得到镜像加速器地址

image-20240517162247947

3.创建目录,并通过修改daemon配置文件/etc/docker/daemon.json来使用加速器
mkdir -p /etc/docker && tee /etc/docker/daemon.json <<-'EOF'
{
  "registry-mirrors": ["https://s0qrw5u9.mirror.aliyuncs.com"]
}
EOF
4.重启daemon
systemctl daemon-reload
5.重启docker
systemctl restart docker && ps -aux | grep docker
2.部署规划图

image-20240519140622123

3.配置一个基础的Redis容器
1.拉取redis:6.0.8到本地
docker pull redis:6.0.8

image-20240518155651987

2.在宿主机新建目录 /app/redis,存放redis的配置文件
mkdir -p /app/redis
3.从redis6.0.8中得到一份redis.conf的配置文件
1.将压缩包上传到/opt目录下

image-20240518163817117

2.进入/opt目录然后解压
cd /opt && tar -zxvf redis-6.0.8.tar.gz
3.复制一份redis.conf到/app/redis目录下
cp /opt/redis-6.0.8/redis.conf /app/redis/redis.conf
4.查看配置文件
ll /app/redis

image-20240519144336734

4.对配置文件进行修改
1.编辑配置文件
vim /app/redis/redis.conf
2.设置redis密码 requirepass foobared

image-20240519144542709

3.使redis支持远程访问 bind 127.0.0.1 和 protected-mode

image-20240519144638041

image-20240519144709268

4.设置daemonize no,如果是yes会与docker的-d方式冲突

image-20240519144746500

5.启动Redis
  • 端口映射为6480
  • 名字为redis-cluster
  • /app/redis/redis.conf 挂载 /etc/redis/redis.conf
  • /app/redis/data:/data 挂载 /data
  • -d:后台启动
  • redis:6.0.8:镜像名字
  • redis-server /etc/redis/redis.conf 指定容器中的配置文件来启动
docker run -p 6480:6379 --name redis-cluster --privileged=true \
-v /app/redis/redis.conf:/etc/redis/redis.conf \
-v /app/redis/data:/data -d redis:6.0.8 \
redis-server /etc/redis/redis.conf

image-20240519145435609

6.连接Redis
1.使用exec命令进入redis容器
docker exec -it redis-cluster /bin/bash

image-20240519145545009

2.连接redis-cli
  • 这里的-p指向的是容器的redis端口默认是6379
  • -a参数指定密码
redis-cli -p 6379 -a 
3.进行操作测试

7.开放6480端口
1.宝塔开启
systemctl start firewalld && firewall-cmd --permanent --add-port=6480/tcp && firewall-cmd --reload && firewall-cmd --query-port=6480/tcp

image-20240519145834678

2.腾讯云开启

image-20240519150021568

8.使用Jedis连接Redis测试

image-20240519150143993

4.使用阿里云镜像仓库,将Redis容器制作为镜像发布(暂时使用不了)
1.访问阿里云的容器镜像服务

https://cr.console.aliyun.com/cn-beijing/instance/repositories

2.创建一个命名空间sunxiansheng,设置公开

image-20240517203410454

3.创建镜像仓库,记得选择命名空间
1.创建仓库

image-20240519151248701

2.进行配置,选择命名空间和仓库名称

image-20240519151434596

3.选择本地仓库

image-20240519151459043

4.创建成功!

image-20240519151543236

4.将redis容器commit到我们的新镜像(在容器外执行)
1.命令格式
docker commit -m="[提交的信息]" -a="[作者名字]" [ImageId] [名称:版本号]
2.查看redis容器的ImageId,并执行命令,构建新镜像 redis-cluster:1.0
docker commit -m="redis集群基础镜像" -a="sun" 85e0dc53515f redis-cluster:1.0

image-20240519152419982

5.将本地镜像发布到阿里云镜像仓库(根据阿里云提供的指令即可)

image-20240519152736012

1.首先登录阿里云镜像仓库
docker login --username=aliyun8104181328 registry.cn-beijing.aliyuncs.com

image-20240519151711109

image-20240519151740831

2.根据要求设置要推送的本地镜像
docker tag [ImageId] registry.cn-beijing.aliyuncs.com/sunxiansheng/redis-cluster:[镜像版本号]
docker tag 5f123e2adb2c registry.cn-beijing.aliyuncs.com/sunxiansheng/redis-cluster:1.0

image-20240519152636949

3.发布镜像到阿里云镜像仓库
docker push registry.cn-beijing.aliyuncs.com/sunxiansheng/redis-cluster:[镜像版本号]
docker push registry.cn-beijing.aliyuncs.com/sunxiansheng/redis-cluster:1.0

image-20240519152932335

6.测试拉取镜像直接执行
1.首先删除本地的镜像

image-20240519153049429

2.拉取镜像到本地

image-20240519153130227

docker pull registry.cn-beijing.aliyuncs.com/sunxiansheng/redis-cluster:[镜像版本号]
docker pull registry.cn-beijing.aliyuncs.com/sunxiansheng/redis-cluster:1.0

image-20240519153234146

3.删除之前进行目录挂载的/app/redis目录,为了测试启动镜像时会不会保留之前的配置
rm -rf /app/redis
4.还要删除本地的redis-cluster容器(保持环境干净)
docker rm -f redis-cluster

image-20240519153836614

5.由于挂载的时候挂载了一个宿主机的/app/redis/redis.conf文件,所以需要手动创建,否则启动会失败
mkdir -p /app/redis && touch /app/redis/redis.conf
6.启动Redis
  • 端口映射为6480
  • 容器名字为redis-cluster
  • /app/redis/redis.conf 挂载 /etc/redis/redis.conf
  • /app/redis/data:/data 挂载 /data
  • -d:后台启动
  • registry.cn-beijing.aliyuncs.com/sunxiansheng/redis-cluster:1.0:镜像名字注意要带标签!
  • redis-server /etc/redis/redis.conf 指定容器中的配置文件来启动
docker run -p 6480:6379 --name redis-cluster --privileged=true \
-v /app/redis/redis.conf:/etc/redis/redis.conf \
-v /app/redis/data:/data -d registry.cn-beijing.aliyuncs.com/sunxiansheng/redis-cluster:1.0 \
redis-server /etc/redis/redis.conf
7.自定义镜像需要Dockerfile,等学了之后再来补充
5.配置另外五台机器(方式类似以49.232.227.185为例)
1.拉取redis:6.0.8到本地
docker pull redis:6.0.8

image-20240518155651987

2.在宿主机新建目录 /app/redis,存放redis的配置文件
mkdir -p /app/redis
3.从最初的机器上得到配置好的redis.conf
1.源服务器使用scp发送文件redis.conf到本服务器的/app/redis下
scp 源用户@源ip:源文件 目标用户@目标ip:目标文件夹

3.启动Redis
  • 端口映射为6480
  • 名字为redis-cluster
  • /app/redis/redis.conf 挂载 /etc/redis/redis.conf
  • /app/redis/data:/data 挂载 /data
  • -d:后台启动
  • redis:6.0.8:镜像名字
  • redis-server /etc/redis/redis.conf 指定容器中的配置文件来启动
docker run -p 6480:6379 --name redis-cluster --privileged=true \
-v /app/redis/redis.conf:/etc/redis/redis.conf \
-v /app/redis/data:/data -d redis:6.0.8 \
redis-server /etc/redis/redis.conf

image-20240519163328718

6.连接Redis
1.使用exec命令进入redis容器
docker exec -it redis-cluster /bin/bash

image-20240519145545009

2.连接redis-cli
  • 这里的-p指向的是容器的redis端口默认是6379
  • -a参数指定密码
redis-cli -p 6379 -a 
3.进行操作测试

7.开放6480端口
1.宝塔开启
systemctl start firewalld && firewall-cmd --permanent --add-port=6480/tcp && firewall-cmd --reload && firewall-cmd --query-port=6480/tcp

image-20240519145834678

2.腾讯云开启

image-20240519150021568

8.使用Jedis连接Redis测试

image-20240519150143993

3.集群搭建

1.六台服务器都要配置
1.修改redis.conf配置文件
1.编辑配置文件
vim /app/redis/redis.conf
2.设置redis节点连接其他redis的密码 masterauth(与requirepass 一致即可)

image-20240503115843829

3.重启redis容器
docker restart redis-cluster

image-20240519171426759

2.开启总线端口10000 + port
1.宝塔开启16480端口
systemctl start firewalld && firewall-cmd --permanent --add-port=16480/tcp && firewall-cmd --reload && firewall-cmd --query-port=16480/tcp
2.腾讯云开启16480端口
3.删除容器,更换为集群模式的启动命令
1.删除原来的容器
docker rm -f redis-cluster

image-20240519173654230

2.以集群模式启动的docker命令
  • -d:后台启动
  • –name:容器名字为redis-node-1,后面依次增加序号
  • –net:host表示使用主机的ip和端口,会根据指定配置文件中的端口直接在主机使用不需要映射
  • –privileged=true:使用数据卷的标配
  • /app/redis/redis.conf 挂载 /etc/redis/redis.conf
  • /app/redis/data:/data 挂载 /data
  • redis:6.0.8:镜像名字
  • redis-server:指定配置文件启动
  • –cluster-enabled yes:以集群模式启动
  • –appendonly yes:使用aof持久化策略
  • –dir /data:设置数据(包括 AOF 文件)存储目录在容器内的/data下,会自动同步到主机,因为前面做了挂载
  • –port 6480:指定启动端口为6480
  • –cluster-config-file /data/nodes.conf:节点配置文件位置在容器内的/data/nodes.conf,会自动同步到主机
  • –cluster-node-timeout:设置节点超时时间为5秒
docker run -d --name redis-node-1 --net=host --privileged=true \
  -v /app/redis/data:/data \
  -v /app/redis/redis.conf:/etc/redis/redis.conf \
  redis:6.0.8 \
  redis-server /etc/redis/redis.conf \
  --cluster-enabled yes \
  --appendonly yes \
  --dir /data \
  --port 6480 \
  --cluster-config-file /data/nodes.conf \
  --cluster-node-timeout 5000

3.查看目录/app/redis/data,持久化文件以及节点文件都同步过来了!
ll /app/redis/data/

image-20240519180031322

2.构建主从关系
1.进入一台机器
docker exec -it redis-node-5 /bin/bash
2.测试连接redis-cli(注意此时的ip已经在启动时指定了6480)
  • –askpass:询问密码的意思
redis-cli -p 6480 --askpass

image-20240519180730143

3.退出redis-cli进行集群构建
redis-cli --cluster create --cluster-replicas 1 --askpass 
4.构建成功!
5.如果发现一直在构建,原因是需要开启总线的端口也就是10000 + 6480
3.常用命令
1.首先进入redis容器的redis-cli
redis-cli -c -p 6480 --askpass
2.查看集群信息
CLUSTER INFO

image-20240519182825973

3.查看集群节点
 CLUSTER NODES
4.SpringBoot测试连接
1.pom.xml
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
         xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/maven-v4_0_0.xsd">
    <modelVersion>4.0.0</modelVersion>
    <groupId>com.sun.redis</groupId>
    <artifactId>redis_springboot</artifactId>
    <version>1.0-SNAPSHOT</version>
    <name>Archetype - redis_springboot</name>
    <url>http://maven.apache.org</url>

    <parent>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-parent</artifactId>
        <version>2.6.6</version>
        <relativePath/> <!-- lookup parent from repository -->
    </parent>

    <properties>
        <java.version>1.8</java.version>
    </properties>

    <dependencies>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <!-- 说 明 : 如 果 这 里 是 spring-boot-start 就 改 成 如 下
            spring-boot-start-web-->
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>
        <!-- redis -->
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-data-redis</artifactId>
        </dependency>
        <!-- spring2.X 集成 redis 所需 common-pool-->
        <dependency>
            <groupId>org.apache.commons</groupId>
            <artifactId>commons-pool2</artifactId>
            <!--不要带版本号,防止冲突-->
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-test</artifactId>
            <scope>test</scope>
        </dependency>
        <dependency>
            <groupId>com.fasterxml.jackson.core</groupId>
            <artifactId>jackson-databind</artifactId>
            <version>2.13.2.2</version>
        </dependency>
    </dependencies>

    <build>
        <plugins>
            <plugin>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-maven-plugin</artifactId>
            </plugin>
        </plugins>
    </build>
</project>

2.application.yml

# redis集群配置
spring:
  redis:
    password: # Redis服务器密码
    database: 0 # 默认数据库为0号
    timeout: 10000ms # 连接超时时间是10000毫秒
    lettuce:
      pool:
        max-active: 8 # 最大活跃连接数,使用负值表示没有限制,最佳配置为核数*2
        max-wait: 10000ms # 最大等待时间,单位为毫秒,使用负值表示没有限制,这里设置为10秒
        max-idle: 200 # 最大空闲连接数
        min-idle: 5 # 最小空闲连接数
    cluster:
      nodes:


3.Redis配置类
package com.sun.redis.config;

import com.fasterxml.jackson.annotation.JsonAutoDetect;
import com.fasterxml.jackson.annotation.JsonTypeInfo;
import com.fasterxml.jackson.annotation.PropertyAccessor;
import com.fasterxml.jackson.databind.ObjectMapper;
import com.fasterxml.jackson.databind.jsontype.impl.LaissezFaireSubTypeValidator;
import org.springframework.cache.CacheManager;
import org.springframework.cache.annotation.CachingConfigurerSupport;
import org.springframework.cache.annotation.EnableCaching;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.data.redis.cache.RedisCacheConfiguration;
import org.springframework.data.redis.cache.RedisCacheManager;
import org.springframework.data.redis.connection.RedisConnectionFactory;
import org.springframework.data.redis.core.RedisTemplate;
import org.springframework.data.redis.serializer.Jackson2JsonRedisSerializer;
import org.springframework.data.redis.serializer.RedisSerializationContext;
import org.springframework.data.redis.serializer.RedisSerializer;
import org.springframework.data.redis.serializer.StringRedisSerializer;

import java.time.Duration;

/**
 * Description:
 *
 * @Author sun
 * @Create 2024/4/29 21:29
 * @Version 1.0
 */
@EnableCaching
@Configuration
public class RedisConfig extends CachingConfigurerSupport {
    @Bean
    public RedisTemplate<String, Object> redisTemplate(RedisConnectionFactory factory) {
        RedisTemplate<String, Object> template =
                new RedisTemplate<>();
        System.out.println("template=>" + template);
        RedisSerializer<String> redisSerializer =
                new StringRedisSerializer();
        Jackson2JsonRedisSerializer jackson2JsonRedisSerializer =
                new Jackson2JsonRedisSerializer(Object.class);
        ObjectMapper om = new ObjectMapper();
        om.setVisibility(PropertyAccessor.ALL, JsonAutoDetect.Visibility.ANY);
        om.activateDefaultTyping(
                LaissezFaireSubTypeValidator.instance, ObjectMapper.DefaultTyping.NON_FINAL, JsonTypeInfo.As.WRAPPER_ARRAY);
        jackson2JsonRedisSerializer.setObjectMapper(om);
        template.setConnectionFactory(factory);
        // key 序列化方式
        template.setKeySerializer(redisSerializer);
        // value 序列化
        template.setValueSerializer(jackson2JsonRedisSerializer);
        // value hashmap 序列化
        template.setHashValueSerializer(jackson2JsonRedisSerializer);
        return template;
    }

    @Bean
    public CacheManager cacheManager(RedisConnectionFactory factory) {
        RedisSerializer<String> redisSerializer =
                new StringRedisSerializer();
        Jackson2JsonRedisSerializer jackson2JsonRedisSerializer = new
                Jackson2JsonRedisSerializer(Object.class);
        // 解决查询缓存转换异常的问题
        ObjectMapper om = new ObjectMapper();
        om.setVisibility(PropertyAccessor.ALL, JsonAutoDetect.Visibility.ANY);
        om.activateDefaultTyping(
                LaissezFaireSubTypeValidator.instance, ObjectMapper.DefaultTyping.NON_FINAL, JsonTypeInfo.As.WRAPPER_ARRAY);
        jackson2JsonRedisSerializer.setObjectMapper(om);
        // 配置序列化(解决乱码的问题),过期时间 600 秒
        RedisCacheConfiguration config = RedisCacheConfiguration.defaultCacheConfig()
                .entryTtl(Duration.ofSeconds(600))
                .serializeKeysWith(RedisSerializationContext.SerializationPair.fromSerializer(redisSerializer))
                .serializeValuesWith(RedisSerializationContext.SerializationPair.fromSerializer(jackson2JsonRedisSerializer))
                .disableCachingNullValues();
        RedisCacheManager cacheManager = RedisCacheManager.builder(factory)
                .cacheDefaults(config)
                .build();
        return cacheManager;
    }
}
4.测试的controller

image-20240519183728717

5.启动测试

image-20240519183932494

5.报错 Unable to connect to [10.2.8.11:6480]: connection timed out: /10.2.8.11:6480
1.这个显示的是连接的内网地址,所以需要配置redis.conf的cluster-announce-ip来暴露服务器外网ip
2.编辑配置文件
vim /app/redis/redis.conf
3.配置 cluster-announce-ip 为每台服务器的外网ip
4.重启redis容器
docker restart 。。。
5.此时就不会再出现连接内网超时的问题了

4.主从扩容和主从缩容

1.主从扩容
1.启动一台主机
1.使用配置好的 redis.conf 启动容器
  • 注意这里的cluster-announce-ip还是使用的配置文件中本服务器的ip
  • 节点密码也是用的配置文件中的
  • 需要修改的配置
    • –name redis-node-7
    • -v /app/redis/nodes7data:/data
    • –cluster-config-file /data/nodes7.conf
    • –port 6481
docker run -d --name redis-node-7 --net=host --privileged=true \
  -v /app/redis/nodes7data:/data \
  -v /app/redis/redis.conf:/etc/redis/redis.conf \
  redis:6.0.8 \
  redis-server /etc/redis/redis.conf \
  --cluster-enabled yes \
  --appendonly yes \
  --dir /data \
  --port 6481 \
  --cluster-config-file /data/nodes7.conf \
  --cluster-node-timeout 5000
2.查看配置data目录是否同步

image-20240520134108395

3.开启端口6481和16481
systemctl start firewalld && firewall-cmd --permanent --add-port=6481/tcp && firewall-cmd --reload && firewall-cmd --query-port=6481/tcp && systemctl start firewalld && firewall-cmd --permanent --add-port=16481/tcp && firewall-cmd --reload && firewall-cmd --query-port=16481/tcp

image-20240520134213034

image-20240520134327012

4.jedis测试连接
2.启动一台从机
1.使用配置好的 redis.conf 启动容器
docker run -d --name redis-node-8 --net=host --privileged=true \
  -v /app/redis/nodes8data:/data \
  -v /app/redis/redis.conf:/etc/redis/redis.conf \
  redis:6.0.8 \
  redis-server /etc/redis/redis.conf \
  --cluster-enabled yes \
  --appendonly yes \
  --dir /data \
  --port 6482 \
  --cluster-config-file /data/nodes8.conf \
  --cluster-node-timeout 5000
2.开启端口6482和16482
systemctl start firewalld && firewall-cmd --permanent --add-port=6482/tcp && firewall-cmd --reload && firewall-cmd --query-port=6482/tcp && systemctl start firewalld && firewall-cmd --permanent --add-port=16482/tcp && firewall-cmd --reload && firewall-cmd --query-port=1648
2/tcp
3.jedis测试连接
3.将新增的7号节点作为master节点加入原集群
1.进入七号容器内部
docker exec -it redis-node-7 /bin/bash
2.添加七号节点到集群(选择任意一个节点即可)
redis-cli --cluster add-node --askpass
3.检查集群情况,可以看到6481已经作为一个master加入了
redis-cli --cluster check  --askpass
4.重新分配槽位
1.执行指令,重新分配槽位
redis-cli --cluster reshard  --askpass
2.计算平均槽位并分配给新机器

image-20240520141445747

3.选择all + yes,意思就是,从其他三台机器共提取4096个槽位给新机器

image-20240520141645625

image-20240520141703498

4.检查集群情况,发现分配规则是前几个机器匀了槽位给新机器
redis-cli --cluster check  --askpass
5.添加8号从机到7号主机下面
1.执行指令添加
  • a9d42be282f99864cf95500ca909ae55dab5eb6b是主机的id
redis-cli --cluster add-node  --cluster-slave --cluster-master-id a9d42be282f99864cf95500ca909ae55dab5eb6b --askpass
2.检查集群情况
redis-cli --cluster check --askpass
6.SpringBoot测试连接
1.测试是否可以设置key

image-20240520143445686

image-20240520143623117

2.检查集群情况,观察是否四个机器都能插入
redis-cli --cluster check --askpass

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1686733.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

电脑连接爱快iKuai软路由之后,网卡没有正常获取到IP,无法访问爱快路由管理页?

前言 上一次咱们说到在爱快控制台上设置/辨认lan口&#xff0c;设置完成之后&#xff0c;其他的一些设置就需要在爱快iKuai软路由的管理页面上设置。 有些小伙伴会发现&#xff0c;当电脑连接上爱快软路由的lan口之后&#xff0c;电脑并没有正常获取到ip&#xff0c;导致无法访…

从零开始运行BERT的详细教程,使用MRPC数据集进行测试

1、安装anaconda环境 镜像网址:Index of /anaconda/archive/ | 清华大学开源软件镜像站 | Tsinghua Open Source Mirror 2、配置环境变量 3、创建虚拟环境 #常用命令 #创建 conda create -n xxx python3.8 #激活 conda activate xxx #删除 conda remove -n xxx --all #查看 con…

汀木云OZON选品工具,OZON跨境电商的选品利器

在竞争激烈的跨境电商市场中&#xff0c;选品是卖家们成功经营的关键之一。而汀木云OZON选品工具&#xff0c;作为OZON跨境电商的选品利器&#xff0c;以其独特的优势&#xff0c;为卖家们提供了精准、高效的选品解决方案。接下来看看汀木云OZON选品工具和萌啦OZON数据跨境OZON…

客户端Web资源缓存

为了提高Web服务器的性能,其中的一种可以提高Web服务器性能的方法就是采用缓存技术。 1.缓存 1.1.什么是缓存&#xff1f; 如果某个资源的计算耗时或耗资源&#xff0c;则执行一次并存储结果。当有人随后请求该资源时&#xff0c;返回存储的结果&#xff0c;而不是再次计算。…

以太坊(3)——智能合约

智能合约 首先明确一下几个说法&#xff08;说法不严谨&#xff0c;为了介绍清晰才说的&#xff09;&#xff1a; 全节点矿工 节点账户 智能合约是基于Solidity语言编写的 学习Solidity语言可以到WFT学院官网&#xff08;Hello from WTF Academy | WTF Academy&#xff09;…

2024电工杯数学建模选题建议及各题思路来啦!

大家好呀&#xff0c;2024电工杯数学建模竞赛开始了&#xff0c;来说一下初步的选题建议吧&#xff1a; 首先定下主基调&#xff0c; 本次电工杯建议选B。A题目难度较高&#xff0c;只建议有相关专业知识和优化经验的队伍选择&#xff0c;小白队伍无脑选B即可。是比较经典的数…

新媒体时代,LCD电子价签赋予零售场景新活力

近年来&#xff0c;全球企业迅速掀起了数字化转型的浪潮&#xff0c;加速了新零售科技的发展与应用。在实体零售门店中&#xff0c;商品货架显示逐渐趋向智能化和多样化。然而&#xff0c;在信息传播日益碎片化和视频化的时代&#xff0c;零售门店如何更有效地吸引消费者的注意…

go slice 扩容

扩容 slice 会迁移到新的内存位置&#xff0c;新底层数组的长度也会增加&#xff0c;这样就可以放置新增的元素。同时&#xff0c;为了应对未来可能再次发生的 append 操作&#xff0c;新的底层数组的长度&#xff0c;也就是新 slice 的容量是留了一定的 buffer 的。否则&…

【附带效果视频】php接口给前端返回流式数据,php使用event-stream进行数据推送,循环一次输出一次

背景&#xff1a;不分接口需要返回流式数据&#xff0c;循环一次输出一次数据 php接口给前端返回流式数据&#xff0c;循环一次输出一次 返回结果效果视频完整返回结果数据格式控制台网络内查看到的数据格式完整代码 返回结果效果视频 php接口给前端返回流式数据&#xff0c;循…

2024年 电工杯 (A题)大学生数学建模挑战赛 | 园区微电网风光储协调优化配置 | 数学建模完整代码解析

DeepVisionary 每日深度学习前沿科技推送&顶会论文&数学建模与科技信息前沿资讯分享&#xff0c;与你一起了解前沿科技知识&#xff01; 本次DeepVisionary带来的是电工杯的详细解读&#xff1a; 完整内容可以在文章末尾全文免费领取&阅读&#xff01; 问题重述…

2024 电工杯高校数学建模竞赛(A题)| 储能配置 |建模秘籍文章代码思路大全

铛铛&#xff01;小秘籍来咯&#xff01; 小秘籍团队独辟蹊径&#xff0c;运用负载均衡&#xff0c;多目标规划等强大工具&#xff0c;构建了这一题的详细解答哦&#xff01; 为大家量身打造创新解决方案。小秘籍团队&#xff0c;始终引领着建模问题求解的风潮。 抓紧小秘籍&am…

Linux备份服务及rsync企业备份架构(应用场景)

备份服务概述 备份服务:需要使用到脚本,打包备份,定时任务. 备份服务:rsyncd服务,不同主机之间数据传输. 特点&#xff1a; rsync是个服务也是命令使用方便&#xff0c;具有多种模式传输数据的时候是增量传输 增量与全量&#xff1a; 全量 &#xff1a;无论多少数据全部推…

【机器学习】必会降维算法之:t-分布邻域嵌入(t-SNE)

t-分布邻域嵌入&#xff08;t-SNE&#xff09; 1、引言2、随机梯度下降&#xff08;SGD&#xff09;2.1 简介2.1.1 定义2.1.2 应用场景 2.2 原理2.3 实现方式2.4 算法公式2.5 代码示例解析&#xff1a; 3、总结 1、引言 小屌丝&#xff1a;鱼哥&#xff0c; 啥是降维算法 小鱼…

AI三级淋巴结构·预测癌症预后和免疫疗法反应

小罗碎碎念 今天分享的这篇文章对于想从事三级淋巴结交叉研究等同学和老师来说&#xff0c;具有非常重要的参考价值&#xff0c;反正我写完这篇推文以后&#xff0c;觉得受益匪浅。 其中重点需要提醒大家关注的是——从2D组织切片计算的TLS面积已被验证为多种肿瘤类型的预后和…

pycharm打开服务器(linux)上的项目

先在本地打开项目 一、项目文件配置 tools-deployment-configuration 新增一个sftp连接 测试服务器是否可以连通 mappings中设置本地路径和服务器上的路径 二、环境配置 先参考文章 复现论文的conda环境&#xff08;win和联网、离线linux&#xff09;_conda复现环境-CSDN博…

bugku 网络安全事件应急响应

开启靶场&#xff1a; 开始实验&#xff1a; 使用Xshell登录服务器&#xff0c;账号及密码如上图。 1、提交攻击者的IP地址 WP: 找到服务器日志路径&#xff0c;通常是在/var/log/&#xff0c;使用cd /var/log/&#xff0c;ls查看此路径下的文件. 找到nginx文件夹。 进入ng…

SAP Credit Management-Reconcile Documented Credit Decisions

ECC 升级S4后,经过事后迁移后,出现如下报错 找到了这里的配置路径: DCD settings – to maintain/complete Create Profile for Case Search -> no entry UKM_CASE – DCD search -> no search fields BC set UKM_DCD_CUST not activated -> transactio

温故而知新-秒杀项目篇【面试复习】

温故而知新-秒杀项目篇【面试复习】 前言版权推荐温故而知新-论坛项目篇【面试】秒杀项目中注册模块怎么实现的&#xff1f;秒杀项目中登录模块怎么实现的&#xff1f;秒杀项目中显示登录用户信息怎么实现的&#xff1f;SessionStorage是什么?为什么不用session而用token什么是…

2024年电工杯高校数学建模竞赛(B题) 建模解析| 大学生平衡膳食食谱的优化设计 |小鹿学长带队指引全代码文章与思路

我是鹿鹿学长&#xff0c;就读于上海交通大学&#xff0c;截至目前已经帮200人完成了建模与思路的构建的处理了&#xff5e; 本篇文章是鹿鹿学长经过深度思考&#xff0c;独辟蹊径&#xff0c;实现综合建模。独创复杂系统视角&#xff0c;帮助你解决电工杯的难关呀。 本题&…

南京中科微Ci2451+11dbm发射功率 国产8位RISC内核无线MCU芯片

Ci2451是一款在现有的2.4GHz射频芯片基础上&#xff0c;内部集成8位RISC内核&#xff08;精简指令集&#xff09;MCU的SOC芯片。 Ci2451引脚图↑ 无线MCU解决方案&#xff0c;集成丰富的MCU资源、更小尺寸&#xff0c;来满足设计中的各种内存、功率、尺寸要求&#xff0c;充分…