当前位置: 首页 > news >正文

redis集群模式连接

目录

一:背景

二:实现过程

三:总结


一:背景

redis集群通过将数据分散存储在多个主节点上,每个主节点可以有多个从节点进行数据的复制,以此来实现数据的高可用性和负载均衡。在集群模式下,客户端不需要关心数据具体存储在哪个节点上,因为Redis集群的客户端库(如PHP的Redis扩展)会自动处理节点间的重定向和数据分片问题。那么我们如何用业务代码连接redis数据库实现像单机redis的读写操作呢?下面我们来实现下。

二:实现过程

1:连接主服务,进行写操作

假定我们的主服务有三个实例,监听的ip和端口分别为:

192.168.1.11 6379

192.168.1.12 6379

192.168.1.13 6379

那么连接代码如下:

$dataKey = 'data';
$key = str_shuffle($dataKey).':'.rand(1,100);

$redisClusterList = ['192.168.1.11:6379','192.168.1.12:6379','192.168.1.13:6379'];
 $redisCluster = new \RedisCluster('myCluster',$redisClusterList,5.0,5.0,false,'123456');
  if ($redisCluster->exists($key)) {
            echo "存在key: ".$redisCluster->get($key)."\n";
    } else {
            $redisCluster->setex($key,100,'200');
           echo "写入key: ".$key."</br>";

   }

2:连接从服务,进行读操作

假定我们的从服务有三个实例,监听的ip和端口分别为:

192.168.1.11 6389

192.168.1.12 6389

192.168.1.13 6389

那么连接从服务的代码如下:

 $redisClusterList = ['192.168.1.11:6389','192.168.1.12:6389','192.168.1.13:6389'];
 $redisCluster = new \RedisCluster('myCluster',$redisClusterList,5.0,5.0,false,'123456');
 if ($redisCluster->exists($key)) {
            echo "redis cluster 存在key: ".$key.' 值: '.$redisCluster->get($key)."\n";
  }

三:总结

过上述示例,我们可以看到在PHP中使用Redis集群进行基本的读写操作并不复杂。关键是正确配置RedisCluster实例,并了解如何在代码中处理数据的读写。此外,还需要注意的是,Redis集群的配置(如主从复制、数据分片等)对客户端的行为有很大影响,因此在设计和实现基于Redis集群的业务系统时,需要充分考虑这些因素。

http://www.lryc.cn/news/444600.html

相关文章:

  • Linux高级I/O:多路转接模型
  • MongoDB Limit 与 Skip 方法
  • 【2025】中医药健康管理小程序(安卓原生开发+用户+管理员)
  • VulnHub-Bilu_b0x靶机笔记
  • Python | Leetcode Python题解之第421题数组中两个数的最大异或值
  • 如何将普通Tokenizer变成Fast Tokenizer
  • 联合复现!考虑最优弃能率的风光火储联合系统分层优化经济调度!
  • Vue开发前端图片上传给java后端
  • react hooks--useCallback
  • 828华为云征文|华为云Flexus X实例docker部署最新Appsmith社区版,搭建自己的低代码平台
  • webservice cxf框架 jaxrs jaxws spring整合 接口测试方法 wsdl报文详解 springboot整合 拦截器 复杂参数类型
  • 2024AI做PPT软件如何重塑演示文稿的创作
  • 谷神后端list转map
  • Java集合(Map篇)
  • VUE3配置路由(超级详细)
  • 【笔记】机器学习算法在异常网络流量监测中的应用
  • 江协科技STM32学习- P15 TIM输出比较
  • 使用python-pptx批量删除备注:清除PPT文档中的所有备注信息
  • RTX NVIDIA 3090卡配置对应pytorch,CUDA版本,NVIDIA驱动过程及问题整理
  • 【Verilog学习日常】—牛客网刷题—Verilog快速入门—VL21
  • 【深度】为GPT-5而生的「草莓」模型!从快思考—慢思考到Self-play RL的强化学习框架
  • 【编程底层原理】Java常用读写锁的使用和原理
  • 自恢复保险丝SMD1206B005TF在电路中起什么作用
  • 2024年躺平,花大半年的时间,就弄了这一件事儿:《C++面试真题宝典》
  • PHP基础语法讲解
  • 【论文速看】DL最新进展20240923-长尾综述、人脸防伪、图像分割
  • device靶机详解
  • 十四、SOA(在企业中的应用场景)
  • 单片机与PIC的区别:多方面对比
  • python新手的五个练习题