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的運(yùn)行方式按脚,持久化文件票编,日志文件的存儲位置等
    通過一下步驟使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)程模式運(yù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    # 可以防止中文顯示亂碼
    

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

redis 鍵名最佳實(shí)踐, 對象類型:對象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)格通配符格式:

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

CONFIG GET XXXX # 獲取當(dāng)前的配置值
SELECT n # 更換數(shù)據(jù)庫,默認(rèn)支持16個(gè)數(shù)據(jù)庫, 默認(rèn)是數(shù)據(jù)庫0
EXISTS key # 判斷一個(gè)鍵是否存在
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 # 增加指定的浮點(diǎn)數(shù)
APPEND key value # 向鍵值的末尾追加 value, 若不存在則等同SET
STRLEN key # 獲取字符串長度 (以utf-8編碼時(shí)培愁,一個(gè)中文長度是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)制個(gè)數(shù)
BITOP operation destkey key [key ...] # 位運(yùn)算,包括 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 # 判斷一個(gè)字段是否存在
HSETNX key field value # 當(dāng)字段不存在時(shí)定续,才執(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個(gè)值為value的元素
2> 當(dāng)count<0, 從列表右邊開始刪除前|count|個(gè)值為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 # 將元素從一個(gè)列表轉(zhuǎn)移到另一個(gè)列表

集合

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

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

SPOP key # 從集合中彈出一個(gè)元素

有序集合

有序倡鲸,唯一,讀取中間部分速度也很快
ZADD key score member [score member ....] # 加入一個(gè)元素和該元素的分?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ù)前加‘(’表示不包括端點(diǎn)宁炫。offset 和 count 類似SQL中的用法,即在結(jié)果集的基礎(chǔ)上向后偏移offset并只取前count個(gè)元素

ZREVRANGEBYSCORE key max min [WITHSCORES] [LIMIT offset count] # 逆序
ZINCRBY key increment member # 增加某個(gè)元素的分?jǐn)?shù), 增量可以為負(fù)數(shù)氮凝,表示減去
ZCARD key # 獲取集合中的元素?cái)?shù)量
ZCOUNT key min max # 獲取指定分?jǐn)?shù)范圍內(nèi)的元素個(gè)數(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] # 計(jì)算多個(gè)有序集合的交集并存儲結(jié)果羔巢,destination中的分?jǐn)?shù)由AGREGATE參數(shù)決定。當(dāng)是SUM(默認(rèn)值)罩阵,分?jǐn)?shù)為每個(gè)參與計(jì)算的集合中該元素分?jǐn)?shù)的總和竿秆;當(dāng)是MIN,分?jǐn)?shù)是每個(gè)參與計(jì)算的集合中該元素分?jǐn)?shù)的最小值稿壁;當(dāng)是MAX幽钢,則是最大值。WEIGHTS為每個(gè)參與計(jì)算的集合的分?jǐn)?shù)權(quán)重傅是,計(jì)算時(shí)分?jǐn)?shù)會乘上該集合的權(quán)重匪燕。

ZUNIONSTORE 同上類似


事務(wù)

MULTI
若干命令
EXEC

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

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

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

注: 如果WATCH一個(gè)有生存時(shí)間的鍵日丹,當(dāng)這個(gè)鍵過期被刪除時(shí),并不會被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)超出限制時(shí)會根據(jù) maxmemory-policy 參數(shù)指定的策略來刪除不需要的鍵。

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

  • maxmemory-samples 當(dāng)內(nèi)存不足時(shí)择示,每次刪除的鍵的數(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ù), 可能會出錯(cuò)需要修改配置文件/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ù)量過多時(shí)束凑,可能會超出PHP的內(nèi)存限制而出錯(cuò)。解除內(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ù)同步

這個(gè)庫通過分析mysql的binlog可將mysql中的數(shù)據(jù)操作同步到Redis栅盲。
實(shí)際項(xiàng)目中需要修改 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)系作者
  • 序言:七十年代末汪诉,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子谈秫,更是在濱河造成了極大的恐慌扒寄,老刑警劉巖,帶你破解...
    沈念sama閱讀 216,470評論 6 501
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件拟烫,死亡現(xiàn)場離奇詭異该编,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)硕淑,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,393評論 3 392
  • 文/潘曉璐 我一進(jìn)店門课竣,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人置媳,你說我怎么就攤上這事于樟。” “怎么了拇囊?”我有些...
    開封第一講書人閱讀 162,577評論 0 353
  • 文/不壞的土叔 我叫張陵迂曲,是天一觀的道長。 經(jīng)常有香客問我寥袭,道長路捧,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,176評論 1 292
  • 正文 為了忘掉前任纠永,我火速辦了婚禮,結(jié)果婚禮上谒拴,老公的妹妹穿的比我還像新娘尝江。我一直安慰自己,他們只是感情好英上,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,189評論 6 388
  • 文/花漫 我一把揭開白布炭序。 她就那樣靜靜地躺著啤覆,像睡著了一般。 火紅的嫁衣襯著肌膚如雪惭聂。 梳的紋絲不亂的頭發(fā)上窗声,一...
    開封第一講書人閱讀 51,155評論 1 299
  • 那天,我揣著相機(jī)與錄音辜纲,去河邊找鬼笨觅。 笑死,一個(gè)胖子當(dāng)著我的面吹牛耕腾,可吹牛的內(nèi)容都是我干的见剩。 我是一名探鬼主播,決...
    沈念sama閱讀 40,041評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼扫俺,長吁一口氣:“原來是場噩夢啊……” “哼苍苞!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起狼纬,我...
    開封第一講書人閱讀 38,903評論 0 274
  • 序言:老撾萬榮一對情侶失蹤羹呵,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后疗琉,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體冈欢,經(jīng)...
    沈念sama閱讀 45,319評論 1 310
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,539評論 2 332
  • 正文 我和宋清朗相戀三年没炒,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了涛癌。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 39,703評論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡送火,死狀恐怖拳话,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情种吸,我是刑警寧澤弃衍,帶...
    沈念sama閱讀 35,417評論 5 343
  • 正文 年R本政府宣布,位于F島的核電站坚俗,受9級特大地震影響镜盯,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜猖败,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,013評論 3 325
  • 文/蒙蒙 一速缆、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧恩闻,春花似錦艺糜、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,664評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽翅楼。三九已至,卻和暖如春真慢,著一層夾襖步出監(jiān)牢的瞬間毅臊,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 32,818評論 1 269
  • 我被黑心中介騙來泰國打工黑界, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留管嬉,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 47,711評論 2 368
  • 正文 我出身青樓园爷,卻偏偏與公主長得像宠蚂,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個(gè)殘疾皇子童社,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,601評論 2 353

推薦閱讀更多精彩內(nèi)容

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