中文字幕日韩精品一区二区免费_精品一区二区三区国产精品无卡在_国精品无码专区一区二区三区_国产αv三级中文在线

Reidis安裝配置

一、redis介紹

創(chuàng)新互聯(lián)公司主要從事網(wǎng)站設(shè)計(jì)、網(wǎng)站建設(shè)、網(wǎng)頁(yè)設(shè)計(jì)、企業(yè)做網(wǎng)站、公司建網(wǎng)站等業(yè)務(wù)。立足成都服務(wù)湘橋,10年網(wǎng)站建設(shè)經(jīng)驗(yàn),價(jià)格優(yōu)惠、服務(wù)專業(yè),歡迎來電咨詢建站服務(wù):028-86922220

  • redis是一個(gè)key-value存儲(chǔ)系統(tǒng),官方站點(diǎn)http://redis.io

  • 和memcached類似,但支持?jǐn)?shù)據(jù)持久化

  • 支持更多value類型,除了和string外,還支持hash、lists(鏈表)、sets(集合)和sorted sets(有序集合)集中數(shù)據(jù)類型

  • redis使用了兩種文件格式:全量數(shù)據(jù)(RDB)和增量請(qǐng)求(aof)。全量數(shù)據(jù)格式是把內(nèi)存中的數(shù)據(jù)寫入磁盤,便于下次讀取文件進(jìn)行加載。增量請(qǐng)求文件則是把內(nèi)存中的數(shù)據(jù)序列化為操作請(qǐng)求,用于讀取文件進(jìn)行replay得到數(shù)據(jù)

  • redis的存儲(chǔ)分為內(nèi)存存儲(chǔ)、磁盤存儲(chǔ)和log文件三部分


二、Redis安裝

cd /usr/local/src
wget   https://codeload.github.com/antirez/redis/tar.gz/2.8.21
mv 2.8.21 redis-2.8.21.tar.gz
tar xf redis-2.8.21.tar.gz
cd redis-2.8.21
make && make PREFIX=/usr/local/redis install
mkdir /usr/local/redis/etc


錯(cuò)誤:

在包含自 adlist.c:34 的文件中:

zmalloc.h:50:31: 錯(cuò)誤:jemalloc/jemalloc.h:沒有那個(gè)文件或目錄

zmalloc.h:55:2: 錯(cuò)誤:#error "Newer version of jemalloc required"

make[1]: *** [adlist.o] 錯(cuò)誤 1

make[1]: Leaving directory `/usr/local/src/redis-2.6.6/src'

make: *** [all] 錯(cuò)誤 2

解決:

make MALLOC=libc


三、Redis配置

vim  /usr/local/redis/etc/redis.conf============配置文件
daemonize yes
pidfile /usr/local/redis/var/redis.pid
port 6379
timeout 300
loglevel debug
logfile /usr/local/redis/var/redis.log
databases 16
save 900 1
save 300 10
save 60 10000
rdbcompression yes
dbfilename dump.rdb
dir /usr/local/redis/var/
appendonly no
appendfsync always


下面是redis.conf的主 要配置參數(shù)的意義:

daemonize:是否以后臺(tái)daemon方式運(yùn)行

pidfile:pid文件位置

port:監(jiān)聽的端口號(hào)

timeout:請(qǐng)求超時(shí)時(shí)間

loglevel:log信息級(jí)別

logfile:log文件位置

databases:開啟數(shù)據(jù)庫(kù)的數(shù)量

save * *:保存快照的頻率,第一個(gè)*表示多長(zhǎng)時(shí)間,第三個(gè)*表示執(zhí)行多少次寫操作。在一定時(shí)間內(nèi)執(zhí)行一定數(shù)量的寫操作時(shí),自動(dòng)保存快照??稍O(shè)置多個(gè)條件。

rdbcompression:是否使用壓縮

dbfilename:數(shù)據(jù)快照文件名(只是文件名,不包括目錄)

dir:數(shù)據(jù)快照的保存目錄(這個(gè)是目錄)

appendonly:是否開啟appendonlylog,開啟的話每次寫操作會(huì)記一條log,這會(huì)提高數(shù)據(jù)抗風(fēng)險(xiǎn)能力,但影響效率。

appendfsync:appendonlylog如何同步到磁盤(三個(gè)選項(xiàng),分別是每次寫都強(qiáng)制調(diào)用fsync、每秒啟用一次fsync、不調(diào)用fsync等待系統(tǒng)自己同步)


=====================編寫一個(gè)redis啟動(dòng)腳本

vi /etc/init.d/redis   //加入如下內(nèi)容:
#!/bin/sh
#
# redis        init file for starting up the redis daemon
#
# chkconfig:   - 20 80
# description: Starts and stops the redis daemon.
# Source function library.
. /etc/rc.d/init.d/functions
name="redis-server"
basedir="/usr/local/redis"
exec="$basedir/bin/$name"
pidfile="$basedir/var/redis.pid"
REDIS_CONFIG="$basedir/etc/redis.conf"
[ -e /etc/sysconfig/redis ] && . /etc/sysconfig/redis
lockfile=/var/lock/subsys/redis
start() {
    [ -f $REDIS_CONFIG ] || exit 6
    [ -x $exec ] || exit 5
    echo -n $"Starting $name: "
    daemon --user ${REDIS_USER-redis} "$exec $REDIS_CONFIG"
    retval=$?
    echo
    [ $retval -eq 0 ] && touch $lockfile
    return $retval
}
stop() {
    echo -n $"Stopping $name: "
    killproc -p $pidfile $name
    retval=$?
    echo
    [ $retval -eq 0 ] && rm -f $lockfile
    return $retval
}
restart() {
    stop
    start
}
reload() {
    false
}
rh_status() {
    status -p $pidfile $name
}
rh_status_q() {
    rh_status >/dev/null 2>&1
}
case "$1" in
    start)
        rh_status_q && exit 0
        $1
        ;;
    stop)
        rh_status_q || exit 0
        $1
        ;;
    restart)
        $1
        ;;
    reload)
        rh_status_q || exit 7
        $1
        ;;
    force-reload)
        force_reload
        ;;
    status)
        rh_status
        ;;
    condrestart|try-restart)
        rh_status_q || exit 0
        restart
        ;;
    *)
        echo $"Usage: $0 {start|stop|status|restart|condrestart|try-restart}"
        exit 2
esac
exit $?


因?yàn)槟_本啟動(dòng)時(shí)以redis用戶啟動(dòng)的,所以需要增加redis用戶

useradd -s /sbin/nologin redis
mkdir /usr/local/redis/var
chmod 777 /usr/local/redis/var
chmod 755 /etc/init.d/redis
chkconfig  --add redis
chkconfig redis on
service redis start


四、Redis數(shù)據(jù)類型

string是最簡(jiǎn)單的類型,你可以理解成Memcached一樣的類型,一個(gè)key對(duì)應(yīng)一個(gè)value,騎上支持的操作與Memcached的操作類似,它的功能更豐富。設(shè)置可以存二進(jìn)制的對(duì)象。

/usr/local/redis/bin/redis-cli 

127.0.0.1:6379> mset key1 szk key2 love key3 yc
OK
127.0.0.1:6379> mget key1 key2 key3
1) "szk"
2) "love"
3) "yc"


list是一個(gè)鏈表結(jié)構(gòu),主要功能是push、pop、獲取一個(gè)范圍的所有值等等。操作中key理解為鏈接的名字。使用List結(jié)構(gòu),我們可以輕松的實(shí)現(xiàn)最新消息排行等功能。使用List結(jié)構(gòu),我們可以輕松地實(shí)現(xiàn)最新消息排行等功能。List的另一個(gè)應(yīng)用就是消息隊(duì)列,可以利用list的push操作,將任務(wù)存在list中,然后工作線程再用pop操作將任務(wù)取出進(jìn)行執(zhí)行。

127.0.0.1:6379> lpush list1 123
(integer) 1
127.0.0.1:6379> lpush list1 aaa
(integer) 2
127.0.0.1:6379> lpush list1 "123 456"
(integer) 3
127.0.0.1:6379> rpop list1
"123"
127.0.0.1:6379> rpop list1
"aaa"
127.0.0.1:6379> rpop list1


set是集合,和我們數(shù)學(xué)中的集合概念類似,對(duì)集合的操作有添加刪除元素,有對(duì)多個(gè)集合求交并差等操作。操作中key理解為集合的名字。比如在微博應(yīng)用中,可以將一個(gè)用戶所有的關(guān)注人存在一個(gè)集合中,將其所有粉絲存在一個(gè)集合。因?yàn)镽edis非常人性化的為幾個(gè)提供了求交集、并集、差集等操作,那么就可以非常方便的實(shí)現(xiàn)如共同關(guān)注、共同喜好、二度好友等功能,對(duì)上面的所有集合 操作,你還可以使用不同的命令選擇將結(jié)果返回給客戶端還是存集到一個(gè)新的集合中。QQ有一個(gè)社交功能叫做"好友標(biāo)簽",這時(shí)就可以使用redis的集合來實(shí)現(xiàn),把每一個(gè)用戶的標(biāo)簽都存儲(chǔ)在一個(gè)集合之中。

127.0.0.1:6379> sadd set1 zbc
(integer) 1
127.0.0.1:6379> sadd set1 szk
(integer) 1
127.0.0.1:6379> smembers set1
1) "zbc"


sorted set是有序集合,它比set多了一個(gè)權(quán)重參數(shù)score,使得集合中的元素能夠按score進(jìn)行有序排列,比如一個(gè)存儲(chǔ)全班同學(xué)成績(jī)的Sorted Sets,其集合value可以是同學(xué)的學(xué)號(hào),而score就可以是其考試得分,這樣在數(shù)據(jù)插入集合的時(shí)候,就已經(jīng)進(jìn)行了天然的排序。

127.0.0.1:6379> zadd mset2 2 "cde 123"
(integer) 1
127.0.0.1:6379> zadd mset2 4 "a123a"
(integer) 1
127.0.0.1:6379> zadd mset2 24 "123-aaa"
(integer) 1
127.0.0.1:6379> zrange mset2 0 -1
1) "cde 123"
2) "a123a"
3) "123-aaa"


hash:在memcached中,經(jīng)常將一些結(jié)構(gòu)化的信息打包成hashmap,在客戶端序列化后存儲(chǔ)為一個(gè)字符串的值(一般是JSON格式),比如用戶的昵稱、年齡、性別、積分等。


五、Redis持久化

  • Redis提供了兩種持久化的方式,分別是RDB(Redis DataBase)和AOF(Append Only FIle)

  • RDB,簡(jiǎn)而言之,就是在不同的時(shí)間點(diǎn),將redis存儲(chǔ)的數(shù)據(jù)生成快照并存儲(chǔ)到磁盤等介質(zhì)上。

  • AOF,則是換了一個(gè)角度來實(shí)現(xiàn)持久化,那就是redis執(zhí)行過的所有寫指令記錄下來,在下次redis重新啟動(dòng)時(shí),只要把這些寫指令從前到后重復(fù)執(zhí)行一遍,就可以實(shí)現(xiàn)數(shù)據(jù)恢復(fù)了。

  • 其實(shí)RDB和AOF兩種方式也可以同時(shí)使用,在這種情況下,如果redis重啟的話,則會(huì)優(yōu)先采用AOF方式來進(jìn)行數(shù)據(jù)恢復(fù),這是因?yàn)锳OF方式的數(shù)據(jù)恢復(fù)完整度更高。

  • 如果你沒有數(shù)據(jù)持久化的需求,也完全可以關(guān)閉RDB和AOF方式,這樣的話,redis將變成一個(gè)純內(nèi)存數(shù)據(jù)庫(kù),就像memcached一樣。


六、Redis通用配置

  • daemonize no #默認(rèn)情況下,redis并不是以daemon形式來運(yùn)行的。通過daemonize配置項(xiàng)可以控制redis的運(yùn)行形式。

  • pidfile /path/to/redis.pid #當(dāng)以daemon形式運(yùn)行時(shí),redis會(huì)生成一個(gè)pid文件,默認(rèn)會(huì)生成在/var/run/redis.pid

  • bind 192.168.1.200 #指定綁定的IP,可以有多個(gè)

  • port 6379 #指定監(jiān)聽端口

  • unixsocket /tmp/redis.sock #也可以監(jiān)聽socket

  • unixsocketperm 755 #當(dāng)監(jiān)聽socket時(shí)可以指定權(quán)限為755

  • timeout 0 #當(dāng)一個(gè)redis-client一直沒有請(qǐng)求發(fā)向server端,那么server端有權(quán)主動(dòng)關(guān)閉這個(gè)連接,可以通過timeout來設(shè)置“空間超時(shí)時(shí)限”,0表示永不關(guān)閉

  • tcp-keepalive 0 #TCP連接保活策略,可以通過tcp-keepalive配置項(xiàng)來進(jìn)行設(shè)置,單位為秒,假如設(shè)置為60秒,則server端會(huì)每60秒向連接空閑的客戶端發(fā)起一次ACk請(qǐng)求,以檢查客戶端是否已經(jīng)掛掉,對(duì)于無響應(yīng)的客戶端則會(huì)關(guān)閉其連接。如果設(shè)置為0,則不會(huì)進(jìn)行保活檢測(cè)

  • loglevel notice #日志級(jí)別,有四種debug,verbose,notice,warning

  • logfile "" #定義日志路徑

  • syslog-ident redis #如果希望日志打印到sysllog中,通過syslog-enabled來控制

  • syslog-facility local0 #指定syslog的設(shè)備,可以是USER或者local0-local7

  • databases 16 #設(shè)置數(shù)據(jù)庫(kù)的總數(shù)量,select n 選擇數(shù)據(jù)庫(kù),0 - 15


七、Redis快照配置(rdb持久化)

  • save 900 1 #表示每15分鐘且至少有1個(gè)key改變,就觸發(fā)一次持久化

  • save 300 10 #表示每5分鐘至少有10個(gè)key改變,就觸發(fā)一次持久化

  • save 60 1000 #表示每60秒至少有10000個(gè)key改變,就觸發(fā)一次持久

  • save "" #這樣可以禁用rdb持久化

  • stop-write-on-bgsave-error yes #rdb持久化寫入磁盤避免不了會(huì)出現(xiàn)失敗的情況,默認(rèn)一旦出現(xiàn)失敗,redis會(huì)馬上停止寫操作。如果你覺得無所謂,那就可以使用選項(xiàng)關(guān)閉這個(gè)功能

  • rdbcompression yes #是否要壓縮

  • rdbchecksum yes #是否進(jìn)行數(shù)據(jù)校驗(yàn)

  • dir ./ #定義快照文件儲(chǔ)存路徑


八、Redis安全相關(guān)配置

vim /usr/local/redis/etc/redis.conf  #設(shè)置redis-server的密碼

#增加下面配置

requirepass szk    


/usr/local/redis/bin/redis-cli -a szk  #-a指定密碼登錄



  • rename-command CONFIG szk.config   #將CONFIG命令更名為szk.config,這樣可以避免誤操作,但 如果使用了AOF持久化,建議不要啟用該功能

  • rename-command CONFIG ""  #也可以后面定義為空,這樣就禁掉了該CONFIG命令


九、Redis限制相關(guān)配置

  • maxclients 10000 #限制最大客戶端連接數(shù)

  • maxmemory <bytes> #設(shè)定最大內(nèi)存使用數(shù),單位是byte

  • maxmemory-policy volatile-lru #指定內(nèi)存移除規(guī)則

  • maxmemory-samples 3 #LRU算大和最小TTL算法都并非是精確的算法,而是估算值。所以你可以設(shè)置樣本的大小。假如redis默認(rèn)會(huì)檢查三個(gè)key,并選擇其中LRU的那個(gè),那么你可以改變這個(gè)key樣本的數(shù)量。


十、Redis AOF持久化相關(guān)配置

  • appendonly no #如果是yes,則開啟aof持久化

  • appendfilename "appendonly.aof" #指定aof文件名字,保存在dir參數(shù)指定的命令

  • appendfsync everysec #指定fsync()調(diào)用模式,有三種no(不調(diào)用fsync),always(每次寫都會(huì)調(diào)用fsync),exerysec(每秒鐘調(diào)用一次fsync)。第一種最快,第二種數(shù)據(jù)最安全,但性能會(huì)差一些,默認(rèn)為第三種方案,性能和安全兼顧。

  • no-appendfsync-on-rewrite no #使用no可避免當(dāng)寫入量非常大時(shí)的磁盤IO阻塞

  • auto-aof-rewrite-percentage 10 #規(guī)定什么情況下觸發(fā)aof重寫。該值為一個(gè)比例,10表示當(dāng)aof文件增幅達(dá)到10%時(shí)則會(huì)觸發(fā)重寫機(jī)制

  • auto-aof-rewrite-min-size 64mb #重寫會(huì)有一個(gè)條件,就是不能低于64MB


十一、Redis慢日志相關(guān)配置

  • 針對(duì)慢日志,你可以設(shè)置兩個(gè)參數(shù),一個(gè)是執(zhí)行時(shí)長(zhǎng),單位是微秒,另一個(gè)是慢日志的長(zhǎng)度。當(dāng)一個(gè)新的命令被寫入日志時(shí),最老的一條會(huì)從命令日志隊(duì)列中被移除。

  • slowlog-log-slower-than 10000 #慢于10000ms則記錄日志

  • slowlog-max-len 128 #日志長(zhǎng)度


十二、Redis主從配置

  • 分別按照之前介紹的步驟安裝好redis并啟動(dòng)

  • master 配置文件不用動(dòng)

  • slave配置文件上加一行:slaveof 192.168.1.200 6379

  • masterauth szk  #如果主上設(shè)置了密碼,要加這行

  • 分別啟動(dòng)master和slave

tail /usr/local/redis/var/redis.log 
3966] 18 Feb 15:02:58.330 * MASTER <-> SLAVE sync: receiving 192 bytes from master
[3966] 18 Feb 15:02:58.330 * MASTER <-> SLAVE sync: Flushing old data
[3966] 18 Feb 15:02:58.330 * MASTER <-> SLAVE sync: Loading DB in memory
[3966] 18 Feb 15:02:58.330 * MASTER <-> SLAVE sync: Finished with success
[3966] 18 Feb 15:03:03.344 - DB 0: 7 keys (0 volatile) in 8 slots HT.
[3966] 18 Feb 15:03:03.344 - 1 clients connected (0 slaves), 466840 bytes in use
[3966] 18 Feb 15:03:08.396 - DB 0: 7 keys (0 volatile) in 8 slots HT.
[3966] 18 Feb 15:03:08.397 - 1 clients connected (0 slaves), 466848 bytes in use


測(cè)試:

/usr/local/redis/bin/redis-cli -a szk           主

127.0.0.1:6379> set key1 szk

OK

127.0.0.1:6379> get key1            

"szk"


/usr/local/redis/bin/redis-cli             從

127.0.0.1:6379> get key1

"szk"


OK


十三、Redis主從其他相關(guān)配置

  • slave-read-only yes #讓從只讀

  • repl-ping-slave-period 10  #設(shè)置slave向master發(fā)起ping的頻率,每10s發(fā)起一次

  • repl-timeout 60  #設(shè)置slave ping不同master多少s后就超時(shí)

  • repl-disable-tcp-nodelay no  #是否開啟tcp_nodeay,開啟后將會(huì)使用更少的帶寬,但會(huì)有延遲,所以建議關(guān)閉

  • repl-backlog-size 1mb  #同步隊(duì)列的長(zhǎng)度,backuplog是master的一個(gè)緩沖區(qū),主從斷開后,master會(huì)先把數(shù)據(jù)寫到緩沖區(qū),slave再次連接會(huì)從緩沖區(qū)中同步數(shù)據(jù)

  • repl-backlog-ttl 3600  #主從斷開后,緩沖區(qū)的有效期,默認(rèn)1小時(shí)

  • slave-priority 100  #多個(gè)slave是可以設(shè)置優(yōu)先級(jí)的,數(shù)值越小優(yōu)先級(jí)越高,應(yīng)用于集群中,支持slave切換為mster,優(yōu)先級(jí)最高的才會(huì)切換

  • min-slave-to-write 3 #和下面的一起使用,它的意思是master發(fā)現(xiàn)有超過3個(gè)slave的延遲高于10s,那么master就會(huì)暫時(shí)停止寫操作。這兩個(gè)數(shù)值任何一個(gè)為0,則關(guān)閉該功能,默認(rèn)第一數(shù)值是0

  • min-slaves-max-log 10 


十四、string常用操作

127.0.0.1:6379> set key1 szk  #給key1賦值為szk
OK 
127.0.0.1:6379> get key1    #獲取這個(gè)值value
"szk"
127.0.0.1:6379> set key1 yc  #一個(gè)key對(duì)應(yīng)一個(gè)value,多次賦值,會(huì)覆蓋前面的value
OK
127.0.0.1:6379> get key1  
"yc"
127.0.0.1:6379> setex key3 10 1   #用來給key設(shè)定過期時(shí)間,ttl key3查看時(shí)間
OK
127.0.0.1:6379> mset key1 1 key2 2 key3 3    #同時(shí)設(shè)置多個(gè)key
OK
127.0.0.1:6379> mget key1 key2 key3    
1) "1"
2) "2"
3) "3"


十五、Hash常用操作

127.0.0.1:6379> hset hash2 name szk
(integer) 1
127.0.0.1:6379> hset hash2  age 23
(integer) 1
127.0.0.1:6379> hset hash2  job it
(integer) 1
127.0.0.1:6379> hgetall hash2 
1) "name"
2) "szk"
3) "age"
4) "23"
5) "job"
6) "it"
127.0.0.1:6379> hmset hash3 name yc age 24 job teacher    #批量創(chuàng)建
OK
127.0.0.1:6379> hgetall hash3
1) "name"
2) "yc"
3) "age"
4) "24"
5) "job"
6) "teacher"
127.0.0.1:6379> hdel hash3 job     #刪除某個(gè)值
(integer) 1
127.0.0.1:6379> hgetall hash3
1) "name"
2) "yc"
3) "age"
4) "24"
127.0.0.1:6379> hkeys hash3   #查看所有的key
1) "name"
2) "age"
127.0.0.1:6379> hvals hash3   #查看所有的values
1) "yc"
2) "24"
127.0.0.1:6379> hlen hash3    #查看hash有幾個(gè)filed
(integer) 2

十六、list常用操作

127.0.0.1:6379> lpush list1 a    #從左邊插入
(integer) 3
127.0.0.1:6379> lpush list1 b     #從左邊插入
(integer) 4
127.0.0.1:6379> lpush list1 c      #從左邊插入
(integer) 5
127.0.0.1:6379> lrange list1 0 -1       #從左邊往右羅列,最先插入在最后邊
1) "c"
2) "b"
3) "a"
127.0.0.1:6379> lpop list1          #從最左邊取出
"c"
127.0.0.1:6379> lrange list1 0 -1    #從左邊往右羅列
1) "b"
2) "a"
127.0.0.1:6379> rpush list1 1          #從右邊插入
(integer) 5
127.0.0.1:6379> rpush list1 2           #從右邊插入
(integer) 6
127.0.0.1:6379> rpush list1 3           #從右邊插入
(integer) 7
127.0.0.1:6379> lrange list1 0 -1       #從右往左羅列,最后插入在最后邊
1) "b"
2) "a"
3) "1"
4) "2"
5) "3"
127.0.0.1:6379> linsert list1  before 3  5        #在3前面插入一個(gè)5
(integer) 8
127.0.0.1:6379> lrange list1 0 -1
1) "b"
2) "a"
3) "1"
4) "2"
5) "5"
6) "3"
127.0.0.1:6379> lset list1 7 6             #將0開始的第7個(gè)元素?fù)Q成6
OK
127.0.0.1:6379> lrange list1 0 -1
1) "b"
2) "a"
3) "456"
4) "123"
5) "1"
6) "2"
7) "5"
8) "6"
127.0.0.1:6379> lindex list1 7     #查看從0開始的第7個(gè)元素
"6"
127.0.0.1:6379> llen list1          #查看列表中有幾個(gè)元素
(integer) 8

十七、set數(shù)據(jù)常用操作 

127.0.0.1:6379> sadd set1 1        #向集合set1中放入元素
(integer) 1
127.0.0.1:6379> sadd set1 2
(integer) 1
127.0.0.1:6379> sadd set1 3
(integer) 1
127.0.0.1:6379> sadd set1 4
(integer) 1
127.0.0.1:6379> smembers set1    #查看集合中所有元素
1) "zbc"
2) "1"
3) "szk"
4) "2"
5) "3"
6) "4"
127.0.0.1:6379> spop set1     #隨機(jī)取出一個(gè)元素,刪除
"szk"
127.0.0.1:6379> sdiff set1 seta       #比較差集,以set1為主來比較
1) "zbc"
2) "4"
127.0.0.1:6379> sdiffstore set3  seta set1   #比較差集,將結(jié)果存入set3中
(integer) 2
127.0.0.1:6379> SMEMBERS set3    #tab自動(dòng)補(bǔ)全,但顯示為大寫
1) "2"
2) "szk"


十八、zset常用操作

127.0.0.1:6379> zadd zset1 1 abc     #創(chuàng)建有序集合
(integer) 1
127.0.0.1:6379> zadd zset1 10 aabc   #創(chuàng)建有序集合
(integer) 1
127.0.0.1:6379> zadd zset1 5 aaa    #創(chuàng)建有序集合
(integer) 1
127.0.0.1:6379> zadd zset1 88 bbb   #創(chuàng)建有序集合
(integer) 1
127.0.0.1:6379> zadd zset1 888 szk   #創(chuàng)建有序集合
(integer) 1
127.0.0.1:6379> ZRANGE zset1 0 -1   #顯示所有元素,按順序顯示
1) "abc"
2) "aaa"
3) "aabc"
4) "bbb"
5) "szk"
127.0.0.1:6379> ZRANGE zset1 0 -1 withscores    #可以帶上分值
 1) "abc"
 2) "1"
 3) "aaa"
 4) "5"
 5) "aabc"
 6) "10"
 7) "bbb"
 8) "88"
 9) "szk"
10) "888"
127.0.0.1:6379> ZREM zset1 abc       #刪除指定元素
(integer) 1
127.0.0.1:6379> ZRANGE zset1 0 -1 withscores
1) "aaa"
2) "5"
3) "aabc"
4) "10"
5) "bbb"
6) "88"
7) "szk"
8) "888"
127.0.0.1:6379> zrevrank zset1 szk  #返回元素的索引值,索引值從0開始,按score正向排序
(integer) 0
127.0.0.1:6379> zrank zset1 szk     #同上,不同的是,按score反序排序
(integer) 3
127.0.0.1:6379> ZCARD  zset1   #查看集合元素的個(gè)數(shù)
(integer) 4 
127.0.0.1:6379> zcount zset1 1 20   #查看分值區(qū)間內(nèi)的元素個(gè)數(shù)
(integer) 2
127.0.0.1:6379> zrangebyscore zset1 1 100 withscores   #返回分支范圍在1-100的元素
1) "aaa"
2) "5"
3) "aabc"
4) "10"
5) "bbb"
6) "88"
127.0.0.1:6379> zrangebyscore zset1 0 10    #刪除分支范圍在0-10的元素,按score排序
1) "aaa"
2) "aabc"


十九、鍵值和服務(wù)器命令

127.0.0.1:6379> keys *            #列出所有鍵值
 1) "key3"
 2) "seta"
 3) "hash2"
 4) "list1"
 5) "key2"
 6) "zset1"
 7) "mset2"
 8) "set2"
 9) "set1"
10) "key1"
11) "hash3"
12) "set3"
127.0.0.1:6379> keys key*
1) "key3"
2) "key2"
3) "key1"
127.0.0.1:6379> EXISTS list1      #查看是否有l(wèi)ist1
(integer) 1
127.0.0.1:6379> del key1      #刪除key1
(integer) 1
127.0.0.1:6379> EXISTS key1
(integer) 0
127.0.0.1:6379> EXPIRE key3 10     #設(shè)置過期時(shí)間
(integer) 1
127.0.0.1:6379> get key3
"3"
127.0.0.1:6379> ttl key3    #查看key的過期時(shí)間,-1不存在過期  -2不存儲(chǔ)鍵值
(integer) -2
127.0.0.1:6379> EXists key3
(integer) 0
127.0.0.1:6379> select 0     #切換庫(kù),默認(rèn)16個(gè)庫(kù)
OK
127.0.0.1:6379> select 1
OK
127.0.0.1:6379[1]> set key1 111   #新建一個(gè)鍵值
OK
127.0.0.1:6379[1]> keys *
1) "key1"
127.0.0.1:6379[1]> move set1 2    #移動(dòng)到庫(kù)2
(integer) 0
127.0.0.1:6379[1]> select 2     #切換庫(kù)2
OK
127.0.0.1:6379[2]> keys *    
1) "key1"
127.0.0.1:6379[2]> EXPIRE key1 200    #設(shè)置過期時(shí)間
(integer) 1
127.0.0.1:6379[2]> ttl key1
(integer) 193
127.0.0.1:6379[2]> PERSIST key1     #取消過期時(shí)間
(integer) 1
127.0.0.1:6379[2]> ttl key1
(integer) -1
127.0.0.1:6379[2]> RANDOMKEY    #隨機(jī)返回一個(gè)key
"key1"
127.0.0.1:6379[2]> RENAME key1 szk   #更改一個(gè)key的名字
OK
127.0.0.1:6379[2]> keys *
1) "szk"
127.0.0.1:6379[2]> type szk         #查看一個(gè)鍵值的類型
string

二十、服務(wù)相關(guān)的操作

127.0.0.1:6379[2]> DBSIZE    #查看一個(gè)庫(kù)的鍵值數(shù)
(integer) 1
127.0.0.1:6379[2]> select 0
OK
127.0.0.1:6379> DBSIZE 
(integer) 10
127.0.0.1:6379> info   #查看redis服務(wù)信息
# Server
redis_version:2.8.21
redis_git_sha1:00000000
略
127.0.0.1:6379> flushdb    #清空當(dāng)前數(shù)據(jù)庫(kù)中所有的鍵
OK
127.0.0.1:6379> keys *
(empty list or set)
127.0.0.1:6379> flushall   #清空所有數(shù)據(jù)庫(kù)中的所有的key
OK
127.0.0.1:6379> SELECT 1
OK
127.0.0.1:6379[1]> keys *
(empty list or set)

二十一、PHP中應(yīng)用Redis

cd /usr/local/src
wget  http://pecl.php.net/get/redis-2.2.5.tgz
tar xf redis-2.2.5.tgz
cd redis-2.2.5
/usr/local/php/bin/phpize
./configure --with-php-config=/usr/local/php/bin/php-confi
make ; make install
mv /usr/local/php/lib/php/extensions/no-debug-zts-20100525/redis.so /usr/lib64/
vim /usr/local/php/php.iniextension_dir = /usr/lib64/extension = redis.so
usr/local/php/bin/php -m | grep redisredis

## 加載成功,可以重啟 nginx 看看 phpinfo 頁(yè)


二十二、Redis實(shí)現(xiàn)session共享

  • php.ini中加入

session.save_handler = "redis"

session.save_path = "tcp://127.0.0.1:6379"

  • 或者apache虛擬主機(jī)加入

php_value session.save_handler "redis"

php_value session.save_path "tcp://127.0.0.1:6379"

  • 或者php-fpm.conf對(duì)應(yīng)的pool中加入

php_value[session.save_handler] = redis

php_value[session.save_path] = " tcp://127.0.0.1:6379 "

網(wǎng)站題目:Reidis安裝配置
轉(zhuǎn)載來源:http://m.rwnh.cn/article34/gshope.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站維護(hù)電子商務(wù)、微信小程序網(wǎng)站營(yíng)銷、動(dòng)態(tài)網(wǎng)站、全網(wǎng)營(yíng)銷推廣

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)

成都seo排名網(wǎng)站優(yōu)化
长汀县| 湖南省| 霍山县| 四子王旗| 延长县| 大邑县| 陆丰市| 高雄县| 肇东市| 嘉善县| 舞钢市| 永定县| 新郑市| 开平市| 中宁县| 密山市| 赣州市| 英吉沙县| 南投县| 苏尼特左旗| 阳信县| 建平县| 平泉县| 六安市| 南漳县| 瑞安市| 龙海市| 南溪县| 开封市| 剑河县| 巴马| 海原县| 固原市| 高清| 灵石县| 龙江县| 新郑市| 娄烦县| 南召县| 应用必备| 渝中区|