Jedis操作Redis的sentinel示例代码:

总共四台机器,crxy99,crxy98分别是主节点和从节点.   crxy97和crxy96是两个监控此主从架构的sentinel节点.

上代码:

 1 import org.junit.Test;
 2
 3 import redis.clients.jedis.HostAndPort;
 4 import redis.clients.jedis.Jedis;
 5 import redis.clients.jedis.JedisPoolConfig;
 6 import redis.clients.jedis.JedisSentinelPool;
 7
 8 public class TestSentinel {
 9     @Test
10     public void test1() {
11         JedisPoolConfig poolConfig = new JedisPoolConfig();
12         String masterName = "mymaster";
13         Set<String> sentinels = new HashSet<String>();
14         sentinels.add("192.168.1.97:26379");
15         sentinels.add("192.168.1.96:26379");
16         JedisSentinelPool jedisSentinelPool = new JedisSentinelPool(masterName, sentinels, poolConfig);
17         HostAndPort currentHostMaster = jedisSentinelPool.getCurrentHostMaster();
18         System.out.println(currentHostMaster.getHost()+"--"+currentHostMaster.getPort());//获取主节点的信息
19         Jedis resource = jedisSentinelPool.getResource();
20         String value = resource.get("a");
21         System.out.println(value);//获得键a对应的value值
22         resource.close();
23     }
24
25 }

运行结果入下:

192.168.1.99--6379
1

Jedis操作集群示例代码:

模拟的集群环境.在一台机器上启动多个redis..每个redis对应的是不同端口.

在crxy99 192.168.1.99上启动的....总共3主3从 端口号对应的的是7000~7005.....

看代码:

 1 import java.util.HashSet;
 2 import java.util.Set;
 3 import org.junit.Test;
 4 import redis.clients.jedis.HostAndPort;
 5 import redis.clients.jedis.JedisCluster;
 6 import redis.clients.jedis.JedisPoolConfig;
 7
 8 public class TestCluster {
 9     @Test
10     public void test1() throws Exception {
11         JedisPoolConfig poolConfig = new JedisPoolConfig();
12         Set<HostAndPort> nodes = new HashSet<HostAndPort>();
13         HostAndPort hostAndPort = new HostAndPort("192.168.1.99", 7000);
14         HostAndPort hostAndPort1 = new HostAndPort("192.168.1.99", 7001);
15         HostAndPort hostAndPort2 = new HostAndPort("192.168.1.99", 7002);
16         HostAndPort hostAndPort3 = new HostAndPort("192.168.1.99", 7003);
17         HostAndPort hostAndPort4 = new HostAndPort("192.168.1.99", 7004);
18         HostAndPort hostAndPort5 = new HostAndPort("192.168.1.99", 7005);
19         nodes.add(hostAndPort);
20         nodes.add(hostAndPort1);
21         nodes.add(hostAndPort2);
22         nodes.add(hostAndPort3);
23         nodes.add(hostAndPort4);
24         nodes.add(hostAndPort5);
25         JedisCluster jedisCluster = new JedisCluster(nodes, poolConfig);//JedisCluster中默认分装好了连接池.
26         //redis内部会创建连接池,从连接池中获取连接使用,然后再把连接返回给连接池
27         String string = jedisCluster.get("a");
28         System.out.println(string);
29     }
30 }

转载于:https://www.cnblogs.com/DreamDrive/p/5631501.html

Java代码操作Redis的sentinel和Redis的集群Cluster操作相关推荐

  1. 【转】Java代码操作Redis的sentinel和Redis的集群Cluster操作

    总共四台机器,crxy99,crxy98分别是主节点和从节点.   crxy97和crxy96是两个监控此主从架构的sentinel节点. 直接看代码: 1 import org.junit.Test ...

  2. Redis 如何使用 Twemproxy 和 Sentinel 构建高可用集群架构?

    文章目录 Redis 如何使用 Twemproxy 和 Sentinel 构建高可用集群架构? 配置环境 构建 RedisSharding1 安装 Redis 配置 RedisSharding1 构建 ...

  3. Redis设计与实现 笔记 第十七章 集群 cluster

    集群 Redis 集群是 Redis 提供的分布式数据库方案,集群通过分片来进行数据共享,并提供复制和故障转移功能 17.1 节点 一个 Redis 集群通常由多个节点组成,在刚开始的时候,每个节点都 ...

  4. 【Redis】集群(cluster)

    文章目录 Redis集群(cluster) 定义 官网 作用 集群算法(分片->槽位) 分片(每台Redis实例) 槽位 slot槽位映射 哈希取余分区 一致性哈希算法分区 哈希槽分区 搭建三主 ...

  5. Redis 高级特性(5)— 集群模式(主从模式、哨兵模式、cluster 集群模式)

    Redis 是如何做到高可用的呢? 它主要通过支持主从模式.哨兵模式.集群模式这三种模式,来满足不同业务特点和可用等级的需求. 其中,主从模式部署最简单,用得也最多,集群模式比较复杂,但可用性最高. ...

  6. redis专题:redis的主从、哨兵、集群架构的配置和部署详情、以及问题分析

    文章目录 1. 在linux下安装redis 2. redis主从架构 2.1 redis主从架构搭建步骤 2.2 redis主从架构数据同步原理 2.3 如果在主从传输过程中,从节点挂了怎么办? 2 ...

  7. 缓存加速------Redis主从复制,哨兵模式,集群

    目录 前言 一.Redis主从复制 1.Redis主从复制概述 2.Redis主从复制作用 3.Redis主从复制流程 4.搭建Redis主从复制 ①环境准备 ②安装Redis ③修改Redis配置文 ...

  8. 不会-Redis 水滴石穿之(七)集群

    Redis 水滴石穿之(七)集群 目录 Redis 水滴石穿之(七)集群 一.概述 二.集群搭建 2.1.手动搭建集群 1.修改配置文件 2.启动节点 3.节点握手 4.分配槽 5.指定主从关系 2. ...

  9. Redis 主从复制、哨兵模式、集群

    1.单机模式 持久化是最简单的高可用方法(有时甚至不被归为高可用的手段),主要作用是数据备份,即将数据存储在硬盘,保证数据不会因进程退出而丢失. 缺点 单机故障,无法保证数据的安全 读写操作无法负载均 ...

最新文章

  1. Android View体系(十)自定义组合控件
  2. boost::mp11::mp_third相关用法的测试程序
  3. BASH Shell 简易进度条小函数
  4. linux mount 查看挂载目录,Linux下使用mount来挂载设备到目录
  5. [python 学习] requests 库的使用
  6. 结果出来了!视觉中国被罚30万 再次发布道歉声明...
  7. 适配器模式真的很简单
  8. go 中recover捕获异常
  9. 英雄启动出错解决方法_超纯水设备高压泵不启动解决方法
  10. Kinect + OpenNI + OpenCV + OpenGL 三维重建
  11. java基础考试_Java基础试题及其答案
  12. 毕业设计 大学生心理健康管理平台
  13. 计算机智能化的例子,工程机械智能化技术案例实例.ppt
  14. 手机浏览器点击标签出现蓝色背景解决方法
  15. java mediatype属性_Java MediaType.MULTIPART_FORM_DATA_TYPE属性代码示例
  16. python matplotlib实现动态实时温度曲线
  17. 史上最长最恐怖的12個英文单词
  18. android 8.0 耳机线控,最新资讯 | 安卓8.0这大变化没法忍!要弃耳机孔
  19. 系统开发视角下的诊断 ———— 动力系统(P)诊断故障6
  20. 提升深度学习模型的表现,你需要这20个技巧

热门文章

  1. 安装mariadb以及允许远程访问
  2. Liferay激活Navigation和Breadcrumb
  3. Bash shell的内建命令:type
  4. tp数据库表大写命名的一些问题
  5. 函数作用域导致的问题
  6. ASA/PIX: Load balancing between two ISP - options
  7. 基于遗传算法实现自动组卷
  8. @responseBody注解的使用
  9. 实验四---继承与派生练习以及运算符[ ]重载练习
  10. Java集合—PriorityQueue底层原理