Redis配置和常用命令

  1. redis.conf配置文件:  
  2. 引用  
  3. #是否作爲守護進程運行  
  4. daemonize yes  
  5. #配置pid的存放路徑及文件名,默認爲當前路徑下  
  6. pidfile redis.pid  
  7. #Redis默認監聽端口  
  8. port 6379  
  9. #客戶端閒置多少秒後,斷開連接  
  10. timeout 300  
  11. #日誌顯示級別  
  12. loglevel verbose  
  13. #指定日誌輸出的文件名,也可指定到標準輸出端口  
  14. logfile stdout  
  15. #設置數據庫的數量,默認連接的數據庫是0,可以通過select N來連接不同的數據庫  
  16. databases 16  
  17. #保存數據到disk的策略  
  18. #當有一條Keys數據被改變是,900秒刷新到disk一次  
  19. save 900 1  
  20. #當有10條Keys數據被改變時,300秒刷新到disk一次  
  21. save 300 10  
  22. #當有1w條keys數據被改變時,60秒刷新到disk一次  
  23. save 60 10000  
  24. #當dump  .rdb數據庫的時候是否壓縮數據對象  
  25. rdbcompression yes  
  26. #dump數據庫的數據保存的文件名  
  27. dbfilename dump.rdb  
  28. #Redis的工作目錄  
  29. dir /home/falcon/redis-2.0.0/  
  30. ###########  Replication #####################  
  31. #Redis的複製配置  
  32. # slaveof <masterip> <masterport>  
  33. # masterauth <master-password>  
  34.   
  35. ############## SECURITY ###########  
  36. # requirepass foobared  
  37.   
  38. ############### LIMITS ##############  
  39. #最大客戶端連接數  
  40. # maxclients 128  
  41. #最大內存使用率  
  42. # maxmemory <bytes>  
  43.   
  44. ########## APPEND ONLY MODE #########  
  45. #是否開啓日誌功能  
  46. appendonly no  
  47. # 刷新日誌到disk的規則  
  48. # appendfsync always  
  49. appendfsync everysec  
  50. # appendfsync no  
  51. ################ VIRTUAL MEMORY ###########  
  52. #是否開啓VM功能  
  53. vm-enabled no  
  54. # vm-enabled yes  
  55. vm-swap-file logs/redis.swap  
  56. vm-max-memory 0  
  57. vm-page-size 32  
  58. vm-pages 134217728  
  59. vm-max-threads 4  
  60. ############# ADVANCED CONFIG ###############  
  61. glueoutputbuf yes  
  62. hash-max-zipmap-entries 64  
  63. hash-max-zipmap-value 512  
  64. #是否重置Hash表  
  65. activerehashing yes  
[plain] view plaincopy
  1. 常規操作命令  
  2.    
  3. 01  exits key              //測試指定key是否存在,返回1表示存在,0不存在  
  4. 02  del key1 key2 ....keyN //刪除給定key,返回刪除key的數目,0表示給定key都不存在  
  5. 03  type key               //返回給定key的value類型。返回 none 表示不存在key,string字符類型,list 鏈表類型 set 無序集合類型...  
  6. 04  keys pattern           //返回匹配指定模式的所有key,下面給個例子  
  7. 05  randomkey              //返回從當前數據庫中隨機選擇的一個key,如果當前數據庫是空的,返回空串  
  8. 06  rename oldkey newkey   //原子的重命名一個key,如果newkey存在,將會被覆蓋,返回1表示成功,0失敗。可能是oldkey不存在或者和newkey相同  
  9. 07  renamenx oldkey newkey //同上,但是如果newkey存在返回失敗  
  10. 08  dbsize                 //返回當前數據庫的key數量  
  11. 09  expire key seconds     //爲key指定過期時間,單位是秒。返回1成功,0表示key已經設置過過期時間或者不存在  
  12. 10  ttl key                //返回設置過過期時間的key的剩餘過期秒數 -1表示key不存在或者沒有設置過過期時間  
  13. 11  select db-index        //通過索引選擇數據庫,默認連接的數據庫所有是0,默認數據庫數是16個。返回1表示成功,0失敗  
  14. 12  move key db-index      //將key從當前數據庫移動到指定數據庫。返回1成功。0 如果key不存在,或者已經在指定數據庫中  
  15. 13  flushdb                //刪除當前數據庫中所有key,此方法不會失敗。慎用  
  16. 14  flushall               //刪除所有數據庫中的所有key,此方法不會失敗。更加慎用  
  17. string 類型數據操作命令  
  18.    
  19. 01  set key value         //設置key對應的值爲string類型的value,返回1表示成功,0失敗  
  20. 02  setnx key value       //同上,如果key已經存在,返回0 。nx 是not exist的意思  
  21. 03  get key               //獲取key對應的string值,如果key不存在返回nil  
  22. 04  getset key value      //原子的設置key的值,並返回key的舊值。如果key不存在返回nil  
  23. 05  mget key1 key2 ... keyN            //一次獲取多個key的值,如果對應key不存在,則對應返回nil。下面是個實驗,首先清空當前數據庫,然後設置k1,k2.獲取時k3對應返回nil  
  24. 06  mset key1 value1 ... keyN valueN   //一次設置多個key的值,成功返回1表示所有的值都設置了,失敗返回0表示沒有任何值被設置  
  25. 07  msetnx key1 value1 ... keyN valueN //同上,但是不會覆蓋已經存在的key  
  26. 08  incr key              //對key的值做加加操作,並返回新的值。注意incr一個不是int的value會返回錯誤,incr一個不存在的key,則設置key爲1  
  27. 09  decr key              //同上,但是做的是減減操作,decr一個不存在key,則設置key爲-1  
  28. 10  incrby key integer    //同incr,加指定值 ,key不存在時候會設置key,並認爲原來的value是 0  
  29. 11  decrby key integer    //同decr,減指定值。decrby完全是爲了可讀性,我們完全可以通過incrby一個負值來實現同樣效果,反之一樣。  
  30. 12  append key value      //給指定key的字符串值追加value,返回新字符串值的長度。下面給個例子  
  31. 13  substr key start end  //返回截取過的key的字符串值,注意並不修改key的值。下標是從0開始的,接着上面例子  
  32. list 類型數據操作命令  
  33.    
  34. 01  lpush key string          //在key對應list的頭部添加字符串元素,返回1表示成功,0表示key存在且不是list類型  
  35. 02  rpush key string          //同上,在尾部添加  
  36. 03  llen key                  //返回key對應list的長度,key不存在返回0,如果key對應類型不是list返回錯誤  
  37. 04  lrange key start end      //返回指定區間內的元素,下標從0開始,負值表示從後面計算,-1表示倒數第一個元素 ,key不存在返回空列表  
  38. 05  ltrim key start end       //截取list,保留指定區間內元素,成功返回1,key不存在返回錯誤  
  39. 06  lset key index value      //設置list中指定下標的元素值,成功返回1,key或者下標不存在返回錯誤  
  40. 07  lrem key count value      //從key對應list中刪除count個和value相同的元素。count爲0時候刪除全部  
  41. 08  lpop key                  //從list的頭部刪除元素,並返回刪除元素。如果key對應list不存在或者是空返回nil,如果key對應值不是list返回錯誤  
  42. 09  rpop                      //同上,但是從尾部刪除  
  43. 10  blpop key1...keyN timeout //從左到右掃描返回對第一個非空list進行lpop操作並返回,比如blpop list1 list2 list3 0 ,如果list不存在list2,list3都是非空則對list2做lpop並返回從list2中刪除的元素。如果所有的list都是空或不存在,則會阻塞timeout秒,timeout爲0表示一直阻塞。當阻塞時,如果有client對key1...keyN中的任意key進行push操作,則第一在這個key上被阻塞的client會立即返回。如果超時發生,則返回nil。有點像unix的select或者poll  
  44. 11  brpop                     //同blpop,一個是從頭部刪除一個是從尾部刪除  
  45. 12  rpoplpush srckey destkey  //從srckey對應list的尾部移除元素並添加到destkey對應list的頭部,最後返回被移除的元素值,整個操作是原子的.如果srckey是空或者不存在返回nil  
  46. set 類型數據操作命令  
  47.    
  48. 01  sadd key member                //添加一個string元素到,key對應的set集合中,成功返回1,如果元素以及在集合中返回0,key對應的set不存在返回錯誤  
  49. 02  srem key member                //從key對應set中移除給定元素,成功返回1,如果member在集合中不存在或者key不存在返回0,如果key對應的不是set類型的值返回錯誤  
  50. 03  spop key                       //刪除並返回key對應set中隨機的一個元素,如果set是空或者key不存在返回nil  
  51. 04  srandmember key                //同spop,隨機取set中的一個元素,但是不刪除元素  
  52. 05  smove srckey dstkey member     //從srckey對應set中移除member並添加到dstkey對應set中,整個操作是原子的。成功返回1,如果member在srckey中不存在返回0,如果key不是set類型返回錯誤  
  53. 06  scard key                      //返回set的元素個數,如果set是空或者key不存在返回0  
  54. 07  sismember key member           //判斷member是否在set中,存在返回1,0表示不存在或者key不存在  
  55. 08  sinter key1 key2...keyN        //返回所有給定key的交集  
  56. 09  sinterstore dstkey key1...keyN //同sinter,但是會同時將交集存到dstkey下  
  57. 10  sunion key1 key2...keyN        //返回所有給定key的並集  
  58. 11  sunionstore dstkey key1...keyN //同sunion,並同時保存並集到dstkey下  
  59. 12  sdiff key1 key2...keyN         //返回所有給定key的差集  
  60. 13  sdiffstore dstkey key1...keyN  //同sdiff,並同時保存差集到dstkey下  
  61. 14  smembers key                   //返回key對應set的所有元素,結果是無序的  
  62. sorted set 類型數據操作命令  
  63.    
  64. 01  zadd key score member        //添加元素到集合,元素在集合中存在則更新對應score  
  65. 02  zrem key member              //刪除指定元素,1表示成功,如果元素不存在返回0  
  66. 03  zincrby key incr member      //增加對應member的score值,然後移動元素並保持skip list保持有序。返回更新後的score值  
  67. 04  zrank key member             //返回指定元素在集合中的排名(下標),集合中元素是按score從小到大排序的  
  68. 05  zrevrank key member          //同上,但是集合中元素是按score從大到小排序  
  69. 06  zrange key start end         //類似lrange操作從集合中去指定區間的元素。返回的是有序結果  
  70. 07  zrevrange key start end      //同上,返回結果是按score逆序的  
  71. 08  zrangebyscore key min max    //返回集合中score在給定區間的元素  
  72. 09  zcount key min max           //返回集合中score在給定區間的數量  
  73. 10  zcard key                    //返回集合中元素個數  
  74. 11  zscore key element           //返回給定元素對應的score  
  75. 12  zremrangebyrank key min max  //刪除集合中排名在給定區間的元素  
  76. 13  zremrangebyscore key min max //刪除集合中score在給定區間的元素  
  77. hash 類型數據操作命令  
  78.    
  79. 01  hset key field value       //設置hash field爲指定值,如果key不存在,則先創建  
  80. 02  hget key field             //獲取指定的hash field  
  81. 03  hmget key filed1....fieldN //獲取全部指定的hash filed  
  82. 04  hmset key filed1 value1 ... filedN valueN //同時設置hash的多個field  
  83. 05  hincrby key field integer  //將指定的hash filed 加上給定值  
  84. 06  hexists key field          //測試指定field是否存在  
  85. 07  hdel key field             //刪除指定的hash field  
  86. 08  hlen key                   //返回指定hash的field數量  
  87. 09  hkeys key                  //返回hash的所有field  
  88. 10  hvals key                  //返回hash的所有value  
  89. 11  hgetall                    //返回hash的所有filed和value  

存值:
./redis-cli set hx value
取值:

./redis-cli get hx

獲取redis中所有緩存的key

keys *
$14
blueprint_id:6

或使用正則比配Key

keys question*

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章