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