Redis教程

Docker部署Redis Cluster

本文主要是介绍Docker部署Redis Cluster,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!

Docker部署Redis Cluster

1.结构
3主3从,hash槽算法负载均衡
2.端口
3主:7000、7001、7002 3从: 7003、7004、7005
3.配置文件
redis.conf

最小配置方案:(官网)

port xxx
cluster-enabled yes
cluster-config-file nodes.conf
cluster-node-timeout 5000
appendonly yes

配置流程

/opt/redis
/7000/redis.conf
/7001/redis.conf
/7002/redis.conf
/7003/redis.conf
/7004/redis.conf
/7005/redis.conf
mkdir /opt/redis
cd /opt/redis
mkdir 7000 7001 7002 7003 7004 7005

cat <<EOF >7000/redis.conf
port 7000
cluster-enabled yes
cluster-config-file nodes.conf
cluster-node-timeout 5000
appendonly yes
EOF

4.启动6个redis实例

--net=host: 让docker容器直接使用宿主机的指定端口,不需要端口映射
redis-server /redis.conf:让redis服务以配置文件的配置方式运行
docker run -d --name redis7000 \
-v /opt/redis/7000/redis.conf:/redis.conf \
--net=host \
--restart=always \
redis \
redis-server /redis.conf 

5.开启集群配置

--cluster-replicas x:配置一台主机分配x台从机

在其中一个docker容器中执行:

docker exec -it redis7000 \
redis-cli --cluster create 192.168.64.150:7000 192.168.64.150:7001 \
192.168.64.150:7002 192.168.64.150:7003 192.168.64.150:7004 192.168.64.150:7005 \
--cluster-replicas 1

执行完成后,显示16384个哈希槽被覆盖:
在这里插入图片描述
6.查看集群信息

命令参数:-c:以集群方式访问 ; -p 指定redis的访问端口(不指定默认的为6379)
cluster info:查看集群信息
cluster nodes:查看集群节点信息
docker exec -it redis7000 redis-cli -c -p 7000
cluster info
cluster nodes

7.测试集群:

存数据:观察存放数据时,节点的切换存储 – 查询和存储会进行redis重定向

docker exec -it redis7000 redis-cli -c -p 7000
set a 1111111
set b 222222222
set c 333333333

在这里插入图片描述
8.Java API 测试 Redis集群(Spring封装的API):
使用Spring Data提供的Spring Data Redis工具类

yml配置

spring:
  redis:
    cluster:
      nodes:
        - 192.168.64.150:7000
        - 192.168.64.150:7001
        - 192.168.64.150:7002
        - 192.168.64.150:7003
        - 192.168.64.150:7004
        - 192.168.64.150:7005

JAVA实现

Redis Cluster Connection(API):
ConnectionFactory - RedisClusterConnection - CRUD operation
@SpringBootApplication
public class Application {
    /*
     * 测试redis集群
     * */
    @Autowired
    private RedisConnectionFactory factory;

    public static void main(String[] args) {
        SpringApplication.run(Application.class, args);
    }
    /*
    * spring执行流程:
    * 扫描 --> 创建实例 --> 依赖注入 --> @PostConstruct(用于执行一些自定义初始化操作)
    * */
    @PostConstruct
    public void test() {
        RedisClusterConnection cluster = factory.getClusterConnection();
        for (int i = 0; i < 100; i++) {
            String k = "k"+i;
            String v = "v"+i;
            cluster.set(k.getBytes(),v.getBytes());
        }
    }
}

在这里插入图片描述

这篇关于Docker部署Redis Cluster的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!