php成功操作redis cluster集群的实例教程
时间:2022-07-27
本文章向大家介绍php成功操作redis cluster集群的实例教程,主要内容包括其使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。
前言
java操作redis cluster集群可使用jredis
php要操作redis cluster集群有两种方式:
1、使用phpredis扩展,这是个c扩展,性能更高,但是phpredis2.x扩展不行,需升级phpredis到3.0,但这个方案参考资料很少
2、使用predis,纯php开发,使用了命名空间,需要php5.3+,灵活性高
我用的是predis,下载地址:点击这里
步骤如下:
下载好后重命名为predis,
server1:192.168.1.198
server2:192.168.1.199
predis.php
<?php
require 'predis/autoload.php';//引入predis相关包
//redis实例
$servers = array(
'tcp://192.168.1.198:7000',
'tcp://192.168.1.198:7001',
'tcp://192.168.1.198:7002',
'tcp://192.168.1.199:7003',
'tcp://192.168.1.199:7004',
'tcp://192.168.1.199:7005',
);
$client = new PredisClient($servers, array('cluster' = 'redis'));
$client- set("name1", "11");
$client- set("name2", "22");
$client- set("name3", "33");
$name1 = $client- get('name1');
$name2 = $client- get('name2');
$name3 = $client- get('name3');
var_dump($name1, $name2, $name3);die;
name1,name2,name3是3个key,按照算法分配到3个slot上,有可能分到3台服务器上
首先运行predis.php查看结果:
然后登录到redis客户端进行集群验证:
server1
[root@localhost src]# redis-cli -c -p 7000
127.0.0.1:7000 get name1
- Redirected to slot [12933] located at 192.168.1.199:7004
"11"
192.168.1.199:7004 get name2
- Redirected to slot [742] located at 192.168.1.199:7003
"22"
192.168.1.199:7003 get name3
"33"
192.168.1.199:7003
server2
[root@localhost src]# redis-cli -c -p 7003
127.0.0.1:7003 get name1
- Redirected to slot [12933] located at 192.168.1.199:7004
"11"
192.168.1.199:7004 get name2
- Redirected to slot [742] located at 192.168.1.199:7003
"22"
192.168.1.199:7003 get name3
"33"
192.168.1.199:7003
可以看到数据分布在各个服务器上,可以根据ps -ef | grep redis
,杀掉其中几个redis实例,再看效果
总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对ZaLou.Cn的支持。
- Android扫描多媒体文件剖析
- Android的进程与线程使用总结
- Android在WebView中加载HTML并实现交互
- 使用ASP.NET MVC2+PDF.NET 构建一个简单的新闻管理程序 示例过程
- 【开源】QuickPager ASP.NET2.0分页控件V2.0.0.3 【增加了使用说明】
- Android中Java和JavaScript交互
- Android UI控件系列:TabWidget(切换卡)
- 在Linux系统运行WinForm程序
- 将ZIP文件添加到程序集资源文件然后在运行时解压文件
- Android中App安装位置详解
- Java面试题系列之基础部分(二)——每天学5个问题
- Java面试题系列之基础部分(四)——每天学5个问题
- 使用ORM框架,必须迁就数据库的设计吗?
- 使用OQL+SQLMAP解决ORM多表复杂的查询问题
- JavaScript 教程
- JavaScript 编辑工具
- JavaScript 与HTML
- JavaScript 与Java
- JavaScript 数据结构
- JavaScript 基本数据类型
- JavaScript 特殊数据类型
- JavaScript 运算符
- JavaScript typeof 运算符
- JavaScript 表达式
- JavaScript 类型转换
- JavaScript 基本语法
- JavaScript 注释
- Javascript 基本处理流程
- Javascript 选择结构
- Javascript if 语句
- Javascript if 语句的嵌套
- Javascript switch 语句
- Javascript 循环结构
- Javascript 循环结构实例
- Javascript 跳转语句
- Javascript 控制语句总结
- Javascript 函数介绍
- Javascript 函数的定义
- Javascript 函数调用
- Javascript 几种特殊的函数
- JavaScript 内置函数简介
- Javascript eval() 函数
- Javascript isFinite() 函数
- Javascript isNaN() 函数
- parseInt() 与 parseFloat()
- escape() 与 unescape()
- Javascript 字符串介绍
- Javascript length属性
- javascript 字符串函数
- Javascript 日期对象简介
- Javascript 日期对象用途
- Date 对象属性和方法
- Javascript 数组是什么
- Javascript 创建数组
- Javascript 数组赋值与取值
- Javascript 数组属性和方法