1 phpredis是php的一個擴展,效率是相當高有鏈表排序功能,對創建內存級的模塊業務關系 2 3 很有用;以下是redis官方提供的命令使用技巧: 4 5 下載地址如下: 6 7 https://github.com/owlient/phpredis(支持redis 2.0.4) 8 9 10 Redis::__construct構造函數 11 $redis = new Redis(); 12 13 connect, open 鏈接redis服務 14 參數 15 host: string,服務地址 16 port: int,端口號 17 timeout: float,鏈接時長 (可選, 默認為 0 ,不限鏈接時間) 18 注: 在redis.conf中也有時間,默認為300 19 20 pconnect, popen 不會主動關閉的鏈接 21 參考上面 22 23 setOption 設置redis模式 24 25 getOption 查看redis設置的模式 26 27 ping 查看連接狀態 28 29 get 得到某個key的值(string值) 30 如果該key不存在,return false 31 32 set 寫入key 和 value(string值) 33 如果寫入成功,return ture 34 35 setex 帶生存時間的寫入值 36 $redis->setex('key', 3600, 'value'); // sets key → value, with 1h TTL. 37 38 setnx 判斷是否重復的,寫入值 39 $redis->setnx('key', 'value'); 40 $redis->setnx('key', 'value'); 41 42 delete 刪除指定key的值 43 返回已經刪除key的個數(長整數) 44 $redis->delete('key1', 'key2'); 45 $redis->delete(array('key3', 'key4', 'key5')); 46 47 ttl 48 得到一個key的生存時間 49 50 persist 51 移除生存時間到期的key 52 如果key到期 true 如果不到期 false 53 54 mset (redis版本1.1以上才可以用) 55 同時給多個key賦值 56 $redis->mset(array('key0' => 'value0', 'key1' => 'value1')); 57 58 59 60 multi, exec, discard 61 進入或者退出事務模式 62 參數可選Redis::MULTI或Redis::PIPELINE. 默認是 Redis::MULTI 63 Redis::MULTI:將多個操作當成一個事務執行 64 Redis::PIPELINE:讓(多條)執行命令簡單的,更加快速的發送給服務器,但是沒有任何原子性的保證 65 discard:刪除一個事務 66 返回值 67 multi(),返回一個redis對象,並進入multi-mode模式,一旦進入multi-mode模式,以后調用的所有方法都會返回相同的對象,只到exec()方法被調用。 68 69 watch, unwatch (代碼測試后,不能達到所說的效果) 70 監測一個key的值是否被其它的程序更改。如果這個key在watch 和 exec (方法)間被修改,這個 MULTI/EXEC 事務的執行將失敗(return false) 71 unwatch 取消被這個程序監測的所有key 72 參數,一對key的列表 73 $redis->watch('x'); 74 75 $ret = $redis->multi() ->incr('x') ->exec(); 76 77 78 subscribe * 79 方法回調。注意,該方法可能在未來里發生改變 80 81 publish * 82 發表內容到某一個通道。注意,該方法可能在未來里發生改變 83 84 exists 85 判斷key是否存在。存在 true 不在 false 86 87 incr, incrBy 88 key中的值進行自增1,如果填寫了第二個參數,者自增第二個參數所填的值 89 $redis->incr('key1'); 90 $redis->incrBy('key1', 10); 91 92 decr, decrBy 93 做減法,使用方法同incr 94 95 getMultiple 96 傳參 97 由key組成的數組 98 返回參數 99 如果key存在返回value,不存在返回false 100 $redis->set('key1', 'value1'); $redis->set('key2', 'value2'); $redis->set('key3', 'value3'); $redis->getMultiple(array('key1', 'key2', 'key3')); 101 $redis->lRem('key1', 'A', 2); 102 $redis->lRange('key1', 0, -1); 103 104 list相關操作 105 lPush 106 $redis->lPush(key, value); 107 在名稱為key的list左邊(頭)添加一個值為value的 元素 108 109 rPush 110 $redis->rPush(key, value); 111 在名稱為key的list右邊(尾)添加一個值為value的 元素 112 113 lPushx/rPushx 114 $redis->lPushx(key, value); 115 在名稱為key的list左邊(頭)/右邊(尾)添加一個值為value的元素,如果value已經存在,則不添加 116 117 lPop/rPop 118 $redis->lPop('key'); 119 輸出名稱為key的list左(頭)起/右(尾)起的第一個元素,刪除該元素 120 121 blPop/brPop 122 $redis->blPop('key1', 'key2', 10); 123 lpop命令的block版本。即當timeout為0時,若遇到名稱為key i的list不存在或該list為空,則命令結束。如果timeout>0,則遇到上述情況時,等待timeout秒,如果問題沒有解決,則對keyi+1開始的list執行pop操作 124 125 lSize 126 $redis->lSize('key'); 127 返回名稱為key的list有多少個元素 128 129 lIndex, lGet 130 $redis->lGet('key', 0); 131 返回名稱為key的list中index位置的元素 132 133 lSet 134 $redis->lSet('key', 0, 'X'); 135 給名稱為key的list中index位置的元素賦值為value 136 137 lRange, lGetRange 138 $redis->lRange('key1', 0, -1); 139 返回名稱為key的list中start至end之間的元素(end為 -1 ,返回所有) 140 141 lTrim, listTrim 142 $redis->lTrim('key', start, end); 143 截取名稱為key的list,保留start至end之間的元素 144 145 lRem, lRemove 146 $redis->lRem('key', 'A', 2); 147 刪除count個名稱為key的list中值為value的元素。count為0,刪除所有值為value的元素,count>0從頭至尾刪除count個值為value的元素,count<0從尾到頭刪除|count|個值為value的元素 148 149 lInsert 150 在名稱為為key的list中,找到值為pivot 的value,並根據參數Redis::BEFORE | Redis::AFTER,來確定,newvalue 是放在 pivot 的前面,或者后面。如果key不存在,不會插入,如果 pivot不存在,return -1 151 $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'); 152 $redis->lRange('key1', 0, -1); 153 $redis->lInsert('key1', Redis::AFTER, 'C', 'Y'); 154 $redis->lRange('key1', 0, -1); 155 $redis->lInsert('key1', Redis::AFTER, 'W', 'value'); 156 157 rpoplpush 158 返回並刪除名稱為srckey的list的尾元素,並將該元素添加到名稱為dstkey的list的頭部 159 $redis->delete('x', 'y'); 160 $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')); 161 var_dump($redis->lRange('x', 0, -1)); 162 var_dump($redis->lRange('y', 0, -1)); 163 164 string(3) "abc" 165 array(1) { [0]=> string(3) "def" } 166 array(3) { [0]=> string(3) "abc" [1]=> string(3) "456" [2]=> string(3) "123" } 167 168 SET操作相關 169 sAdd 170 向名稱為key的set中添加元素value,如果value存在,不寫入,return false 171 $redis->sAdd(key , value); 172 173 sRem, sRemove 174 刪除名稱為key的set中的元素value 175 $redis->sAdd('key1' , 'set1'); 176 $redis->sAdd('key1' , 'set2'); 177 $redis->sAdd('key1' , 'set3'); 178 $redis->sRem('key1', 'set2'); 179 180 sMove 181 將value元素從名稱為srckey的集合移到名稱為dstkey的集合 182 $redis->sMove(seckey, dstkey, value); 183 184 sIsMember, sContains 185 名稱為key的集合中查找是否有value元素,有ture 沒有 false 186 $redis->sIsMember(key, value); 187 188 sCard, sSize 189 返回名稱為key的set的元素個數 190 191 sPop 192 隨機返回並刪除名稱為key的set中一個元素 193 194 sRandMember 195 隨機返回名稱為key的set中一個元素,不刪除 196 197 sInter 198 求交集 199 200 sInterStore 201 求交集並將交集保存到output的集合 202 $redis->sInterStore('output', 'key1', 'key2', 'key3') 203 204 sUnion 205 求並集 206 $redis->sUnion('s0', 's1', 's2'); 207 s0,s1,s2 同時求並集 208 209 sUnionStore 210 求並集並將並集保存到output的集合 211 $redis->sUnionStore('output', 'key1', 'key2', 'key3'); 212 213 sDiff 214 求差集 215 216 sDiffStore 217 求差集並將差集保存到output的集合 218 219 sMembers, sGetMembers 220 返回名稱為key的set的所有元素 221 222 sort 223 排序,分頁等 224 參數 225 'by' => 'some_pattern_*', 226 'limit' => array(0, 1), 227 'get' => 'some_other_pattern_*' or an array of patterns, 228 'sort' => 'asc' or 'desc', 229 'alpha' => TRUE, 230 'store' => 'external-key' 231 例子 232 $redis->delete('s'); $redis->sadd('s', 5); $redis->sadd('s', 4); $redis->sadd('s', 2); $redis->sadd('s', 1); $redis->sadd('s', 3); 233 var_dump($redis->sort('s')); // 1,2,3,4,5 234 var_dump($redis->sort('s', array('sort' => 'desc'))); // 5,4,3,2,1 235 var_dump($redis->sort('s', array('sort' => 'desc', 'store' => 'out'))); // (int)5 236 237 string命令 238 getSet 239 返回原來key中的值,並將value寫入key 240 $redis->set('x', '42'); 241 $exValue = $redis->getSet('x', 'lol'); // return '42', replaces x by 'lol' 242 $newValue = $redis->get('x')' // return 'lol' 243 244 append 245 string,名稱為key的string的值在后面加上value 246 $redis->set('key', 'value1'); 247 $redis->append('key', 'value2'); 248 $redis->get('key'); 249 250 getRange (方法不存在) 251 返回名稱為key的string中start至end之間的字符 252 $redis->set('key', 'string value'); 253 $redis->getRange('key', 0, 5); 254 $redis->getRange('key', -5, -1); 255 256 setRange (方法不存在) 257 改變key的string中start至end之間的字符為value 258 $redis->set('key', 'Hello world'); 259 $redis->setRange('key', 6, "redis"); 260 $redis->get('key'); 261 262 strlen 263 得到key的string的長度 264 $redis->strlen('key'); 265 266 getBit/setBit 267 返回2進制信息 268 269 zset(sorted set)操作相關 270 zAdd(key, score, member):向名稱為key的zset中添加元素member,score用於排序。如果該元素已經存在,則根據score更新該元素的順序。 271 $redis->zAdd('key', 1, 'val1'); 272 $redis->zAdd('key', 0, 'val0'); 273 $redis->zAdd('key', 5, 'val5'); 274 $redis->zRange('key', 0, -1); // array(val0, val1, val5) 275 276 zRange(key, start, end,withscores):返回名稱為key的zset(元素已按score從小到大排序)中的index從start到end的所有元素 277 $redis->zAdd('key1', 0, 'val0'); 278 $redis->zAdd('key1', 2, 'val2'); 279 $redis->zAdd('key1', 10, 'val10'); 280 $redis->zRange('key1', 0, -1); // with scores $redis->zRange('key1', 0, -1, true); 281 282 zDelete, zRem 283 zRem(key, member) :刪除名稱為key的zset中的元素member 284 $redis->zAdd('key', 0, 'val0'); 285 $redis->zAdd('key', 2, 'val2'); 286 $redis->zAdd('key', 10, 'val10'); 287 $redis->zDelete('key', 'val2'); 288 $redis->zRange('key', 0, -1); 289 290 zRevRange(key, start, end,withscores):返回名稱為key的zset(元素已按score從大到小排序)中的index從start到end的所有元素.withscores: 是否輸出socre的值,默認false,不輸出 291 $redis->zAdd('key', 0, 'val0'); 292 $redis->zAdd('key', 2, 'val2'); 293 $redis->zAdd('key', 10, 'val10'); 294 $redis->zRevRange('key', 0, -1); // with scores $redis->zRevRange('key', 0, -1, true); 295 296 zRangeByScore, zRevRangeByScore 297 $redis->zRangeByScore(key, star, end, array(withscores, limit )); 298 返回名稱為key的zset中score >= star且score <= end的所有元素 299 300 zCount 301 $redis->zCount(key, star, end); 302 返回名稱為key的zset中score >= star且score <= end的所有元素的個數 303 304 zRemRangeByScore, zDeleteRangeByScore 305 $redis->zRemRangeByScore('key', star, end); 306 刪除名稱為key的zset中score >= star且score <= end的所有元素,返回刪除個數 307 308 zSize, zCard 309 返回名稱為key的zset的所有元素的個數 310 311 zScore 312 $redis->zScore(key, val2); 313 返回名稱為key的zset中元素val2的score 314 315 zRank, zRevRank 316 $redis->zRevRank(key, val); 317 返回名稱為key的zset(元素已按score從小到大排序)中val元素的rank(即index,從0開始),若沒有val元素,返回“null”。zRevRank 是從大到小排序 318 319 zIncrBy 320 $redis->zIncrBy('key', increment, 'member'); 321 如果在名稱為key的zset中已經存在元素member,則該元素的score增加increment;否則向集合中添加該元素,其score的值為increment 322 323 zUnion/zInter 324 參數 325 keyOutput 326 arrayZSetKeys 327 arrayWeights 328 aggregateFunction Either "SUM", "MIN", or "MAX": defines the behaviour to use on duplicate entries during the zUnion. 329 對N個zset求並集和交集,並將最后的集合保存在dstkeyN中。對於集合中每一個元素的score,在進行AGGREGATE運算前,都要乘以對於的WEIGHT參數。如果沒有提供WEIGHT,默認為1。默認的AGGREGATE是SUM,即結果集合中元素的score是所有集合對應元素進行SUM運算的值,而MIN和MAX是指,結果集合中元素的score是所有集合對應元素中最小值和最大值。 330 331 Hash操作 332 hSet 333 $redis->hSet('h', 'key1', 'hello'); 334 向名稱為h的hash中添加元素key1—>hello 335 336 hGet 337 $redis->hGet('h', 'key1'); 338 返回名稱為h的hash中key1對應的value(hello) 339 340 hLen 341 $redis->hLen('h'); 342 返回名稱為h的hash中元素個數 343 344 hDel 345 $redis->hDel('h', 'key1'); 346 刪除名稱為h的hash中鍵為key1的域 347 348 hKeys 349 $redis->hKeys('h'); 350 返回名稱為key的hash中所有鍵 351 352 hVals 353 $redis->hVals('h') 354 返回名稱為h的hash中所有鍵對應的value 355 356 hGetAll 357 $redis->hGetAll('h'); 358 返回名稱為h的hash中所有的鍵(field)及其對應的value 359 360 hExists 361 $redis->hExists('h', 'a'); 362 名稱為h的hash中是否存在鍵名字為a的域 363 364 hIncrBy 365 $redis->hIncrBy('h', 'x', 2); 366 將名稱為h的hash中x的value增加2 367 368 hMset 369 $redis->hMset('user:1', array('name' => 'Joe', 'salary' => 2000)); 370 向名稱為key的hash中批量添加元素 371 372 hMGet 373 $redis->hmGet('h', array('field1', 'field2')); 374 返回名稱為h的hash中field1,field2對應的value 375 376 redis 操作相關 377 flushDB 378 清空當前數據庫 379 380 flushAll 381 清空所有數據庫 382 383 randomKey 384 隨機返回key空間的一個key 385 $key = $redis->randomKey(); 386 387 select 388 選擇一個數據庫 389 move 390 轉移一個key到另外一個數據庫 391 $redis->select(0); // switch to DB 0 392 $redis->set('x', '42'); // write 42 to x 393 $redis->move('x', 1); // move to DB 1 394 $redis->select(1); // switch to DB 1 395 $redis->get('x'); // will return 42 396 397 rename, renameKey 398 給key重命名 399 $redis->set('x', '42'); 400 $redis->rename('x', 'y'); 401 $redis->get('y'); // → 42 402 $redis->get('x'); // → `FALSE` 403 404 renameNx 405 與remane類似,但是,如果重新命名的名字已經存在,不會替換成功 406 407 setTimeout, expire 408 設定一個key的活動時間(s) 409 $redis->setTimeout('x', 3); 410 411 expireAt 412 key存活到一個unix時間戳時間 413 $redis->expireAt('x', time() + 3); 414 415 keys, getKeys 416 返回滿足給定pattern的所有key 417 $keyWithUserPrefix = $redis->keys('user*'); 418 419 dbSize 420 查看現在數據庫有多少key 421 $count = $redis->dbSize(); 422 423 auth 424 密碼認證 425 $redis->auth('foobared'); 426 427 bgrewriteaof 428 使用aof來進行數據庫持久化 429 $redis->bgrewriteaof(); 430 431 slaveof 432 選擇從服務器 433 $redis->slaveof('10.0.1.7', 6379); 434 435 save 436 將數據同步保存到磁盤 437 438 bgsave 439 將數據異步保存到磁盤 440 441 lastSave 442 返回上次成功將數據保存到磁盤的Unix時戳 443 444 info 445 返回redis的版本信息等詳情 446 447 type 448 返回key的類型值 449 string: Redis::REDIS_STRING 450 set: Redis::REDIS_SET 451 list: Redis::REDIS_LIST 452 zset: Redis::REDIS_ZSET 453 hash: Redis::REDIS_HASH 454 other: Redis::REDIS_NOT_FOUND