redis介紹和安裝:
redis介紹:
1:redis是一個key-value存儲系統,官方站點 http://redis.io
2:和memcached類似,但支持數據持久化
3:支持更多value類型,除了和string外,還支持hash lists(鏈表) sets(集合)和sorted sets(有序集合)幾種數據類型
4:redis使用了兩種文件格式:全量數據(RDB)和增量請求(aof)。全量數據格式是把內存中的數據寫入磁盤,便於下次讀取文件進行加載。增量請求文件則是把內存中的數據序列化爲操作請求,用於讀取文件進行replay得到數據。
5:redis的存儲分爲內存存儲、磁盤存儲和log文件三部分。
redis安裝-下載安裝配置:
1:wget https://codeload.github.com/antirez/redis/tar.gz/2.8.21 -O redis-2.8.21.tar.gz
2:tar zxvf redis-2.8.21.tar.gz
3:cd redis_2.8.21
yum install -y gcc epel-release ;yum install -y jemalloc-devel
4:make (如果出錯,運行如下命令:cd deps;make hiredis lua jemalloc linenoise;cd ..;make)
5:make PREFIX=/usr/local/redis install
5:mkdir /usr/local/redis/etc
6:wget http://www.apelearn.com/study_v2/.redis_conf -O /usr/local/redis/etc/redis.conf 2>/dev/null
redis安裝-啓動腳本:
1:wget http://www.apelearn.com/study_v2/.redis_init -O /etc/init.d/redis 2>/dev/null
2:useradd -s /sbin/nologin redis
3:mkdir /usr/local/redis/var
4:chmod 777 /usr/local/redis/var
5:chmod 755 /etc/init.d/redis
6:chkconfig --add redis
7:chkconfig redis on
8:service redis start
redis數據結構:
redis數據類型-string:
string其實是最簡單的類型,你可以理解成與memcached一樣的類型,一個key對應一個value,其上支持的操作與memcached的操作類似,它的功能更豐富。設置可以存二進制的對象。
示例:
#redis-cli set mykey "aminglinux.com"
OK
#redis-cli get mykey
"aminglinux.com"
127.0.0.1:6379> mset key1 1 key2 a key3 c
127.0.0.1:6379> mget key1 key2 key3
1)"1"
2)"a"
3)"c"
redis數據類型-list:
1:list是一個鏈表結構,主要功能是push、pop、獲取一個範圍的所有值等等。操作中key理解爲鏈表的名字。使用list結構,我們可以輕鬆的實現最新消息排行等功能(比如新浪微博的timeline)。list的另一個應用就是消息隊列,可以利用list的push操作,將任務存在list中,然後工作線程再用pop操作將任務取出進行執行。
示例:
# redis-cli lpush list1 "aminglinux" lpush左側插入命令
(integer ) 1 pop取出命令 rpop從右側取出
#redis-cli lpush list1 "1 2 3"
(integer) 2
#redis-cli lpush list1 "aaaa bbb"
(integer) 3
#redis-cli lrange list1 0 -1 lrange:查看所有隊列 0表示最左側第一個 -1表示最右側第一個
1)"aaaa bbb"
2)"1 2 3"
3)"aminglinnux"
#redis-cli lrange list1 0 1
1)"aaaa bbb"
2)"1 2 3"
redis數據類型-set
1:set是集合,和我們數學中的集合概念類似,對集合的操作有添加刪除元素,有對多個集合求交併差等操作。操作中key理解成集合的名字,比如在微博應用中,可以將一個用戶所有的關注人存在一個集合中,將其所有粉絲存在一個集合。因爲redis非常人性化的爲集合提供了求交集、並集和差集等操作,那麼就可以很方便的實現如共同關注、共同喜好、二度好友等功能,對上面的所有集合操作,你還可以使用不同的命令選擇將結果返回給客戶端還是存集到一個新的集合中。QQ有一個社交功能叫做“好友標籤”,大家可以給你的好友貼標籤,比如“大美女”“土豪”“歐巴”等等,這時就可以使用redis的集合來實現,把每一個用戶的標籤都存儲在一個集合當中。
#redis-cli sadd set1 a
(integer) 1
#redis-cli sadd set1 b
(integer) 1
#redis0cli sadd set1 d
(integer) 1
#redis-cli smembers set1
1)"b"
2)"d"
3)"a"
redis數據類型-sort set
sorted set是有序集合,它比set多了一個權重參數score,使得集合中的元素能夠按score進行有序排列,比如一個儲存全班同學成績的sorted sets,其集合value可以是同學的學號,而score就可以是其考試得分,這樣在數據插入集合的時候,就已經進行了天然的排序。
#redis-cli zadd set2 12 "sbc"
#redis-cli zadd set2 2 "cde 123"
#redis-cli zadd set2 24 "123-aaa"
#redis-cli zadd set2 4 "a123a"
#redis-cli zrange set2 0 -1
1)"cde 123"
2)"a123a"
3)"abc"
4)"123-aaa"
倒序#redis-cli zrevrange set2 0 -1
1)"123-aaa"
2)"abc"
3)"a123a"
4)"cde 123"
redis數據類型-hash
在memcached中,我們經常將一些結構化的信息打包成hashmap,在客戶端序列化後存儲爲一個字符串的值(一般是JSON格式),比如用戶的暱稱、年齡、性別、積分等。
#redis-cli
127.0.0.1:6379>hset hash1 name aming
(integer) 1
127.0.0.1:6379>hget hash1 name
"aming"
127.0.0.1:6379>hset hash1 age 30
(integer) 1
127.0.0.1:6379>hget hash1 age
"30"
127.0.0.1:6379>hgetall hash1
1)"name"
2)"aming"
3)"'age"
4)"30"
redis持久化:
1:redis提供了兩種持久化的方式,分別是RDB(redis database)和AOF(append only file)。
2:RDB,簡而言之,就是在不同的時間點,將redis存儲的數據生成快照並存儲到磁盤等介質上。
3:AOF,則是換了一個角度來實現持久化,那就是將redis執行過的所有指令記錄下來,在下次redis重新啓動時,只要把這些寫指令從前到後再重複執行一遍,就可以實現數據恢復了。
4:其實RDB和AOF兩種方式也可以同時使用,在這種情況下,如果redis重啓的話,則會優先採用AOF方式來進行數據恢復,這是因爲AOF方式的數據恢復完整度更高。
5:如果你沒有數據持久化的需求,也可以完全關閉RDB和AOF方式,這樣的話,redis將變成一個純內存數據庫,就像memcached一樣。
redis配置講解(上)
redis查看配置:
#redis-cli
127.0.0.1:6379>CONFIG get * //查看所有的配置項
127.0.0.1:6379>CONFIG get timeout //查看timeout
1)"timeout"
2)"300"
127.0.0.1:6379>CONFIG set timeout 0 //重設timeout
OK
127.0.0.1:6379>CONFIG get timeout
1)"timeout"
2)"0"
redis通用配置:
daemonize no #默認情況下,redis並不是以daemon形式來運行的。通過daemonize配置項可以控制redis的運行形式。daemon表示後臺
pidfile /path/to/redis.pid #當以daemon形式運行時,redis會生成一個pid文件,默認會生成在/var/run/redis.pid
bind 192.168.1.2 10.8.4.2 #指定綁定的IP,可以有多個
port 6379 #指定監聽端口
unixsocket /tmp/redis.sock #也可以監聽socket
unixsocketperm 755 #當監聽socket時可以指定權限爲755
timeout 0 #當一個redis-client一直沒有請求轉發向server端,那麼server端有權主動關閉這個連接,可以通過timeout來設置“空閒超時時限”,0表示永不關閉。
tcp-keepalive 0 #tcp連接活動策略,可以通過tcp-keepalive配置項來進行設置,單位爲秒,假如設置爲60秒,則server端會每60秒向連接空閒的客戶端發起一次ACK請求,以檢查客戶端是否掛掉,對於無響應的客戶端則會關閉其連接。如果設置爲0,則不會進行保活檢測。
loglevel notice $日誌級別,有四種 debug,verbose,notice,warning
logfile ""#定義日誌路徑
syslog-ident redis #如果希望日誌打印到syslog中,通過syslog-enabled來控制,另外,syslog-ident還可以讓你指定syslog裏的日誌標誌。
syslog-facility local0 #指定syslog的設備,可以是USER或者local0-local7.
databases 16#設置數據庫的總數量,select n選擇數據庫,0-15
redis快照配置(rdb持久化):
save 900 1#表示每15分鐘且至少有1個key改變,就觸發一次持久化
save 300 10 #表示每5分鐘且至少有10個key改變,就觸發一次持久化
save 60 10000# 表示每60秒至少有10000個key改變,就觸發一次持久化
save ""#這樣可以禁用rdb持久化
stop-writes-on-bgsave-error yes #rdb持久化寫入磁盤避免不了會出現失敗的情況,默認一旦出現失敗,redis會馬上停止寫操作。如果你覺得無所謂,那就可以使用該選項關閉這個功能。
rdbcompression yes #是否要壓縮
rdbchecksum yes #是否進行數據校驗
dbfilename dump.rdb #定義快照文件的名字
dir ./ #定義快照文件存儲路徑
redis安全相關配置:
requirepass aminglinux #設置redis-server的密碼
rename-command CONFIG aminglinux.config #將CONFIG命令更名爲aminglinux.config。這樣可以避免誤操作,但如果使用了AOF持久化,建議不要啓用該功能。
rename-command CONFIG "" #也可以後面定義爲空,這樣就禁掉了該CONFIG命令
redis限制相關的配置:
maxclients 10000 #限制最大客戶端連接數
maxmemory <bytes> #設定最大內存使用數,單位是byte
maxmemory-policy volatile-lru #指定內存移除規則
maxmemory-samples 3 #LRU算法和最小TTL算法都並非是精確的算法,而是估算值。所以你可以設置樣本的大小。假如redis默認會檢查3個key並選擇其中LRU的那個,那麼你可以改變這個key樣本的數量。
redis AOF持久化相關配置:
appendonly on #如果是yes,則開啓aof持久化
appendfilename "appendonly.aof" #指定AOF文件名字,保存在dir參數指定的目錄
appendfsync everysec #指定fsync()調用模式,有三種No(不調用fsync),always(每次寫都會調用fsync),everysec(每秒鐘調用一次fsync)。第一種最快,第二種數據最安全,但性能會差一些,第三種爲這種方案,默認爲第三種。
no-appendfsync-on-rewrite no #使用no可避免當磁盤寫入量非常大時的磁盤IO阻塞
auto-aof-rewrite-percentage 10 #規定什麼情況下會觸發AOF重寫。該值爲一個比例,10表示當AOF文件增幅達到10%時則會觸發重寫機制
auto-aof-rewrite-min-size 64mb #重寫會有一個條件,就是不能低於64MB
redis慢日誌相關配置:
針對慢日誌,你可以設置兩個參數,一個是執行時長,單位是微秒,另一個是慢日誌的長度。當一個新的命令被寫入日誌時,最老的一條會從命令日誌隊列中被移除。
slowlog-log-slower-than 10000 #慢於10000ms則記錄日誌
slowlog-max-len 128 #日誌長度
redis安裝配置主從:
1:兩臺服務器 :master(192.168.31.105)和slave(192.168.31.112)
2:分別按照之前介紹的步驟安裝好redis並啓動
3:master配置文件不用動
4:slave配置文件加上一行
slaveof 192.168.31.105 6379
masterauth passwd //如果主上設置了密碼。要加這行
5:分別啓動master和slave
redis主從其他相關配置:
slave-read-only yes //讓從只讀
repl-ping-slave-period 10 //設置slave向master發起ping的頻率,每10秒發起一次
repl-timeout 60 //設置slave ping不通master多少秒後超時
repl-disable-tcp-nodelay no //是否開啓tcp_nodelay,開啓後將會使用更少的帶寬,但會有延遲,所以建議關閉
repl-backlog-size 1Mb //同步隊列的長度,backuplog是master的一個緩衝區,主從斷開後,master會先把數據寫到緩衝區,slave再次連接會從緩衝區中同步數據。
repl-backlog-ttl 3600 //主從斷開後,緩衝區的有效期,默認1小時
slave-priority 100 //多個slave是可以設置優先級的,數值越小優先級越高,應用於集羣中,支持slave切換爲master,優先級最高的纔會切換
min-slaves-to-write 3 //和下面的一起使用,它的意思是master發現有超過3個slave的延遲高於10秒,那麼master就會暫時停止寫操作。這兩個數值任何一個爲0,則關閉該功能,默認第一數值是0.
min-slaves-max-lag 10
string類型常用命令
string常用操作:
set key1 aminglinux
get key1
set key1 aming //一個key對應一個value,多次賦值,會覆蓋前面的value
setnx key2 aaa //返回1
get key2
setnx key2 bbb //返回0
說明:setnx如果key存在,則返回0,不存在會直接創建這個key
setex key3 10 1 //這個是用來給key設定過期時間的
mset key1 1 key2 2 key3 3 //同時設置多個key
mget key1 key2 key3
hash類型常用命令
hash數據常用操作:
hset user1 name aming //建立hash
hset user1 age 30
hset user1 job it
hgetall user1
hmset user2 name aming age 30 job it //批量建立鍵值樹
hmget user2
hmget user2 name age job
hdel user2 job //刪除指定filed
hkeys user2 //打印所有的key
hvals user2 //打印所有的values
hlen user2 //查看hash有幾個filed
list數據常用操作:
lpush lista a //從左側壓入一個元素
lpush lista b
lrange lista 0 -1 //0爲頭 -1爲尾
lpop lista //從左側取出
rpush lista 1 //從右側壓入一個元素
rpush lista 2
lrange lista 0 -1
rpop lista //從右側取第一個元素
linsert lista before 2 3 //在2的前面插入一個元素爲3
lset lista 4 bbb //把第5個元素修改爲bbb
lindex lista 0 //查看第1個元素
lindex lista 3 //查看第4個元素
llen lista //查看鏈表中有幾個元素
set數據常用操作:
sadd seta aaa //向集合seta中放入元素
smembers seta //查看集合中的所有元素
srem seta aaa //刪除元素
spop seta //隨機取出一個元素,刪除
sdiff seta setb //求差集。以seta爲標準
sdiffstore setc seta setb //求差集並且存儲,存儲到了setc裏
sinter seta setb //求交集
sinterstore setd seta setb //求交集存儲setd
sunion seta setb //求並集
sunionstore sete seta setb //求並集並存儲到sete
sismember seta aaa //判斷一個元素是否屬於一個集合
srandmember seta //隨機取出一個元素,但不刪除
zset數據常用操作:
zadd zseta 11 123 //創建有序集合
zrange zseta 0 -1 //顯示所有元素,按順序顯示
zrange zseta 0 -1 withscores //可以帶上分值
zrem zseta 222 //刪除指定元素
zrank zseta 222 //返回元素的索引值,索引值從0開始,按score正向排序
zrevrank zseta 222 //同上,不同的是,按score反向排序
zrevrange zseta 0 -1 //反序顯示所有元素
zcard zseta //返回集合中所有元素的個數
zcount zseta 1 10 //返回分值範圍1-10的元素個數
zrangebyscore zseta 0 2 //刪除索引範圍0-2的元素,按score正向排序
zremrangebyscore zseta 1 10 //刪除分值範圍1-10的元素
鍵值和服務器命令:
鍵值相關操作:
keys * //取出所有key
keys my* //模糊匹配
exists name //有name鍵,返回1,否則返回0
del key1 //刪除一個key //成功返回1 ,否則返回0
EXPIRE key1 100 //設置key1 100秒後過期
ttl key //查看鍵還有多長時間過期,單位是秒,當key不存在時,返回-2,當key存在但沒有設置剩餘生存時間時,返回-1,否則,返回key的剩餘生存時間。
select 0 //代表選擇當前數據庫,默認進入0數據庫
move age 1 //把age移動到1數據庫
persist key1 //取消key1的過期時間
randomkey //隨機返回一個key
rename oldname newname //重命名key
type key1 //返回鍵的類型
服務相關操作:
dbsize //返回當前數據庫中key的數目
info //返回redis數據庫狀態信息
flushdb //清空當前數據庫中所有的鍵
flushall //清空所有數據庫中的所有的key
php中應用redis
redis擴展模塊安裝:
1:wget https://codeload.github.com/phpredis/phpredis/zip/develop -O phpredis.zip
2:
3:unzip phpredis.zip
4:cd phpredis-develop
5:/usr/local/php/bin/phpize
6:./configure --with-php-config=/usr/local/php/bin/php-config
7:make && make install
8:vim /usr/local/php/etc/php.ini //最後面增加一行extension = redis.so
9:/usr/local/php/bin/php -m |grep redis 檢查是否成功 重啓Apache或者nginx
10:php redis 中文文檔 http://www.cnblogs.com/weafer/archive/2011/09/21/2184059.html
redis實現session共享:
1:php.ini中加入
session.save_handler = "redis"
session.save_path = "tcp://127.0.0.1:6379"
2:或者Apache虛擬主機加入:
php_value session.save_handler "redis"
php_value session.save_path "tcp://127.0.0.1:6379"
3:或者php-fpm.conf對應的pool中加入
php_value[session.save_handler] = redis
php_value[session.save_path] = "tcp://127.0.0.1:6379"
redis存儲session測試:
1:wget http://study.lishiming.net/.mem_se.txt
2:mv .mem_se.txt /usr/local/apache2/htdocs/session.php
3:curl localhost/session.php
4:輸出類似於 1443710814<br><br>1443710814<br><br>9jm6nom9ogojedj3pth0iscv22
5:連接redis:
redis-cli
127.0.0.1:6379>keys * //可以把所有的key都列出來
"PHPREDIS_SESSION:9jm6nom9ogojedj3pth0iscv22"
127.0.0.1:6379>get PHPREDIS_SESSION:9jm6nom9ogojedj3pth0iscv22
"TEST|i:1443710814;TEST3|i:1443710814;"