PHP与REDIS
安装
1.一定要搞懂自己php的版本,和环境,今天试一上午,就是因为X86,而我的php环境是X64.
2. 将下载的php_redis.dll和php_igbinary.dll放在php扩展目录中(ext),并修改配置文件php.ini
3.重新启动服务
常用操作
<?php
//PHP操作redis
/*链接redis*/
$redis = new redis();
$result = $redis->connect('127.0.0.1', 6379); /*set 设置 key的值*/
$result = $redis->set('key',"abc"); /*get 获取key的值*/
$result = $redis->get('key');
var_dump($result); //string 'abc' (length=3) /*delete 删除指定的key*/
$redis->set('test',"123456");
$redis->delete('test');
var_dump($redis->get('test')); //boolean false /*setnx 如果数据库中不存在key键,生成key键*/
$redis->setnx('test2',"22222222");
var_dump($redis->get('test2')); //string '22222222' (length=8) /*exists 验证key是否存在*/
var_dump($redis->exists('test2')); //boolean true /*incr 递增数据*/
$redis->set('test',"123");
var_dump($redis->incr("test")); //int 124 /*decr 递减数据*/
var_dump($redis->decr("test")); //int 123 /*getMultiple 给参数数组赋值*/
$redis->set('test1',"1");
$redis->set('test2',"2");
var_dump($redis->getMultiple(array('test1','test2'))); //array (size=2) 0 => string '1' (length=1) 1 => string '2' (length=1) /*lpush 由列表头部添加字符串值。如果不存在该键则创建该列表*/
$redis->delete('test');
var_dump($redis->lpush("test","111")); //结果:int(1)
var_dump($redis->lpush("test","abc")); //结果:int(2) /*rpush 由列表尾部添加字符串值。如果不存在该键则创建该列表。*/
var_dump($redis->rpush("test","333")); //结果:int(3)
var_dump($redis->rpush("test","444")); //结果:int(4) /*lpop 返回和移除列表的第一个元素*/
var_dump($redis->lpop("test")); //string 'abc' (length=3) /*lsize,llen 返回的列表的长度。如果列表不存在或为空,该命令返回0。如果该键不是列表,该命令返回FALSE。*/
var_dump($redis->lsize("test")); //int 3 /*lget 返回指定键存储在列表中指定的元素。 0第一个元素,1第二个… -1最后一个元素,-2的倒数第二*/
var_dump($redis->lget("test",0)); //string '111' (length=3) /*lset 为列表指定的索引赋新的值*/
var_dump($redis->lset("test",0,"333")); //boolean true /*lgetrange 返回在该区域中的指定键列表中开始到结束存储的指定元素*/
print_r($redis->lgetrange("test",0,-1)); // Array ( [0] => 333 [1] => 333 [2] => 444 ) /*lremove 从列表中从头部开始移除count个匹配的值。 key count*/
var_dump($redis->lremove('test','333',1));
print_r($redis->lgetrange('test', 0, -1)); // Array ( [0] => 333 [1] => 444 ) /*sadd 为一个Key添加一个值。如果这个值已经在这个Key中,则返回FALSE。*/
var_dump($redis->sadd('bigtest','111'));
var_dump($redis->sadd('bigtest','333'));
print_r($redis->sort('bigtest')); //Array ( [0] => 111 [1] => 333 ) /*sremove 删除Key中指定的value值*/
$redis->sremove('bigtest','111');
print_r($redis->sort('bigtest')); //Array ( [0] => 333 ) /*smove 将Key1中的value移动到Key2中*/
$redis->delete('test');
$redis->delete('test1');
$redis->sadd('test','111');
$redis->sadd('test','333');
$redis->sadd('test1','222');
$redis->sadd('test1','444');
$redis->smove('test',"test1",'111');
print_r($redis->sort('test1')); //Array ( [0] => 111 [1] => 222 [2] => 444 ) /*scontains 检查集合中是否存在指定的值*/
var_dump($redis->scontains('test1', '111')); //boolean true /*ssize 返回集合中存储值的数量*/
echo $redis->ssize('test1'); //3 /*spop 随机移除并返回key中的一个值*/
var_dump($redis->spop("test1")); /*sinter 返回一个所有指定键的交集。*/
var_dump($redis->sinter("test","test1")); //empty /*sinterstore 把结果储存到新建的变量中*/
var_dump($redis->sinterstore('new',"test","test1")); /*sunion 返回一个所有指定键的并集*/
print_r($redis->sunion("test","test1")); /*sunionstore 把结果储存到新建的变量中*/
var_dump($redis->sunionstore('new',"test","test1")); //int 3 /*sdiff 返回第一个集合中存在并在其他所有集合中不存在的结果*/
print_r($redis->sdiff("test","test1")); //Array ( [0] => 333 ) /*sdiffstore 执行sdiff命令并把结果储存到新建的变量中*/
var_dump($redis->sdiffstore('new',"test","test1")); //int 1 /*smembers, sgetmembers 返回集合的内容*/
print_r($redis->smembers('test1')); //Array ( [0] => 111 [1] => 444 ) ?>
PHP与REDIS的更多相关文章
- 使用redis构建可靠分布式锁
关于分布式锁的概念,具体实现方式,直接参阅下面两个帖子,这里就不多介绍了. 分布式锁的多种实现方式 分布式锁总结 对于分布式锁的几种实现方式的优劣,这里再列举下 1. 数据库实现方式 优点:易理解 缺 ...
- Ignite性能测试以及对redis的对比
测试方法 为了对Ignite做一个基本了解,做了一个性能测试,测试方法也比较简单主要是针对client模式,因为这种方法和使用redis的方式特别像.测试方法很简单主要是下面几点: 不作参数优化,默认 ...
- mac osx 安装redis扩展
1 php -v查看php版本 2 brew search php|grep redis 搜索对应的redis ps:如果没有brew 就根据http://brew.sh安装 3 brew ins ...
- Redis/HBase/Tair比较
KV系统对比表 对比维度 Redis Redis Cluster Medis Hbase Tair 访问模式 支持Value大小 理论上不超过1GB(建议不超过1MB) 理论上可配置(默认配置1 ...
- Redis数据库
Redis是k-v型数据库的典范,设计思想及数据结构实现都值得学习. 1.数据类型 value支持五种数据类型:1.字符串(strings)2.字符串列表(lists)3.字符串集合(sets)4.有 ...
- redis 学习笔记(2)
redis-cluster 简介 redis-cluster是一个分布式.容错的redis实现,redis-cluster通过将各个单独的redis实例通过特定的协议连接到一起实现了分布式.集群化的目 ...
- redis 学习笔记(1)
redis持久化 snapshot数据快照(rdb) 这是一种定时将redis内存中的数据写入磁盘文件的一种方案,这样保留这一时刻redis中的数据镜像,用于意外回滚.redis的snapshot的格 ...
- python+uwsgi导致redis无法长链接引起性能下降问题记录
今天在部署python代码到预生产环境时,web站老是出现redis链接未初始化,无法连接到服务的提示,比对了一下开发环境与测试环境代码,完全一致,然后就是查看各种日志,排查了半天也没有查明是什么原因 ...
- nginx+iis+redis+Task.MainForm构建分布式架构 之 (redis存储分布式共享的session及共享session运作流程)
本次要分享的是利用windows+nginx+iis+redis+Task.MainForm组建分布式架构,上一篇分享文章制作是在windows上使用的nginx,一般正式发布的时候是在linux来配 ...
- windows+nginx+iis+redis+Task.MainForm构建分布式架构 之 (nginx+iis构建服务集群)
本次要分享的是利用windows+nginx+iis+redis+Task.MainForm组建分布式架构,由标题就能看出此内容不是一篇分享文章能说完的,所以我打算分几篇分享文章来讲解,一步一步实现分 ...
随机推荐
- Sql Server 新的日期类型
新的日期类型:是出现在2008中的在2005中没有的日期类型. 1,Date 数据类型 2,time 数据类型 3, datetime2 数据类型 4, datetimeoffset 数据类型 ...
- Linux多进程编程实例
前言:编写多进程程序时,我们应该了解一下,创建一个子进程时,操作系统内核是怎样做的.当通过fork函数创建新的子进程时,内核将父进程的用户地址空间的内容复制给子进程,这样父子进程拥有各自独立的用户空间 ...
- 自己动手写http服务器——处理http连接(二)
关于http报文格式请看这篇文章 //http_conn.h #ifndef HTTPCONNECTION_H #define HTTPCONNECTION_H #include <unistd ...
- 解决failed to push some refs to git
Administrator@PC-20150110FGWU /K/cocos2d/yc (master) $ git push -u origin master To git@github.com:y ...
- Solr集群搭建详细教程(一)
一.Solr集群的系统架构 注:欢迎大家转载,非商业用途请在醒目位置注明本文链接和作者名dijia478,商业用途请联系本人dijia478@163.com. SolrCloud(solr 云)是So ...
- NHibernate3剖析:Configuration篇之SessionFactory lambda配置
概览 在NHibernate3.0中.SessionFactory的Properties和Cache配置实现了流配置(fluent-configuration)和lambda表达式配置(lambda- ...
- 18、Cocos2dx 3.0游戏开发找小三之cocos2d-x,请问你是怎么调度的咩
重开发人员的劳动成果,转载的时候请务必注明出处:http://blog.csdn.net/haomengzhu/article/details/30478251 Cocos2d 的一大特色就是提供了事 ...
- .NET Core RSA 签名和验签(密钥为 16 进制编码)
使用 OpenSSL 生成公私钥对,命令: $ openssl genrsa -out rsa_1024_priv.pem $ openssl pkcs8 -topk8 -inform PEM -in ...
- ASP.NET Core 指定环境发布(hosting environment)
ASP.NET Core 应用程序发布命令: dotnet publish [<PROJECT>] [-f|--framework] [-r|--runtime] [-o|--output ...
- plsql本机不安装数据库连接远程数据库
用PL/SQL连接oracle数据库,不管是本地的还是远程的,一般都需要安装oracle客户端 如何达到不安装oracle客户端,又能使用PL/SQL工具? 1. oracle官网提供了i ...