Windows10搭建Redis集群及Java客户端测试Redis集群

男娘i 2022-05-14 12:21 321阅读 0赞

Redis-Cluster

Redis是在内存中保存数据的,而我们的电脑一般内存都不大,这也就意味着Redis不适合存储大数据,适合存储大数据的是Hadoop生态系统的Hbase或者是MogoDB。Redis更适合处理高并发,一台设备的存储能力是很有限的,但是多台设备协同合作,就可以让内存增大很多倍,这就需要用到集群。
redis 3.0之后版本支持redis-cluster集群,它是Redis官方提出的解决方案,Redis-Cluster采用无中心结构,每个节点保存数据和整个集群状态,每个节点都和其他所有节点连接。其redis-cluster架构图如下:
这里写图片描述
客户端与 redis 节点直连,不需要中间 proxy 层.客户端不需要连接集群所有节点连接集群中任何一个可用节点即可。
所有的 redis 节点彼此互联(PING-PONG 机制),内部使用二进制协议优化传输速度和带宽.

分布存储机制-槽

Redis 集群中内置了 16384 个哈希槽,当需要在 Redis 集群中放置一个 key-value 时,redis 先对 key 使用 crc16 算法算出一个结果,然后把结果对 16384 求余数,这样每个key 都会对应一个编号在 0-16383 之间的哈希槽,redis 会根据节点数量大致均等的将哈希槽映射到不同的节点。

容错机制-投票

选举过程是集群中所有master参与,如果半数以上master节点与故障节点通信超过(cluster-node-timeout),认为该节点故障,自动触发故障转移操作. 故障节点对应的从节点自动升级为主节点

Redis集群搭建

下面搭建三主三从的Redis集群

安装ruby

从官方下载安装包
https://rubyinstaller.org/downloads/
版本如下
这里写图片描述
双击安装

安装rubygems

从官方中下载 zip包
https://rubygems.org/pages/download
这里写图片描述
选择zip

解压后,在cmd中使用setup.rb安装

gem安装redis

这里写图片描述

安装redis

redis是没有windows的安装文件,但Microsoft提供支持
从官方的github上下载
https://github.com/MicrosoftArchive/redis/releaseshttps://github.com/MicrosoftArchive/redis/releases
版本如下
这里写图片描述
创建文件夹D:\server\redis-cluster放6个redis安装包
把redis的zip解压到D:\server\redis-cluster\Redis-1

修改配置文件redis.windows.conf

  1. port 6379
  2. cluster-enable yes
  3. appendonly yes
  4. cluster-node-timeout 15000

cluster-enabled 选项用于开实例的集群模式,

其他的复制,修改端口为6380 6381 6382 6383 6384即可

编写一个 bat 来启动 redis,在每个节点目录下建立 start.bat,内容如下:

  1. title redis-6380
  2. redis-server.exe redis.windows.conf

启动集群

启动6个节点的 start.bat
下载redis-trib.rb CSDN的下载地址如下
https://download.csdn.net/download/james23vs24/10404681?utm_source=bbsseo
复制redis-trib.rb到D:\server\redis-cluster\Redis-1
集群命令,三主三从

  1. redis-trib.rb create --replicas 1 127.0.0.1:6379 127.0.0.1:6380 127.0.0.1:6381 127.0.0.1:6382 127.0.0.1:6383 127.0.0.1:6384

下面使用Java客户端测试Redis集群
引入依赖

  1. <!-- https://mvnrepository.com/artifact/redis.clients/jedis -->
  2. <dependency>
  3. <groupId>redis.clients</groupId>
  4. <artifactId>jedis</artifactId>
  5. <version>2.9.0</version>
  6. </dependency>

测试代码很简单,注释写的很详细

  1. @Test
  2. public void test1(){
  3. JedisPoolConfig poolConfig = new JedisPoolConfig();
  4. // 最大连接数
  5. poolConfig.setMaxTotal(1);
  6. // 最大空闲数
  7. poolConfig.setMaxIdle(1);
  8. // 最大允许等待时间,如果超过这个时间还未获取到连接,则会报JedisException异常:
  9. poolConfig.setMaxWaitMillis(1000);
  10. Set<HostAndPort> nodes = new LinkedHashSet<HostAndPort>();
  11. nodes.add(new HostAndPort("127.0.0.1", 6379));
  12. nodes.add(new HostAndPort("127.0.0.1", 6380));
  13. nodes.add(new HostAndPort("127.0.0.1", 6381));
  14. nodes.add(new HostAndPort("127.0.0.1", 6382));
  15. nodes.add(new HostAndPort("127.0.0.1", 6383));
  16. nodes.add(new HostAndPort("127.0.0.1", 6384));
  17. JedisCluster cluster = new JedisCluster(nodes, poolConfig);
  18. cluster.set("age", "18");
  19. System.out.println(cluster.get("age"));
  20. try {
  21. cluster.close();
  22. } catch (IOException e) {
  23. e.printStackTrace();
  24. }
  25. }

发表评论

表情:
评论列表 (有 0 条评论,321人围观)

还没有评论,来说两句吧...

相关阅读

    相关 WindowsRedis

    功名竹帛非我事,存亡贵贱付皇天 序 好久没写博客了,有点生疏了。这次介绍下我研究了很久的Redis集群。 步骤 1. 这里需要用到Ruby语言,这里我不再赘述

    相关 windowsredis

    作为一 个高性能的key-value数据库,redis的应用场景非常广泛,无论是应用缓存还是token验证,都离不开它的影子,和memcached不同,redis不存在旧...