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ù)同步
- 第三方庫: python-mysql-replication
https://github.com/noplay/python-mysql-replication
這個(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'