Redis

redis 相關(guān)的可執(zhí)行文件

  • redis-server Redis服務(wù)器

  • redis-cli Redis客戶端

  • redis-benchmark Redis 性能測試工具

  • redis-check-aof AOF文件修復(fù)工具

  • redis-check-dump RDB文件檢查工具


redis 啟動關(guān)閉等操作

  • 直接啟動
    redis-server --port 6379 // 默認(rèn)使用 6379 端口
    redis-server /etc/redis/redis.conf // 指定配置文件

  • 通過初始化腳本啟動
    在Redis源碼包的utils文件中有 redis_init_script 初始化腳本文件
    我們需要配置redis的運行方式,持久化文件,日志文件的存儲位置等
    通過一下步驟使redis隨系統(tǒng)啟動:
    > sudo cp utils/redis_init_script /etc/init.d/redis_6379
    > sudo mkdir /etc/redis # 存放redis的配置文件
    > sudo mkdir /var/redis/6379 # 存放redis的持久化文件
    修改配置文件:
    port = 6379 # 監(jiān)聽的端口號
    daemonize yes # 以守護(hù)進(jìn)程模式運行
    dir /var/redis/6379 # 設(shè)置持久化文件存儲位置
    pidfile /var/run/redis_6379.pid

  > sudo cp redis.conf /etc/redis/6379.conf
  > sudo update-rc.d redis_6379 defaults     # 使redis隨系統(tǒng)自動啟動
  • 停止redis
    redis-cli SHUTDOWN
  • redis-cli 客戶端

    redis-cli -h 127.0.0.1 -p 6379
    redis-cli ping    # 測試連接是否正常
    redis-cli --raw    # 可以防止中文顯示亂碼
    

一個redis實例支持多個數(shù)據(jù)庫,默認(rèn)是16個。但每個數(shù)據(jù)庫并不是完全隔離,例如FLUSHDB可以清空一個redis實例的所有數(shù)據(jù)庫。因此不用的應(yīng)用的數(shù)據(jù)應(yīng)該存儲在不同的redis實例中。

redis 鍵名最佳實踐, 對象類型:對象ID:對象屬性, 多單詞推薦用逗號分隔
例如 user:1:friends


redis命令

利用命令批量刪除key
> redis-cli KEYS "doctor:*" | xargs redis-cli DEL

系統(tǒng)級

DBSIZE # 獲取鍵的數(shù)量
KEYS pattern # 獲取符合規(guī)則的鍵名, pattern支持glob風(fēng)格通配符格式:

?  匹配一個字符
*  匹配任意個字符
[]  匹配括號內(nèi)的任意字符,可以使用 - 表示范圍
\x  匹配x, 用于轉(zhuǎn)義

CONFIG GET XXXX # 獲取當(dāng)前的配置值
SELECT n # 更換數(shù)據(jù)庫,默認(rèn)支持16個數(shù)據(jù)庫, 默認(rèn)是數(shù)據(jù)庫0
EXISTS key # 判斷一個鍵是否存在
DEL key [key ...] # 刪除鍵
TYPE key # 獲取鍵值的數(shù)據(jù)類型

字符串

SET key value
GET key
INCR key
DECR key

如何獲得自增的ID: 對于每一類對象使用名為  對象類型(復(fù)數(shù)形式):count (例如 users:count ) 的鍵來存儲當(dāng)前對象的數(shù)量

INCRBY key increment # 增加指定的整數(shù)
DECRBY key decrement
INCRBYFLOAT key increment # 增加指定的浮點數(shù)
APPEND key value # 向鍵值的末尾追加 value, 若不存在則等同SET
STRLEN key # 獲取字符串長度 (以utf-8編碼時,一個中文長度是3)
MGET key [key ...]
MSET key value [key value ......]

位操作

GETBIT key offset
SETBIT key offset value
BITCOUNT key [start] [end] # 獲得字節(jié)范圍內(nèi)值是1的二進(jìn)制個數(shù)
BITOP operation destkey key [key ...] # 位運算,包括 AND, OR, XOR, NOT

散列值

鍵, 字段, 字段值
HSET key field value
HGET key field
HMSET key field value [field value ......]
HMGET key field [field ......]
HGETALL key
HEXISTS key field # 判斷一個字段是否存在
HSETNX key field value # 當(dāng)字段不存在時,才執(zhí)行賦值操作
HINCRBY key field increment
HDEL key field [field ......]
HKEYS key # 只獲取字段名
HVALS key # 只獲取字段值
HLEN key # 獲取字段數(shù)量

列表

插入刪除非???,通過索引訪問元素比較慢
LPUSH key value [value ......]
RPUSH key value [value ......]
LPOP key
RPOP key
LLEN key
LRANGE key start stop # 獲取列表片段,包含兩端的元素,支持負(fù)索引
LREM key count value # 刪除指定的值

1> 當(dāng)count>0, 從列表左邊開始刪除前count個值為value的元素
2> 當(dāng)count<0, 從列表右邊開始刪除前|count|個值為value的元素
3> 當(dāng)count=0, 刪除所有值為value的元素

LINDEX key index # 獲取指定索引的元素值
LSET key index value # 設(shè)置指定索引的元素值
LTRIM key start end # 只保留列表指定片段
LINSERT key BEFORE|AFTER pivot value # 向列表中指定元素的前/后插入元素
RPOPLPUSH source destination # 將元素從一個列表轉(zhuǎn)移到另一個列表

集合

無序,唯一
SADD key member [member ......]
SREM key member [member ......]
SMEMBERS key # 獲得集合中的所有元素
SISMEMBER key member # 判斷是否是集合中的元素
SDIFF key [key ....] # 差集運算
SINTER key [key ...] # 交集運算
SUNION key [key ...] # 并集運算
SDIFFSTORE destination key [key ....] # 差集運算并存儲結(jié)果
SINTERSTORE destination key [key ...] # 交集運算并存儲結(jié)果
SUNIONSTORE destination key [key ...] # 并集運算并存儲結(jié)果
SCARD key # 獲取集合中的元素個數(shù)
SRANDMEMBER key [count] # 隨機(jī)獲取集合中的元素

  count>0 獲取count個不重復(fù)的元素, count<0 獲取count個可能重復(fù)的元素

SPOP key # 從集合中彈出一個元素

有序集合

有序,唯一,讀取中間部分速度也很快
ZADD key score member [score member ....] # 加入一個元素和該元素的分?jǐn)?shù)
ZSCORE key member # 獲取元素的分?jǐn)?shù)
ZRANGE key start stop [WITHSCORES] # 獲取排名在指定范圍內(nèi)的元素列表,從小到大
ZREVRANGE key start stop [WITHSCORES] # 逆序
ZRANGEBYSCORE key min max [WITHSCORES] [LIMIT offset count] # 獲得指定分?jǐn)?shù)范圍的元素,從小到大,包含兩端。若在分?jǐn)?shù)前加‘(’表示不包括端點。offset 和 count 類似SQL中的用法,即在結(jié)果集的基礎(chǔ)上向后偏移offset并只取前count個元素

ZREVRANGEBYSCORE key max min [WITHSCORES] [LIMIT offset count] # 逆序
ZINCRBY key increment member # 增加某個元素的分?jǐn)?shù), 增量可以為負(fù)數(shù),表示減去
ZCARD key # 獲取集合中的元素數(shù)量
ZCOUNT key min max # 獲取指定分?jǐn)?shù)范圍內(nèi)的元素個數(shù)
ZREM key member [member ......]
ZREMRANGEBYRANK key start stop # 按照排名范圍刪除元素,從小到大
ZREMRANGEBYSCORE key start stop # 按照分?jǐn)?shù)范圍刪除元素,從小到大
ZRANK key member # 獲得元素排名, 從小到大
ZREVRANK key member

ZINTERSTORE destination numkeys key [key ...] [WEIGHTS weight [weight ...]] [AGREGATE SUM|MIN|MAX] # 計算多個有序集合的交集并存儲結(jié)果,destination中的分?jǐn)?shù)由AGREGATE參數(shù)決定。當(dāng)是SUM(默認(rèn)值),分?jǐn)?shù)為每個參與計算的集合中該元素分?jǐn)?shù)的總和;當(dāng)是MIN,分?jǐn)?shù)是每個參與計算的集合中該元素分?jǐn)?shù)的最小值;當(dāng)是MAX,則是最大值。WEIGHTS為每個參與計算的集合的分?jǐn)?shù)權(quán)重,計算時分?jǐn)?shù)會乘上該集合的權(quán)重。

ZUNIONSTORE 同上類似


事務(wù)

MULTI
若干命令
EXEC

事務(wù)中的錯誤處理:
1> 若出現(xiàn)語法錯誤,則事務(wù)中的所有命令都不會執(zhí)行
2> 若出現(xiàn)運行時錯誤,其他命令依然會執(zhí)行

WATCH / UNWATCH 命令
WATCH 命令監(jiān)控一個或多個鍵,一旦其中有一個鍵被修改或刪除,之后的事務(wù)就不會執(zhí)行。監(jiān)控一直持續(xù)到EXEC命令, 執(zhí)行EXEC命令會取消對所有鍵的監(jiān)控,也可以使用 UNWATCH 命令取消監(jiān)控

EXPIRE key seconds # 為鍵設(shè)置生存時間
TTL key # 獲取鍵的生存時間, 返回-1表示永久存在, -2 表示不存在這個鍵
PERSIST key # 取消鍵的生存時間,即設(shè)置為永久,SET/GETSET 為鍵賦值也會取消生存時間
PEXPIRE key microseconds # 同EXPIRE,區(qū)別在于單位是毫秒
PTTL key

注: 如果WATCH一個有生存時間的鍵,當(dāng)這個鍵過期被刪除時,并不會被WATCH命令認(rèn)為該鍵發(fā)生了改變


排序

  • SORT key [ALPHA] [DESC] [LIMIT offset count]
  • SORT key BY somekey[->somefiled] [DESC] [LIMIT offset count] GET somekey[->somefield] STORE new-key

配置文件

  • maxmemory 最大可使用內(nèi)存大小,單位字節(jié)。當(dāng)超出限制時會根據(jù) maxmemory-policy 參數(shù)指定的策略來刪除不需要的鍵。

  • maxmemory-policy 支持 volatile-lru, allkeys-lru, volatile-random, allkeys-random, volatile-ttl, noeviction

  • maxmemory-samples 當(dāng)內(nèi)存不足時,每次刪除的鍵的數(shù)量


Redis 管理工具

  • phpRedisAdmin
    安裝步驟:
    > sudo apt-get install nginx # ubuntu12.04上nginx默認(rèn)根目錄在/var/share/nginx/html, 可以通過修改配置文件更改根目錄
    nginx 相關(guān)命令
    > sudo service nginx start/stop/restart
    > sudo nginx
    > sudo ngix -s stop/reload
    > sudp apt-get install php5-fpm
    > sudo php-fpm   # 在OSX上需要手動啟動該服務(wù), 可能會出錯需要修改配置文件/php-fpm.conf   

OSX上 php-fpm啟動服務(wù) 參考文檔

    > git clone https://github.com/ErikDubbelboer/phpRedisAdmin.git
    > cd phpRedisAdmin
    > git submodule init
    > git submodule update
    > git clone https://github.com/nrk/predis.git vendor

當(dāng)redis中的鍵數(shù)量過多時,可能會超出PHP的內(nèi)存限制而出錯。解除內(nèi)存限制:
> vim vendor/src/Connection/StreamConnection.php
> 增加如下代碼: ini_set('memory_limit','-1');

修改nginx配置文件中對php的配置:

   fastcgi_param  SCRIPT_FILENAME  $document_root$fastcgi_script_name;

Redis與Mysql之間的數(shù)據(jù)同步

這個庫通過分析mysql的binlog可將mysql中的數(shù)據(jù)操作同步到Redis。
實際項目中需要修改 site-packages/pymysqlreplication/row_event.py 中的 176行:

    if column.character_set_name == 'utf8mb4':
        column.character_set_name = 'utf8'
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

  • redis是一個以key-value存儲的非關(guān)系型數(shù)據(jù)庫。有五種數(shù)據(jù)類型,string、hashes、list、s...
    林ze宏閱讀 1,095評論 0 0
  • 1 Redis介紹1.1 什么是NoSql為了解決高并發(fā)、高可擴(kuò)展、高可用、大數(shù)據(jù)存儲問題而產(chǎn)生的數(shù)據(jù)庫解決方...
    克魯?shù)吕?/span>閱讀 5,707評論 0 36
  • 一、Redis基礎(chǔ) 1.概述 Redis是一個開源,高級的鍵值存儲和一個適用的解決方案,用于構(gòu)建高性能,可擴(kuò)展的W...
    鄭元吉閱讀 368評論 0 0
  • Ubuntu下安裝redis 安裝redis 在 Ubuntu 系統(tǒng)安裝 Redi 可以使用以下命令: 啟動 Re...
    riverstation閱讀 1,041評論 0 0
  • 常用管理命令 1、啟動Redis >redis-server[--port6379] 如果命令參數(shù)過多,建議通過配...
    weizilong閱讀 672評論 0 0

友情鏈接更多精彩內(nèi)容