管理员
   
论坛积分
分
威望 点
贡献值 个
金币 枚
|
- **php.ini文件添加:extension=php_redis.dll 重启php, phpinfo可以看到redis则证明安装成功**
复制代码 php连接redis测试- <?php
3 \& a/ [, B; w T7 s' U - $redis = new Redis();
, w# ^% o. D1 L# ^ - $redis->connect('127.0.0.1', 6379);//serverip port6 ]; F8 X/ i. b. ]
- $redis->auth('mypassword');//my redis password
9 a, X0 V5 {: o1 ` - $redis ->set( "test" , "Hello World");
. ]' @; H5 X8 |6 H$ a0 e - echo $redis ->get( "test");
5 V' ?3 H2 Z6 I8 g, ~
复制代码 php操作redis函数封装- /**1 d: B5 n- s9 N4 ]+ Q& c3 ~/ o
- * 如果不传入$host和$port默认读取Laravel环境变量的参数* C" F& p. I! K' \& Y
- * redis Set/setex封装,可直接传入数组,可设置过期时间 written:yangxingyi
F+ [- M3 F4 T* E( u - */, y; p: ^* m U$ W9 } p6 z* I
- function RedisSet($key,$value,$expire=0,$host='',$port=''){! N% ?4 B; v T9 ^4 t8 }
- if(!$key||!$value) return false;5 n) m9 x# A( ]+ ]8 S6 Y V
- $host = $host?$host:getenv('REDIS_HOST');
% F6 m* O4 P: T, X - $port = $port?$port:getenv('REDIS_PORT');" }" |: ~ H# ]" U1 u
- $redis = new Redis();
0 K4 f; F5 n6 y h+ U - $redis->connect($host, $port);* z3 k5 {1 B! A! C$ L
- $value = is_array($value)?json_encode($value):$value;5 b4 }% s, n: p7 o. x( r
- return $expire>0?$redis->setex(getenv('REDIS_PREFIX').$key, $expire,$value):$redis->set(getenv('REDIS_PREFIX').$key,$value);
% t) U7 b; T0 t5 F7 |: ` - }: ^ t7 ^" I" S5 n {6 ^. v( z9 Y
- /**4 E; K" m/ D% D5 r x$ T! ]
- * redis get封装,如果传入的是数组,返回的也是数组,同理字符串 written:yangxingyi
' W b' s" q* h! b+ v, N2 p - */$ Y3 P3 Q# W' P6 O3 b* X
- function RedisGet($key,$host='',$port=''){9 s& K2 V1 U ?- Q1 ]' T# |
- $redis = new Redis();2 c- a4 c( j- `. w" T' G
- $host = $host?$host:getenv('REDIS_HOST');$ l# E* h9 y% ^
- $port = $port?$port:getenv('REDIS_PORT');' ]8 {- _# T; x/ K. _
- $redis->connect($host, $port);* ~) Q" L/ | ] i6 H- \, U- Q" R
- $result = $redis->get(getenv('REDIS_PREFIX').$key);
7 O/ K& _8 Q& c0 t1 e - return is_null(json_decode($result))?$result:json_decode($result,true);
3 |8 M- c4 Y5 }% B - }
; Z; y; o3 x. B7 J# T/ j0 F7 z" y( {
复制代码 php操作redis大全,基本上php操作redis常用的函数都在下面了5 {2 ^) L& X6 S, P
- setex 带生存时间的写入值1 e; z- Y M% O3 [7 Y5 h! Y; V
- $redis->setex('key', 3600, 'value'); 6 F$ w7 o; ]" T7 C" b8 D b
- setnx 判断是否重复的,写入值,如存在了不修改返回0,不存在就添加返回1
, ]4 a9 V- C& w - $redis->setnx('key', 'value'); @" _0 W$ r2 x- i
- 返回已经删除key0 i/ ^8 s4 T# q( X0 B
- $redis->delete('key1'); 成功返回1失败返回0
: b4 [$ ^7 _1 p - $redis->delete('key1','key2'); 删除两个键成功返回1失败返回0
& n% L3 X, E6 ]. \: { }2 H( Y - 查询生存时间' }$ X" A5 f4 |
- $redis->ttl('key1'); 持久化的返回-1,有生存时间的返回时间(单位秒); Y& ?5 N' E5 Y7 b
- 同时给多个key赋值,同时设置key0和key1
5 D9 k' Q6 q2 A8 B5 I - $redis->mset(array('key0' => 'value0', 'key1' => 'value1'));
" H* d' }' h; W - key中的值进行自增1,如果填写了第二个参数,者自增第二个参数所填的值* [9 w# o8 T# x' q8 Y
- $redis->incr('key1');
$ Z; _; z& P4 o/ [, p. f: m - $redis->incrBy('key1', 10);1 B2 [# }0 m; L( V% z: s/ M
- 减法跟加法一样
- f- W7 R+ y0 d; M - $redis->decr("key1"); 减少1! _# o. G' X5 R& \7 }: {
- $redis->decrBy("key1",5) 减少5
$ S& E3 |& F% h# O! c3 A+ Q3 u- z7 Y - H4 o H# p1 d" K7 L
- list相关操作,连表操作9 M6 h1 x9 d: k! x" Q/ r1 O! A
- lPush* L, V( N' |$ _; f" u7 U8 o
- $redis->lPush("list", "888");6 {# B/ S0 g1 I5 B7 ]3 E
- $id = $redis->lpush('list','HHHHHHH');echo $id;返回链表的元素个数/ X0 p( S, A- X4 ]! e1 K2 Y$ v
- $redi->lrange('list',0,-1); 返回全部数据,数组形式: C0 a& O2 K+ i
- $redis->lrange('list',0.2); 返回连表0-2坐标的三个元素
: m% m% G4 D! Q3 n - lPushx/rPushx
) A ?: `$ q3 V/ E9 e - $redis->lPushx(key, value);. e+ {) ~* a& Y4 |6 `
- 在名称为key的list左边(头)/右边(尾)添加一个值为value的元素,如果value已经存在,则不添加
V% }. z ]6 x' z& d! c7 v - $ C' R: V: s; W# N9 U
- $redis->lpop('list');输出链表最左边的ksy的值,输出后删除掉这个key7 b$ \0 k( X' D/ a N6 z
- $redis->rpop('list');输出链表最右边的ksy的值,输出后删除掉这个key
1 B/ g& Y8 Z* d- ~! i - $redis->lset('list',7,"update"); 修改坐标为7的值,成功返回19 z- a% l9 f r1 J$ f1 J
- 集合:sadd,sadd是无序的集合,每次插入集合的时候都可能会弄乱里面集合的排序
& e1 x! _1 ]/ |) p - sadd s1 zhangsan
9 @9 {9 h4 v$ b7 I& G* B" L - sadd s1 lisi
4 V, Z8 T b$ j - sadd s1 wangwu
2 w3 D0 J2 ]3 m* O# E2 m5 \ - sadd t1 yangxingyi9 w" M1 q3 F9 k* G5 M; ^1 q
- sadd t1 lilei* n7 k, X1 a2 G3 B6 q7 o. G' b
- sadd t1 zhangsan
; c! |3 @. o0 Z( B( V* `% { - smembers s1 s1的所有集合内容
3 M% \ Q$ b# W9 \7 z9 _, U% B* ] - sdiff s1 t1 s1有的,t1没有的,差集
" h$ N$ [/ z5 Z q3 w - $redis->sinter('s1','t1');返回s1和t1两个集合都有的,数组形式
& f9 C$ C! E) o5 | - scard s1 返回s1集合里面的个数,有多少个就返回多少个,没有从0开始的,坐标才从0开始的9 ? I3 L2 w7 r
- spop抽奖场景,返回集合里面随机的数
, D. {+ T' f- S' U6 p% S - spop s1 默认返回1个,返回后就删除这个数,中奖了就不能再中了
" V ?# \( m) l# _* E6 T) @ - $i = $redis->spop('s1');var_dump($i); 返回一个数,返回后删除这个数
8 N$ N3 C! G% `, i* T, ~# k. f - $i = $redis->spop('s1',2);var_dump($i);不能返回两个的,提示错误的
^/ v2 q; l2 c0 {5 y - 随机返回集合里面的一个元素,但不删除,重复中奖
8 ]9 D: N$ N. U! ~: ~ - $i = $redis->srandmember('s1');echo $i;. h# f7 n% J, ]6 U p
- sismember s1 zhangsan 查询张三在不在集合里面,在1,不在false
2 k9 q/ @, k2 j( Q5 ?) b' C+ W- { - $i = $redis->sismember('s1','zhangsan2');echo $i;在1,不在false( M; Z" T4 e! p5 O7 T
- ; z& ]' F0 \( V2 b- f$ j/ `6 B' K
- zadd key 2 value 有序集合
+ ~% a7 o/ G+ i2 X* ?# l' J0 }+ u - zadd y1 1 zhangsan;
, ?( @ x- Q8 j; I5 x" y! o - zadd y1 3 lisi;
6 u4 e: M9 v: ?2 p) g4 N - zadd y1 2 wangwu;& G( |4 v) p' x- V% k4 |
- zrange y1 0 -1; 排序就是,根据插入的时候的排序从小到达zhangsan,wangwu,lisi
. p2 r( Q1 y0 m7 t0 @ w/ g$ t# H - $i = $redis->zrange('y1',0,-1);var_dump($i);
5 t2 H5 `) h! e3 s- T) T1 L - 返回数组,键值不是插入时候给的键,是从0开始的新键
+ v) x& E' {& A$ }/ q! \2 n" _( M - zrevrange y1 0 -1; 反转排序,插入的时候键值越高,排序越优先7 c9 S5 S, P! z
- zcard y1 ;获取有序集合里面的个数,有多少个就返回多少个,没有从0开始的,坐标才从0开始的, D( v' b4 z" n3 M2 U
- 无序就scard,有序就zcard,有z没有s
L3 N( F/ i: m& T - sInterStore& u7 F6 o+ g* \3 s+ {
- 求交集并将交集保存到output的集合
( Y! U- b a5 W2 f7 { z% o$ H0 a/ ] - $redis->sInterStore('output', 'key1', 'key2', 'key3')! n" G6 v. B# t1 ^; Q+ J2 c& w+ b
- 1 m* L9 ?6 K0 z: |6 z5 s
- Hash操作7 E: T; S* Z, d( s) Y- b
- hSet' W- v8 w) \4 A" j
- $redis->hSet('h', 'key1', 'hello');- M2 c# q, x3 s+ _" \
- 向名称为h的hash中添加元素key1—>hello
5 }0 `( M) B6 d - 6 t6 @5 b5 V- q
- hGet
8 J5 Z" P3 Q- s2 O3 L) D4 A, U% U - $redis->hGet('h', 'key1');
! Z2 c" i) [! c2 P) P' |% c, k. X - 返回名称为h的hash中key1对应的value(hello)/ Y, A% y0 z4 Y" j
8 T9 ?$ X8 U7 U$ X% l8 ]5 }, q- hLen8 D5 l. J$ ~7 J+ G. c3 z$ K9 r1 q- ]$ v7 e
- $redis->hLen('h');( s; ^$ x( W& v+ ^6 r
- 返回名称为h的hash中元素个数
7 ~& v( x$ b) H# U" T/ l
5 p. k$ i! g; h. T- hDel. Z0 v4 s) w8 F* e D8 \
- $redis->hDel('h', 'key1');
. f/ h6 c' k' d5 N- d% k0 i - 删除名称为h的hash中键为key1的域5 Z" P+ N4 M" h S3 v
$ X+ u1 W7 ]( M: c* c7 j- hKeys
: p. g, Z4 T( ?2 D3 C8 J - $redis->hKeys('h');. w% H$ h' p; E
- 返回名称为key的hash中所有键. c& O* L# o. b: B# n* g
- 7 b9 _5 v3 a/ X5 c, V; n: b
- hVals
4 K p- O2 {, C2 c - $redis->hVals('h')
3 h; z) b5 h( P8 r' p0 b) @ - 返回名称为h的hash中所有键对应的value$ m% ~4 T" X0 m# X7 c1 E
- 6 j, b* q5 a } p
- hGetAll
: h1 M" B n2 B( B6 C5 z - $redis->hGetAll('h');
. i# l, g) o2 h# x7 ^; o - 返回名称为h的hash中所有的键(field)及其对应的value
9 D9 c% n! D; R- V4 V! g - 4 Y7 J* H+ G2 @0 R) v1 m/ v+ p
- hExists
S- b1 J: v# g6 n - $redis->hExists('h', 'a');3 Y: n3 k! k5 t7 {8 J% W' [
- 名称为h的hash中是否存在键名字为a的域
0 D+ M0 Q( x7 K$ }7 r5 y% S3 u4 v
) c- N, k; p1 b- hIncrBy
5 H$ r2 }3 ~+ K% u- i4 I v - $redis->hIncrBy('h', 'x', 2);
7 ?& v+ U" A* h0 P - 将名称为h的hash中x的value增加2
% A3 a* g& g* p - 4 j, K/ f: y x, W0 A
- hMset
" h: L1 r$ J% }) D! F9 }# { - $redis->hMset('user:1', array('name' => 'Joe', 'salary' => 2000));8 ~: p q, ^. m/ V- {
- 向名称为key的hash中批量添加元素3 w8 X6 T7 w7 e
$ G p3 H& ]6 b- hMGet
1 W3 u3 D" T4 F' | - $redis->hmGet('h', array('field1', 'field2'));& Z. s+ B {5 x3 b5 m- X+ Z
- 返回名称为h的hash中field1,field2对应的value0 j3 a- `8 h! ]
|/ h; Q8 p% ^2 m- t5 _- redis 操作相关8 g; h% P$ [4 W: u2 s- n
- flushDB2 M6 q8 R4 D! R4 G
- 清空当前数据库: }3 a# {5 e+ b% s
. ^% B, z- ?2 Z" B2 m/ I( n* U- flushAll5 W+ i) b. ^, v* ~4 u5 M
- 清空所有数据库" t0 d' C/ E% Y& H, e& T
- + n$ Q: @) y" {- w' S8 J) B6 W
- randomKey
7 P. P( ]2 a' m7 h - 随机返回key空间的一个key" `- g" N _, z% t6 e
- $key = $redis->randomKey();/ D4 y1 p: G5 p8 D5 I
( Y1 L) u4 G# B) L+ O/ n- select
$ E" g! U/ `! j7 n" ]/ M4 H/ T - 选择一个数据库& c% O' U% H: z+ {( N4 H1 k: c
- move
$ l! {( _; Z' C* T4 e4 H+ ^ - 转移一个key到另外一个数据库
7 y r& K: L7 R/ D8 B8 ` - $redis->select(0); // switch to DB 0
% T8 B% d! O3 z; g( d - $redis->set('x', '42'); // write 42 to x1 f: H$ L- g' Y$ e# W, s H* O7 G
- $redis->move('x', 1); // move to DB 1
# R, U: o& ?0 @$ }5 X. s" J* S - $redis->select(1); // switch to DB 18 R+ Y" z8 t. w {
- $redis->get('x'); // will return 42/ W b; ]& K" |( m. E0 ~+ [) A
0 A9 ]6 `7 s. D$ M- rename, renameKey
6 p: f T5 X+ u) ^- h - 给key重命名" Y* k5 u: U! }$ d2 A0 b
- $redis->set('x', '42');0 j/ N& o% ^+ F" w5 Z5 X
- $redis->rename('x', 'y');+ {$ r0 ~6 n/ n( F! O- v
- $redis->get('y'); // → 420 s7 t8 s$ p# y4 s3 y6 u1 T
- $redis->get('x'); // → `FALSE`
" D- s! s5 v; q5 S& G: | - ! Y. r( s; ?: Y- a+ n1 e
- renameNx/ @$ X5 X; [9 c
- 与remane类似,但是,如果重新命名的名字已经存在,不会替换成功
+ v+ c9 d$ G- K" ?3 _( l: P% D' w/ J - # G3 i4 v$ z" Y5 e; k# u0 K( D' |
- setTimeout, expire
. i8 k* E" m0 w, a - 设定一个key的活动时间(s)
% G5 q5 Y5 {3 U' C7 v - $redis->setTimeout('x', 3);1 F g) m# l9 l* n3 V
- 8 k% a0 w- ?8 t. {7 D5 t
- expireAt' O2 Q. _+ }+ x. J1 {) K P
- key存活到一个unix时间戳时间
2 _ P0 E8 a& R+ S0 c6 x - $redis->expireAt('x', time() + 3);
: l3 J8 i6 X; v9 g5 W
+ d- o3 B* b: m8 ?* H4 }- keys, getKeys
2 ~5 ?3 ~- D0 j0 J* f6 Q# [ - 返回满足给定pattern的所有key$ K K9 M# r. d" _
- $keyWithUserPrefix = $redis->keys('user*');+ [5 u0 J& p6 l% r, O3 L, [
& x3 |+ m, N* g. C8 F9 m- dbSize4 j) o2 m- D. _, i; m; k
- 查看现在数据库有多少key
, f6 s" a' Q( f8 i: Y - $count = $redis->dbSize();5 u N7 d6 m4 F, ~" [
- , @8 k! X/ a+ \+ k! o+ \& E1 t
- auth
- o' Q/ c6 [* L* ]8 x - 密码认证
( v6 o& N/ ~$ w; F/ w1 H1 B6 C - $redis->auth('foobared');
" d) x* _$ n! y# } - 0 v _. v2 B: I d( U# k) o7 l
- bgrewriteaof, n3 p7 r' Q% G9 @8 q5 z
- 使用aof来进行数据库持久化
" G: j+ b( J! {& |( T - $redis->bgrewriteaof();
+ _; p( J4 ] n0 _1 \6 w J7 |1 m - 7 N' `% M/ N* Q( S! y; H
- slaveof
% X! c& t/ X+ Y- I% H- n: y - 选择从服务器
( p+ u8 c8 V' W- f6 Z3 \- D- W - $redis->slaveof('10.0.1.7', 6379);
6 R, r' x9 @- x1 r; t" G
: |% u, P2 b- O4 S% q- save
. M5 f5 H w- x, v+ t3 S - 将数据同步保存到磁盘
3 Z0 z% c% w3 ?* F3 ^% w
' I! Y/ b3 R# E4 {/ ~- bgsave! ?; U& T# M! V
- 将数据异步保存到磁盘
- d( G! B7 G0 _; P
4 D! ^ Q0 u! \0 N" g+ U2 a1 Z. v- lastSave
& D7 Z6 X, ]/ a - 返回上次成功将数据保存到磁盘的Unix时戳* s$ _4 g$ y" @9 a" K. n
- 4 n I7 D/ X) p) h$ ]! N% x3 o( B
- info
j# {4 R3 c- z# J* o9 Z. H( ?; w N, Y - 返回redis的版本信息等详情
# Y( p. U' k, `+ }& r3 X6 h% y - e% c# v4 j# r& v' }$ F7 W
- Redis::__construct构造函数
% S$ J& C9 H; I0 {# \2 F* ?% a, n) k - $redis = new Redis();. G9 }, S2 B7 O/ }& r: N% s2 t
- ( @# `2 Q6 s; K' F. F6 B
- connect, open 链接redis服务0 [; K, z7 e% u# x0 l
- 参数6 P6 J! J+ {% a3 j0 Z: B7 ?" R/ M
- host: string,服务地址; y2 p' a, W, `! O
- port: int,端口号
) M! s& ?# l' Z3 f2 T - timeout: float,链接时长 (可选, 默认为 0 ,不限链接时间)+ b+ M: B' X. E4 @3 g1 a
- 注: 在redis.conf中也有时间,默认为300
2 I& }, G% ?4 B" c' Q; H$ y$ e( b3 H
/ j) x0 Q- ^- `& m6 L" z- pconnect, popen 不会主动关闭的链接+ n/ A5 X6 o( k/ K/ k' _$ K
- 参考上面% ~! w: D! \6 x8 ?! K
: v% L9 K/ @1 o c2 x# E1 \/ e' \- setOption 设置redis模式& p% z( T1 g. D- Z9 Z
6 C' q7 a9 |9 u% P1 t- getOption 查看redis设置的模式
& o' o- ~7 k. I - * q' i' y& ~* R. L
- ping 查看连接状态
* y1 }$ T0 o4 Y - ( h6 B; [8 Z( a) a8 e
- get 得到某个key的值(string值)
2 i2 u1 |+ I. d/ X - 如果该key不存在,return false" ~+ q) i* U# \% ^2 ~ s: j
- 6 F- z/ |& j5 H- V
- set 写入key 和 value(string值)
( e, U' ~1 L3 m3 t! U - 如果写入成功,return ture
, J$ d8 H: Q3 |' {4 i4 ? - / m3 x. m& o) \5 @; D2 G, D5 f P
- setex 带生存时间的写入值- f, b4 _$ W& {. l
- $redis->setex('key', 3600, 'value'); // sets key → value, with 1h TTL." I2 n+ M1 m; [) W
- ) V; H! \! x+ b& O) g" j; g
- setnx 判断是否重复的,写入值, i7 k1 |' h, U$ f' ]2 { b4 D
- $redis->setnx('key', 'value');/ V, O k) C3 W8 y5 Q. l2 m0 S
- $redis->setnx('key', 'value');
3 d) g: w: Y5 J; h& X9 |8 C - / \, R# q" V1 N5 R* S
- delete 删除指定key的值
* K1 h& K2 D L - 返回已经删除key的个数(长整数)3 g5 g z# e4 s0 T
- $redis->delete('key1', 'key2');/ p3 w1 N( P2 E& p* d2 f0 N: D
- $redis->delete(array('key3', 'key4', 'key5'));" x5 o- g. o+ t! e; c+ O
( }: `6 t/ t! d- ttl
. A4 @7 z$ H; | - 得到一个key的生存时间
1 Q( E7 o3 C8 X* s0 W" c' f2 S8 p4 Q - 3 V0 K; \7 K. b6 J& W8 }/ {
- persist
. R8 {- L# N+ A% O - 移除生存时间到期的key1 u0 h: p$ v* S$ p! {1 \
- 如果key到期 true 如果不到期 false
% X+ ]% y. v" u* N; g& `! t B6 f* N - / d/ ]6 Y# g- a
- mset (redis版本1.1以上才可以用). N- V7 `; e A( S+ e2 @+ e, e; Z. G
- 同时给多个key赋值8 f6 `+ H d ]
- $redis->mset(array('key0' => 'value0', 'key1' => 'value1'));
$ `) W' s/ `8 j/ \$ @' H; ~ - ; |1 \0 f2 R y
- ( z6 G7 [$ M0 C: n7 m
- * \8 a) N& x2 \$ `2 S! O
- multi, exec, discard8 `9 }2 t$ ^/ V3 @
- 进入或者退出事务模式
3 O' ?/ z6 V4 i; t - 参数可选Redis::MULTI或Redis::PIPELINE. 默认是 Redis::MULTI' W4 V: K. V& x( Z
- Redis::MULTI:将多个操作当成一个事务执行
4 M' e; |8 H' m, l - Redis::PIPELINE:让(多条)执行命令简单的,更加快速的发送给服务器,但是没有任何原子性的保证1 c; j6 b# B6 d8 x4 G: n2 i0 {2 O
- discard:删除一个事务
a& l7 U% b) U1 ~, `/ S! K! ? - 返回值
L/ R( S8 t* m! u - multi(),返回一个redis对象,并进入multi-mode模式,一旦进入multi-mode模式,以后调用的所有方法都会返回相同的对象,只到exec()方法被调用。
. a0 A% I2 B a6 a; b3 X8 ~( j5 z
! s6 H# L, i$ X" G- watch, unwatch (代码测试后,不能达到所说的效果)
+ A4 d$ h3 `2 c" b. a; ` - 监测一个key的值是否被其它的程序更改。如果这个key在watch 和 exec (方法)间被修改,这个 MULTI/EXEC 事务的执行将失败(return false)
+ L2 e! {- x D - unwatch 取消被这个程序监测的所有key- _- L H; d& P5 D/ H" V5 q
- 参数,一对key的列表
& x9 c6 l7 }& l1 K! Q5 j1 G1 }: U6 P - $redis->watch('x');
" N) |7 C& `; G5 h3 `
- p [; _8 x. [( M- $ret = $redis->multi() ->incr('x') ->exec();
5 u4 l! c! ?9 \9 q2 D. Y+ Z
3 l9 b* [ L2 u% i/ A# b
7 d7 V1 ]6 n# ?- subscribe *
; }! @% p6 F- u1 Y0 }7 s& M - 方法回调。注意,该方法可能在未来里发生改变+ {" l, J- o. h7 h" I) P* A; [' _2 o, P
- p" h3 m/ \7 f: L/ b5 ~
- publish *
4 w( n) w! L7 \3 _: |% P - 发表内容到某一个通道。注意,该方法可能在未来里发生改变
2 W3 \% h8 F0 Z) B - - E2 s& z/ d0 j/ x& ]
- exists
6 ` d" y- R/ Y# S2 w - 判断key是否存在。存在 true 不在 false
4 \- C: R( E4 D3 j. h( G& U
+ y2 Q& T0 _! H- incr, incrBy/ K+ e1 ]( h( J8 n7 z
- key中的值进行自增1,如果填写了第二个参数,者自增第二个参数所填的值
( N1 U% C- l' _9 ^. b v9 O - $redis->incr('key1');1 c! F- k, v0 v6 v& j& r& _
- $redis->incrBy('key1', 10);3 C# s) d0 S8 @0 ~% @$ g+ n
- # ^/ x, h- x8 w, E
- decr, decrBy9 J3 ]& C7 A- |' D9 K4 a
- 做减法,使用方法同incr' r7 X4 ?" X1 ]2 }6 W
0 } F! S1 d7 Y4 @* O- getMultiple2 S* u" Q6 t+ d/ H
- 传参
2 d* ?* c: G7 t - 由key组成的数组, V* v$ C" \1 d$ f* E
- 返回参数) X$ ^: t. _ Y: B+ E8 [/ p
- 如果key存在返回value,不存在返回false+ s8 G' T+ u* X) Q( j
- $redis->set('key1', 'value1'); $redis->set('key2', 'value2'); $redis->set('key3', 'value3'); $redis->getMultiple(array('key1', 'key2', 'key3'));# B2 O( a# K6 J/ }- H* M0 b
- $redis->lRem('key1', 'A', 2);) Q, R; I% F+ T9 u U, s" k) W
- $redis->lRange('key1', 0, -1);
; ~, U! g2 H# z, E
9 P* |! X/ k3 \) V- P0 q8 B- list相关操作
# ~# q% b5 A4 d" U - lPush# s1 T% @- f) Y7 H4 |1 A
- $redis->lPush(key, value);
6 m5 R4 r. Z4 \" ?6 } - 在名称为key的list左边(头)添加一个值为value的 元素
; `: t* ^ ~2 j, n3 M - + D; E) V$ k1 O/ Z7 U
- rPush
7 N. `7 l& N4 @ - $redis->rPush(key, value);9 k; x: W+ A N' {
- 在名称为key的list右边(尾)添加一个值为value的 元素! L- Q( `" d& s2 i$ V7 m
- 6 |/ m+ A" ^9 y6 _& |& F7 d
- lPushx/rPushx3 i: T1 R) o9 O
- $redis->lPushx(key, value);
/ A- q* k7 F+ G0 ^- n3 p - 在名称为key的list左边(头)/右边(尾)添加一个值为value的元素,如果value已经存在,则不添加" v/ {+ z8 j. [, w3 z6 N8 D
f, a9 i8 P" d) I- lPop/rPop
$ M! A3 N) |- L' ^4 g7 j - $redis->lPop('key');
" m g6 J' b) P! c- J' @ - 输出名称为key的list左(头)起/右(尾)起的第一个元素,删除该元素3 \0 ^/ D+ Z" @; [6 y! ?& q& s% d
- 1 {# ]5 E9 {6 A* }
- blPop/brPop. B7 h1 |& Z7 l7 ]! K
- $redis->blPop('key1', 'key2', 10);
! ?; u! g& M8 j- m - lpop命令的block版本。即当timeout为0时,若遇到名称为key i的list不存在或该list为空,则命令结束。如果timeout>0,则遇到上述情况时,等待timeout秒,如果问题没有解决,则对keyi+1开始的list执行pop操作6 A- @6 b- x: f) I. W6 j. m% `
- # P- X$ H' k/ v3 E
- lSize7 j$ i3 R8 e# b6 \$ V* x
- $redis->lSize('key');
% ]& h- i7 F T- y( V, F! P/ O - 返回名称为key的list有多少个元素0 q0 V8 |% C) F$ U/ p6 n/ p+ L
% L4 e' e$ a8 o, P* ^1 G- lIndex, lGet7 ]! y3 T* N3 P) [- X2 v+ s
- $redis->lGet('key', 0);
! N7 @+ n5 k' ?" W7 k4 [) K - 返回名称为key的list中index位置的元素
) c" t1 ]+ ?: v7 q - 8 e( c6 h- o, D. v W/ Z+ d
- lSet
7 d0 _& P9 E0 W; N2 h, c( g - $redis->lSet('key', 0, 'X');
1 f) w2 P; J, ?! u1 i- a - 给名称为key的list中index位置的元素赋值为value
9 O7 G0 P W5 P0 V" p - 3 s8 x* p) E) }. `5 I4 p" i
- lRange, lGetRange
1 C) b/ x9 l; ]4 ~" w$ f - $redis->lRange('key1', 0, -1);7 F5 ?. ?3 s [7 g$ `
- 返回名称为key的list中start至end之间的元素(end为 -1 ,返回所有)
! u* e2 c4 \; @: m
2 L, S- H& ~0 ]4 K6 ~6 V, O- lTrim, listTrim
: @. J# p6 o! K/ V - $redis->lTrim('key', start, end);
/ x! D' p. R3 f& w$ v% b - 截取名称为key的list,保留start至end之间的元素
5 P' v' X C9 Z# E2 n8 y) g
( x' ^! ~* c+ R* B3 M- lRem, lRemove
4 m* } r4 P& g3 c# d( j, _ - $redis->lRem('key', 'A', 2);4 x9 a( Q/ F3 L# y
- 删除count个名称为key的list中值为value的元素。count为0,删除所有值为value的元素,count>0从头至尾删除count个值为value的元素,count<0从尾到头删除|count|个值为value的元素
& M- ^* Z W( @- T3 b: c" d - , W9 q# z8 b! g3 i: H, J" T9 R% C
- lInsert
d. p& H2 d' B9 b7 a - 在名称为为key的list中,找到值为pivot 的value,并根据参数Redis::BEFORE | Redis::AFTER,来确定,newvalue 是放在 pivot 的前面,或者后面。如果key不存在,不会插入,如果 pivot不存在,return -1& N6 z9 S- t. ]* b% B$ a
- $redis->delete('key1'); $redis->lInsert('key1', Redis::AFTER, 'A', 'X'); $redis->lPush('key1', 'A'); $redis->lPush('key1', 'B'); $redis->lPush('key1', 'C'); $redis->lInsert('key1', Redis::BEFORE, 'C', 'X');' V/ T% r l8 M+ D* j1 }
- $redis->lRange('key1', 0, -1);
" I2 B# i8 s/ \ - $redis->lInsert('key1', Redis::AFTER, 'C', 'Y');* P& T$ [8 ? B: l, t5 T
- $redis->lRange('key1', 0, -1);
4 _8 R( M9 Q ~9 x, s8 {6 E - $redis->lInsert('key1', Redis::AFTER, 'W', 'value');9 H9 U/ ?5 `; Q, N/ U0 j+ q
+ B, n q! k4 K7 w p% d& i- rpoplpush
; _# e5 _! |+ K5 F0 F# e, b! U7 ] - 返回并删除名称为srckey的list的尾元素,并将该元素添加到名称为dstkey的list的头部0 m) H( \- j8 _( E9 j# Z4 _5 s
- $redis->delete('x', 'y');/ H, u6 m( }# Z
- $redis->lPush('x', 'abc'); $redis->lPush('x', 'def'); $redis->lPush('y', '123'); $redis->lPush('y', '456'); // move the last of x to the front of y. var_dump($redis->rpoplpush('x', 'y'));
+ v5 @# T* r4 Q" v! Z+ E: w - var_dump($redis->lRange('x', 0, -1));
' A4 v* T P( z6 E4 Y - var_dump($redis->lRange('y', 0, -1));
9 j5 E+ O. y2 A+ Y - , o: I- Y; ~; _
- string(3) "abc" / ?0 s! `" K5 U1 h& |
- array(1) { [0]=> string(3) "def" }
# P0 @2 D' ^+ q9 i$ j - array(3) { [0]=> string(3) "abc" [1]=> string(3) "456" [2]=> string(3) "123" }) N( W5 ?" S' C( y* f( Q/ _1 {
- 3 Y/ l" x# x7 Z. }: i1 B4 L
- SET操作相关8 u3 L9 u' `# v& b3 A
- sAdd0 R8 P$ b3 y0 q2 T) s! k" V
- 向名称为key的set中添加元素value,如果value存在,不写入,return false
; _6 `0 B& J7 s- z6 }9 B - $redis->sAdd(key , value);
: l) k& i. r! X$ |1 ? - ; x9 l# F9 Q# ]6 }; z
- sRem, sRemove
+ } j% x0 D7 z+ x/ d0 M - 删除名称为key的set中的元素value$ A1 [4 S! O6 O: f
- $redis->sAdd('key1' , 'set1');; P; E% W2 i+ u3 T* W" Z- L5 D ~: H
- $redis->sAdd('key1' , 'set2');) W# o1 ~5 u- W( E' c% n
- $redis->sAdd('key1' , 'set3');& D$ Q) Q7 c$ B6 O1 f
- $redis->sRem('key1', 'set2');
6 P. ?* R! S9 }- }8 @: ^9 D( g
& H* f& v, Y/ B- sMove
+ c: i: y! n( R3 r0 J: X - 将value元素从名称为srckey的集合移到名称为dstkey的集合
6 x! D2 m3 X. t1 m) { - $redis->sMove(seckey, dstkey, value);* B) R0 y! }; g; S
- 9 M) c; k! Y1 P+ u( i0 |
- sIsMember, sContains ?/ S" t( X7 V, u
- 名称为key的集合中查找是否有value元素,有ture 没有 false( j, `: H" w$ m1 ]
- $redis->sIsMember(key, value);7 Z4 j- i! c( X# P3 O
- * I5 l, [3 d7 j. ^( `/ Q! p4 u
- sCard, sSize
z- D) K k) J% `4 q - 返回名称为key的set的元素个数
" k( Y4 J# x+ l9 T4 ~ - " W( v3 |3 ~5 k' H
- sPop
- J4 o2 _; _* x$ L9 I3 W - 随机返回并删除名称为key的set中一个元素
, o. o6 E6 u! \4 a - . i5 N: a9 q# p3 t
- sRandMember% [" T; z# W3 z l
- 随机返回名称为key的set中一个元素,不删除
3 k( r' i5 X1 `# ^" [
$ E% ^! u0 \+ v3 O$ H( W+ H- sInter2 E& K+ f( T/ Z( f4 L6 ~
- 求交集# X/ H" N" y* |7 [* L5 L& b' v
8 Z6 o& K; g+ Z/ X9 v* e V K- sInterStore
1 h3 ]" ~5 d; d0 O" |, \3 ~- { - 求交集并将交集保存到output的集合1 ]$ D( \6 R4 I; [0 M1 N8 H/ W2 w
- $redis->sInterStore('output', 'key1', 'key2', 'key3')8 A$ x+ a3 s, L6 S" _" \
- ' ~0 E2 E! i; h+ x* y* T2 C/ b
- sUnion. p, q/ F3 s, o. \; m8 A! E! r
- 求并集$ V2 D" { ^8 [: n& x6 h1 ~
- $redis->sUnion('s0', 's1', 's2');
7 z4 `2 @; J+ b; r" ]8 W0 S - s0,s1,s2 同时求并集1 s s4 q. L, a2 }) \
/ b/ B, S% Q0 w" \5 n) v3 ?- sUnionStore
, S( B O) `$ x% W - 求并集并将并集保存到output的集合
9 Q. a, |% ]8 S; t# q - $redis->sUnionStore('output', 'key1', 'key2', 'key3');
& _, Z6 g( h# {9 B2 N# |4 u - ! B3 R: f6 |0 t: x) z
- sDiff4 x/ G0 A: d* y- Q) T& r
- 求差集
' j" N0 X! t8 v0 [( Z - . _$ i6 h# p' [, k# S
- sDiffStore
, d6 M7 T6 t; x4 B# T - 求差集并将差集保存到output的集合8 J, a3 E/ \9 V1 t9 y, Y
2 y4 z! z4 y( x: U1 i- sMembers, sGetMembers
0 D+ Q. e5 k8 C. M - 返回名称为key的set的所有元素
- v" P' Q2 P! S; Y1 `- b/ F7 | - 1 _1 A+ g7 W3 I0 b
- sort1 T. }! J3 d; \3 S& {% ~
- 排序,分页等6 b r! `4 p" T" w; p
- 参数
1 U1 F3 \, S# x# b& j - 'by' => 'some_pattern_*',
1 C1 q" Z* q8 e" {' L- J2 C3 [ - 'limit' => array(0, 1),2 ^$ k9 K9 s0 p" g7 y' `
- 'get' => 'some_other_pattern_*' or an array of patterns,' w: E/ y% }/ A
- 'sort' => 'asc' or 'desc',* O& \% y4 Q$ k! o7 B: w
- 'alpha' => TRUE,
9 Y0 M8 s; p9 o" g( s& v- } - 'store' => 'external-key'
: [3 c. S$ e% H- ? - 例子7 T; C. r2 I( {. N8 Z! l
- $redis->delete('s'); $redis->sadd('s', 5); $redis->sadd('s', 4); $redis->sadd('s', 2); $redis->sadd('s', 1); $redis->sadd('s', 3);
( R: j& q7 u! x+ h: f - var_dump($redis->sort('s')); // 1,2,3,4,52 v' S1 D8 i3 c5 B$ ?
- var_dump($redis->sort('s', array('sort' => 'desc'))); // 5,4,3,2,1# I) x* j7 Z0 L( u' C
- var_dump($redis->sort('s', array('sort' => 'desc', 'store' => 'out'))); // (int)5# u, a& @0 A& a6 o2 D" @7 @
-
* g( s0 L/ U7 Z+ o$ `- j F, h - string命令
3 `; c4 |( g4 d5 v4 N/ A6 f; H - getSet
% q" G3 r7 e! K2 t" T9 Y2 r/ T- g - 返回原来key中的值,并将value写入key9 d7 i+ Y8 B N/ _
- $redis->set('x', '42');4 N) N; z1 b8 e' |) M7 W' `; X
- $exValue = $redis->getSet('x', 'lol'); // return '42', replaces x by 'lol'
1 Q X. k# x( E( D- g - $newValue = $redis->get('x')' // return 'lol'
8 }' \) g: z6 Q8 g1 v! E
" ^2 h1 I: L6 O- append. o, Z- Z1 f% _: X( M
- string,名称为key的string的值在后面加上value
A. Y! \; i$ v9 y1 G; g3 l5 ^ - $redis->set('key', 'value1');. n7 k5 v! X; v6 G, X% f
- $redis->append('key', 'value2');2 i. R+ d0 I% \' A/ Z
- $redis->get('key');
% V/ z9 }0 d4 A, ^6 s - ( N) {! W/ u/ `6 P
- getRange (方法不存在)
0 W; [" V$ }' H; A - 返回名称为key的string中start至end之间的字符
) L' |9 b9 \% i - $redis->set('key', 'string value');
; ~% H& q5 Z; J- B4 K6 x - $redis->getRange('key', 0, 5); q( R0 o e, U# d
- $redis->getRange('key', -5, -1);/ t6 q5 ?" B! |# i# m
1 m$ d( `# T# q+ H. }1 m* `- setRange (方法不存在)3 w4 S6 l& j, f
- 改变key的string中start至end之间的字符为value
. ]' ?8 ~, n' B& m2 G. u - $redis->set('key', 'Hello world');8 E- \. r7 |; V# a; b
- $redis->setRange('key', 6, "redis");
8 o F; i* S5 R5 g2 ` - $redis->get('key');
8 Q% x$ e/ S: L$ u - * @# G C' e- \) b. @0 H" Y' g# P
- strlen. B; s/ z& @2 n5 Q& T4 j
- 得到key的string的长度1 I8 P. p# n- R5 w2 y/ n
- $redis->strlen('key');, P) r% B% p5 d$ P9 F/ g2 o& f
- $ Q6 O& {. g! |
- getBit/setBit* h* f! C' ^9 N k g+ F. A o+ G
- 返回2进制信息
. r( e; U: a( n
% j+ w% ]: \% O% b" k- zset(sorted set)操作相关
+ _, W8 F: A' l9 ?. o$ Y - zAdd(key, score, member):向名称为key的zset中添加元素member,score用于排序。如果该元素已经存在,则根据score更新该元素的顺序。
2 ~, t3 k8 z, a6 V. G6 L9 | - $redis->zAdd('key', 1, 'val1');6 @# P" k" s, e* t. i
- $redis->zAdd('key', 0, 'val0');
5 \3 l$ _1 F; G0 i! m - $redis->zAdd('key', 5, 'val5');0 P% D( T8 d) j" p
- $redis->zRange('key', 0, -1); // array(val0, val1, val5)) d' Z+ ?4 G+ U, |- O4 n
- - f2 u7 W* A* w9 r7 x( v
- zRange(key, start, end,withscores):返回名称为key的zset(元素已按score从小到大排序)中的index从start到end的所有元素
) y$ g' R) k/ s - $redis->zAdd('key1', 0, 'val0');! ~9 a/ Q3 Y- C0 D. B4 u' e
- $redis->zAdd('key1', 2, 'val2');1 R* u R0 I2 g, B6 m
- $redis->zAdd('key1', 10, 'val10');* E, v% e, ^% o4 c, R# I: D5 L3 v
- $redis->zRange('key1', 0, -1); // with scores $redis->zRange('key1', 0, -1, true);, k1 z. _5 K Y6 {& F* K
$ v; e- _# V1 E3 l- zDelete, zRem# M6 p4 V4 u' w' i: J& R
- zRem(key, member) :删除名称为key的zset中的元素member# R }# q( e1 y, V& h$ L2 M9 C
- $redis->zAdd('key', 0, 'val0');
8 Y# ]/ h4 o& u - $redis->zAdd('key', 2, 'val2');' O3 R, {# |. {& d2 Y5 n# U4 t
- $redis->zAdd('key', 10, 'val10');+ e% G7 J$ I0 k/ M; l6 @; V9 x0 j9 O
- $redis->zDelete('key', 'val2');
) E1 V& V3 f K6 K - $redis->zRange('key', 0, -1);
' ?3 w# Z5 O+ l, z/ M - 9 ]$ I6 e' a6 B% S( f7 K8 @- K
- zRevRange(key, start, end,withscores):返回名称为key的zset(元素已按score从大到小排序)中的index从start到end的所有元素.withscores: 是否输出socre的值,默认false,不输出% E# l. y" Q6 k* K! D9 O. R
- $redis->zAdd('key', 0, 'val0');1 n# ? { R* {4 f
- $redis->zAdd('key', 2, 'val2');
1 A( t+ b* n& K; `0 c+ G; G - $redis->zAdd('key', 10, 'val10');
) j; Z6 l6 i2 x& y6 P8 H - $redis->zRevRange('key', 0, -1); // with scores $redis->zRevRange('key', 0, -1, true);, G3 w& V; l M4 Z: R0 T1 n
- ! k2 U- V: ]2 b4 p) x& g
- zRangeByScore, zRevRangeByScore
+ Y& W# X. @0 H/ v - $redis->zRangeByScore(key, star, end, array(withscores, limit ));
8 s0 x' ^3 z" D. n0 i6 m - 返回名称为key的zset中score >= star且score <= end的所有元素
, G9 C" j" b6 U+ i7 I - * [; N5 X9 ?. B5 x& ^
- zCount
5 r: n2 u! o1 f0 t - $redis->zCount(key, star, end);
; @4 N7 l' ^( z* a - 返回名称为key的zset中score >= star且score <= end的所有元素的个数
/ C" i& O2 j' ~( m4 f P' X - , b: K: X6 p+ d
- zRemRangeByScore, zDeleteRangeByScore
5 e* T' d; u& j8 Q( y( i: C1 G - $redis->zRemRangeByScore('key', star, end);
& v- {7 H3 p. g0 h4 k7 ` - 删除名称为key的zset中score >= star且score <= end的所有元素,返回删除个数
; U3 n* d! \0 v" r# ^ - 0 ^# t8 ?9 c6 w% K; @
- zSize, zCard
8 j/ j4 Q2 `" D2 @7 W% q3 t( t - 返回名称为key的zset的所有元素的个数6 o- z1 p/ G* O' F; }8 d
- * g5 G* R7 B& j
- zScore
: \& A: h* N3 N1 Q1 E7 G3 `4 ^ - $redis->zScore(key, val2);3 g5 s' T/ W9 M" D8 |/ W* C; D
- 返回名称为key的zset中元素val2的score3 P' o2 C0 }0 g m, D# A
- + \. ?7 H; M ~0 y( w( w
- zRank, zRevRank
$ \$ z% f0 ?# y# R' u9 D! o& Z" ` - $redis->zRevRank(key, val);8 R2 Y/ q+ Y$ H: W
- 返回名称为key的zset(元素已按score从小到大排序)中val元素的rank(即index,从0开始),若没有val元素,返回“null”。zRevRank 是从大到小排序
; n8 Z9 f" a& l9 G3 N. c. M0 R9 I
: y e+ D5 n$ K* P; d# n- zIncrBy' v$ E& H+ O6 p4 v0 k
- $redis->zIncrBy('key', increment, 'member');
7 [: q: X/ Z# c# f+ a* b - 如果在名称为key的zset中已经存在元素member,则该元素的score增加increment;否则向集合中添加该元素,其score的值为increment. [! r4 a9 m, {1 P2 y2 e! U
' j, b4 L0 s, C# b3 H4 ]5 k- zUnion/zInter. ~) E% j0 Z1 W. ]
- 参数0 {" P1 I: ]0 k; }
- keyOutput% O7 j0 T# e6 u0 X" ^
- arrayZSetKeys5 P1 ?/ N) K$ c) g1 R6 X" Y- a
- arrayWeights* F( @: r! b6 [+ Y# Y+ T
- aggregateFunction Either "SUM", "MIN", or "MAX": defines the behaviour to use on duplicate entries during the zUnion.# B; V$ q7 r1 x4 n7 O' t$ M8 _
- 对N个zset求并集和交集,并将最后的集合保存在dstkeyN中。对于集合中每一个元素的score,在进行AGGREGATE运算前,都要乘以对于的WEIGHT参数。如果没有提供WEIGHT,默认为1。默认的AGGREGATE是SUM,即结果集合中元素的score是所有集合对应元素进行SUM运算的值,而MIN和MAX是指,结果集合中元素的score是所有集合对应元素中最小值和最大值。
7 Z5 _; A& q9 \( H' V
复制代码
; F/ z: X# x2 c0 _% n- G4 ~" R
1 m* k; i$ f- P6 S: r. d& I0 A1 K* ^! j, L3 i
3 q$ U y* P6 C5 T |
|