您好,登錄后才能下訂單哦!
這篇文章給大家分享的是有關(guān)redis的基本用法是什么的內(nèi)容。小編覺得挺實用的,因此分享給大家做個參考。一起跟隨小編過來看看吧。
將介紹redis的基本用法。
一、Redis基礎(chǔ)部分:
1、redis介紹與安裝比mysql快10倍以上
redis適用場合
1.取最新N個數(shù)據(jù)的操作
2.排行榜應(yīng)用,取TOP N 操作
3.需要精確設(shè)定過期時間的應(yīng)用
4.計數(shù)器應(yīng)用
5.Uniq操作,獲取某段時間所有數(shù)據(jù)排重值
6.實時系統(tǒng),反垃圾系統(tǒng)7.Pub/Sub構(gòu)建實時消息系統(tǒng)
7.Pub/Sub構(gòu)建實時消息系統(tǒng)8.構(gòu)建隊列系統(tǒng)
9.緩存
SET操作每秒鐘 110000 次,GET操作每秒鐘 81000 次,服務(wù)器配置如下:
Linux 2.6, Xeon X3320 2.5Ghz.
stackoverflow 網(wǎng)站使用 Redis 做為緩存服務(wù)器。
同時也會將數(shù)據(jù)寫到硬盤上。所以數(shù)據(jù)是安全的(除突然斷電外,重啟服務(wù)會寫到dump.rdb文件中)
1.安裝:
tar zxvf redis-2.6.9.tar.gz
cd redis-2.6.9
make
cd src && make install
2.移動配置文件位置(為了便于管理)
cd /usr/local/
mkdir -p /usr/local/redis/bin
mkdir -p /usr/local/redis/etc
mv /lamp/redis-2.6.9/redis.conf /usr/local/redis/etc
cd /lamp/redis-2.6.9/src
mv mkreleasehdr.sh redis-benchmark redis-check-aof redis-check-dump redis-cli redis-server /usr/local/redis/bin
3.修改配置文件
vi /usr/local/redis/etc/redis.conf
將daemonize no 中no改為yes[yes指后臺運行]
4.啟動/隨機(jī)啟動:
cd /usr/local/redis/bin
./redis-server /usr/local/redis/etc/redis.conf#啟動redis并指定配置文件。
#vi /etc/rc.local #設(shè)置隨機(jī)啟動。
/usr/local/redis/bin/redis-server /usr/local/redis/etc/redis.conf
5.查看是否啟動成功
ps -ef | grep redis
netstat -tunpl | grep 6379#查看端口是否占用。
6.進(jìn)入客戶端/退出
cd /usr/local/redis/bin
./redis-cli#進(jìn)入
quit#退出
7.關(guān)閉redis
pkill redis-server#關(guān)閉
./redis-cli shutdown#關(guān)閉
Redis安全
Redis的安全性???(由以下4種方式)
1.用ACL控制器安全性。
2.在redis.conf配置文件增加下面這一行配置,即可把redis綁定在單個接口上(但并不是只有接受這個網(wǎng)卡的數(shù)據(jù))。
bind 127.0.0.1
3.給redis加上較長密碼(無需要記住)
4.在redis.conf配置啟用認(rèn)證功能。
5.SSL代理
6.禁用指定命令。
Redis配置
daemonize 如果需要在后臺運行,把該項改為yes
pidfile 配置多個pid的地址 默認(rèn)在/var/run/redis.pid
bind 綁定ip,設(shè)置后只接受來自該ip的請求
port 監(jiān)聽端口,默認(rèn)為6379
timeout 設(shè)置客戶端連接時的超時時間,單位為秒
loglevel 分為4級,debug、verbose、notice、warning
logfile 配置log文件地址
databases 設(shè)置數(shù)據(jù)庫的個數(shù),默認(rèn)使用的數(shù)據(jù)庫為0
save 設(shè)置redis進(jìn)行數(shù)據(jù)庫鏡像的頻率
rdbcompression 在進(jìn)行鏡像備份時,是否進(jìn)行壓縮
Dbfilename 鏡像備份文件的文件名
Dir 數(shù)據(jù)庫鏡像備份的文件放置路徑
Slaveof 設(shè)置數(shù)據(jù)庫為其他數(shù)據(jù)庫的從數(shù)據(jù)庫
Masterauth 主數(shù)據(jù)庫連接需要的密碼驗證
Requirepass 設(shè)置登錄時需要使用的密碼
Maxclients 限制同時連接的客戶數(shù)量
Maxmemory 設(shè)置redis能夠使用的最大內(nèi)存
Appendonly 開啟append only模式
以下了解即可:
Appendfsync 設(shè)置對appendonly.aof文件同步的頻率
vm-enabled 是否開啟虛擬內(nèi)存支持
vm-swap-file 設(shè)置虛擬內(nèi)存的交換文件路徑
vm-max-memory 設(shè)置redis使用的最大物理內(nèi)存大小
vm-page-size 設(shè)置虛擬內(nèi)存的頁大小
vm-pages 設(shè)置交換文件的總的page數(shù)量
vm-max-threads 設(shè)置VM IO同時使用的線程數(shù)量
Glueoutputbuf 把小的輸出緩存存放在一起
hash-max-zipmap-entries 設(shè)置hash的臨界值
Activerehashing 重新hash
5種數(shù)據(jù)類型:字符串、哈希、鏈表、集合、有序集合。
支持:push/pop、add/remove 、取交集、并集、差集、排序。
redis<===同步====>mysql
同時也會將數(shù)據(jù)寫到硬盤上。所以數(shù)據(jù)是安全的(除突然斷電外,重啟服務(wù)會寫到dump.rdb文件中)
select num#選擇庫,默認(rèn)在0庫,共16個庫
auth liweijie#授權(quán)用戶所需密碼(密碼就是redis.conf中配置的密碼)
flushdb#清空數(shù)據(jù)庫。
String(字符串)類型:
set name lijie#設(shè)置鍵name的值為lijie
get name#獲取name的值。
keys *#查詢所有的鍵。
setnx name liweijie#如果鍵已存在則返回0,不更新,防止覆蓋。
setex haircolor 10 red #設(shè)置鍵的值的有效期為10秒。
setrange email 6 lampbre.com#替換鍵的值從第6個字符開始換為lampbre.com
mset name1 李大偉 name2 李小偉#設(shè)置多個鍵的值。
msetnxname1 張三 name3 李四#判斷鍵是否存在,不存在則設(shè)置,否則不設(shè)置返回0
mget name1 name2 name3#一次獲取多個鍵的值。
getset name1 Tom#重新設(shè)置鍵的值,并返回舊的鍵值。
getrange email 6 18#截取email鍵的值,從第6-18位間的字符。
incr uid#每次自增1 (如果key中uid不存在,則設(shè)置并從0開始,下同)
incrby uid 5#每次自增5
incrby uid -5#每次自減5
decr uid #每次自減1
decrby uid 5#每次自減5
appendname1 @126.com#給name1的值,添加字符串@126.com
strlenname1#返回鍵name1的值的長度。
Hashes(哈希)類型:
hset user:001 name liweijie#哈希設(shè)置用戶user:001的name鍵值為liweijie
hset user:001 age 21#同樣,增加一個age鍵值為21
hsetnx user:001 age 22#同上,但檢測鍵是否存在。若不存在創(chuàng)建。
hmset user:002 name liweijie2 age 26 sex 1#同時設(shè)置多個鍵的值。
hget user:001 name#哈希獲取用戶user:001的name鍵的值。
hget user:001 age #同上。
hmget user:001 name age sex#獲取多個指定的鍵的值。
hgetall user:001#獲取所有鍵的值。
hincrbyuser:001 age -8#在指定鍵上加上給定的值。
hexists user:001 sex#檢測指定的鍵值是否存在。
hlen user:001#返回指定哈希的鍵個數(shù)/字段個數(shù)。
hdel user:001 sex#刪除指定(user:001)哈希的指定字段或是鍵值。
hkeys user:003#返回哈希里所有字段或是鍵值。
Lists(鏈表)類型及操作(棧或隊列):
lpush mylist "world"#從頭部插入字符串
lpush mylist "hello"#同上
lrange mylist 0 -1#獲取從0到最后一個如[1) "hello" 2) "world"]
rpush mylist "jiejie"#在尾部插入
linsert mylist before "hello" "this is linsert" #指定插入位置(在hello之前插入)。
lset mylist 0 "what"#設(shè)置修改指定下標(biāo)的值。
lrem mylist 1 "hello"#刪除(1個)一個值為hello的元素。(n<0從尾部刪除,n=0全部刪除)
ltrim mylist 1 2 #保留表中下標(biāo)為1/2的元素。
lpop mylist#彈出開頭元素并返回。
rpop mylist#彈出尾部元素并返回。
rpoplpush mylist mylist2 #從mylist尾部彈出插入到mylist2的頭部。
lindex mylist 0#獲取表下標(biāo)為0的元素值。
llen mylist#返回表元素個數(shù)(相當(dāng)于count($arr ))。
sets(集合)類型及操作(好友推薦、blog、tag功能):
smembers myset#查看myset集合中所有元素值。
sadd myset "hello"#向mysets集合中添加一個值hello
srem myset "hello"#刪除myset集合中名稱為hello的元素。
spop myset #隨機(jī)彈出并返回mysets中的一個元素。
sdiff myset2 myset3#返回myset2中的與myset3的差集(以myset2為準(zhǔn))。
sdiffstore myset4 myset2 myset3#返回myset2中的與myset3的差集,并存入myset4中去。
sinter myset2 myset3#返回myset2與myset3的交集。
sinterstore myset5 myset2 myset3#返回myset2與myset3的交集,并存入myset5中去。
sunion myset2 myset3#求并集(去重復(fù))
sunionstore myset6 myset2 myset3#求并集,并存入myset6中去。
smove myset2 myset3 "three"#將myset2中的three移到myset3中去。
scard myset2#返回元素個數(shù)。
sismember myset2 "one"#判斷元素one是不是myset2集合的(相當(dāng)于is_array())。
srandmember myset2#隨機(jī)返回myset2集合中的一個元素,但不刪除(相當(dāng)于array_rand())。
sorted sets(有序集合)類型及操作(以scores排序):
zadd myzset 1 "one"#向順序1的添加元素one
zadd myzset 2 "two"#同上。
zadd myzset 3 "two"#相當(dāng)于更新順序為2的值
zrange myzset 0 -1 withscores#查看所有元素并帶上排序(默認(rèn)升序)。
zrem myzset "two"#刪除two
zincrby myzset 2 "two"#將two的順序值加上2
zrank myzset "two"#返回集合中元素的索引下標(biāo)值。
zrevrank myzset two#元素反轉(zhuǎn)并返回新下標(biāo)值。
zrevrange myzset 0 -1 withscores#按順序反轉(zhuǎn)(相當(dāng)于降序排序)
zrangebyscore myzset 1 10 withscores#返回順序為1-10的元素(可做分頁)。
zcount myzset 1 10 #返回順序在1-10之間元素的個數(shù)。
zcard myzset#返回集合中所有元素的個數(shù)。
zremrangebyrank myzset 1 2#刪除集合中下標(biāo)為1到2的元素。
zremrangebyscore myzset 1 10#刪除集合中順序為1到10的元素。
Redis常用命令
鍵/值相關(guān)命令。
keys * #查詢所有
keys user*#查詢指定的
exists user:001#判斷是否存在。
del name#刪除指定的鍵。
expire addr 10#設(shè)置過期時間
ttl addr#查詢過期時間
select 0 #選擇數(shù)據(jù)庫
move age 1#將age移到1數(shù)據(jù)庫。
get age #獲取
persist age#移除age的過期時間。
randomkey#隨機(jī)返回一個key
rename name1 name2#重命名鍵
type myset#返回鍵的類型。
ping #測試redis連接是否存活。
echo lamp#輸出一個lamp
select 10#選擇數(shù)據(jù)庫。
quit/exit/crtl+C#退出客戶端
dbsize#返回庫里的鍵的個數(shù)。
服務(wù)器相關(guān)命令:
info#顯示redis服務(wù)器的相關(guān)信息。
config get */loglevel #返回所有/指定的配置信息。
flushdb#刪除當(dāng)前庫中的所有鍵/表。
flushall#刪除所有數(shù)據(jù)庫中的所有鍵/表
二、Redis高級部分:
1、Redis安全性:
1.用ACL控制器安全性。
2.給redis加上較長密碼
# requirepass foobared
requirepass beijing
3.在redis.conf配置啟用認(rèn)證功能。
方式一:Auth beijing
方式二:./redis-cli -a beijing
4.在redis.conf配置文件增加下面這一行配置,即可把redis綁定在單個接口上(但并不是只有接受這個網(wǎng)卡的數(shù)據(jù))。
bind 127.0.0.1(單臺機(jī)器的時候可以配置,分布式或主從復(fù)制時最好不要配置)
5.SSL代理
6.禁用指定命令。
2、Redis主從復(fù)制:
redis只需在從服務(wù)器(slave)上配置即可:
slaveof 211.122.11.11 6379 #指定master 的ip 和端口
masterauth beijing#這是master主機(jī)的密碼
Info#查看主/從服務(wù)器的狀態(tài)。
3、Redis事務(wù)處理:
Redis事務(wù)很不完善。
4、Redis持久化機(jī)制:
1.兩種方式:一、備份數(shù)據(jù)到磁盤(快照)[ snapshotting(快照)也是默認(rèn)方式]
記錄操作命令[ Append-only file(縮寫aof)的方式]
備份數(shù)據(jù)到磁盤(快照)[ snapshotting(快照)也是默認(rèn)方式]
save 900 1 #900秒內(nèi)如果超過1個key被修改,則發(fā)起快照保存
save 300 10 #300秒內(nèi)容如超過10個key被修改,則發(fā)起快照保存
save 60 10000
二、記錄操作命令[ Append-only file(縮寫aof)的方式](較安全持久化)
appendonly yes #啟用aof 持久化方式
# appendfsync always //收到寫命令就立即寫入磁盤,最慢,但是保證完全的持久化
appendfsync everysec //每秒鐘寫入磁盤一次,在性能和持久化方面做了很好的折中
感謝各位的閱讀!關(guān)于redis的基本用法是什么就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,讓大家可以學(xué)到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到吧!
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。