1) 什么是Redis
REmote DIctionary Server(Redis) 是一個(gè)由Salvatore Sanfilippo寫的key-value存儲(chǔ)系統(tǒng)。
Redis是一個(gè)開源的使用ANSI C語(yǔ)言編寫虑灰、遵守BSD協(xié)議吨瞎、支持網(wǎng)絡(luò)、可基于內(nèi)存亦可持久化的日志型穆咐、Key-Value數(shù)據(jù)庫(kù)颤诀,并提供多種語(yǔ)言的API。
它通常被稱為數(shù)據(jù)結(jié)構(gòu)服務(wù)器对湃,因?yàn)橹担╲alue)可以是 字符串(String), 哈希(Map), 列表(list), 集合(sets) 和 有序集合(sorted sets)等類型崖叫。
2) Redis簡(jiǎn)介
Redis 是完全開源免費(fèi)的,遵守BSD協(xié)議拍柒,是一個(gè)高性能的key-value數(shù)據(jù)庫(kù)心傀。
Redis 與其他 key - value 緩存產(chǎn)品有以下三個(gè)特點(diǎn):
- Redis支持?jǐn)?shù)據(jù)的持久化,可以將內(nèi)存中的數(shù)據(jù)保存在磁盤中拆讯,重啟的時(shí)候可以再次加載進(jìn)行使用脂男。
- Redis不僅僅支持簡(jiǎn)單的key-value類型的數(shù)據(jù),同時(shí)還提供list种呐,set宰翅,zset,hash等數(shù)據(jù)結(jié)構(gòu)的存儲(chǔ)爽室。
- Redis支持?jǐn)?shù)據(jù)的備份汁讼,即master-slave模式的數(shù)據(jù)備份。
3) Redis用處
定時(shí)器阔墩、計(jì)數(shù)器
發(fā)布嘿架、訂閱消息系統(tǒng)
模擬類似于HttpSession這種需要設(shè)定過(guò)期時(shí)間的功能
取最新N個(gè)數(shù)據(jù)的操作,如:可以將最新的10條評(píng)論的ID放在Redis的List集合里面
內(nèi)存存儲(chǔ)和持久化:redis支持異步將內(nèi)存中的數(shù)據(jù)寫到硬盤上戈擒,同時(shí)不影響繼續(xù)服務(wù)
4) Redis 優(yōu)勢(shì)
性能極高 – Redis能讀的速度是110000次/s,寫的速度是81000次/s 眶明。
豐富的數(shù)據(jù)類型 – Redis支持二進(jìn)制案例的 Strings, Lists, Hashes, Sets 及 Ordered Sets 數(shù)據(jù)類型操作。
原子 – Redis的所有操作都是原子性的筐高,同時(shí)Redis還支持對(duì)幾個(gè)操作全并后的原子性執(zhí)行搜囱。
豐富的特性 – Redis還支持 publish/subscribe, 通知, key 過(guò)期等等特性丑瞧。
5) Redis與其他key-value存儲(chǔ)有什么不同?
Redis有著更為復(fù)雜的數(shù)據(jù)結(jié)構(gòu)并且提供對(duì)他們的原子性操作蜀肘,這是一個(gè)不同于其他數(shù)據(jù)庫(kù)的進(jìn)化路徑绊汹。Redis的數(shù)據(jù)類型都是基于基本數(shù)據(jù)結(jié)構(gòu)的同時(shí)對(duì)程序員透明,無(wú)需進(jìn)行額外的抽象扮宠。
Redis運(yùn)行在內(nèi)存中但是可以持久化到磁盤西乖,所以在對(duì)不同數(shù)據(jù)集進(jìn)行高速讀寫時(shí)需要權(quán)衡內(nèi)存,因?yàn)閿?shù)據(jù)量不能大于硬件內(nèi)存坛增。在內(nèi)存數(shù)據(jù)庫(kù)方面的另一個(gè)優(yōu)點(diǎn)是获雕,相比在磁盤上相同的復(fù)雜的數(shù)據(jù)結(jié)構(gòu),在內(nèi)存中操作起來(lái)非常簡(jiǎn)單收捣,這樣Redis可以做很多內(nèi)部復(fù)雜性很強(qiáng)的事情届案。同時(shí),在磁盤格式方面他們是緊湊的以追加的方式產(chǎn)生的罢艾,因?yàn)樗麄儾⒉恍枰M(jìn)行隨機(jī)訪問(wèn)
6)Windows下安裝
不建議在Windows下使用Redis
Redis 支持 32 位和 64 位楣颠。這個(gè)需要根據(jù)你系統(tǒng)平臺(tái)的實(shí)際情況選擇,這里我們下載 Redis-x643.2.100.zip壓縮包到 C 盤咐蚯,解壓后童漩,將文件夾重新命名為 redis。
打開一個(gè) cmd 窗口 使用cd命令切換目錄到 C:\redis 運(yùn)行 redis-server.exe redis.windows.conf 春锋。
如果想方便的話矫膨,可以把 redis 的路徑加到系統(tǒng)的環(huán)境變量(本人測(cè)試,未能成功,可能是未配置正確)里,這樣就省得再輸路徑了看疙,后面的那個(gè) redis.windows.conf 可以省略豆拨,如果省略,會(huì)啟用默認(rèn)的能庆。輸入之后施禾,會(huì)顯示如下界面:
這時(shí)候另啟一個(gè)cmd窗口,原來(lái)的命令窗口不要關(guān)閉搁胆,不然就無(wú)法訪問(wèn)服務(wù)端了弥搞。
切換到redis(c:/redis/)目錄下運(yùn)行 redis-cli.exe -h 127.0.0.1 -p 6379 。
設(shè)置鍵值對(duì) set myKey abc
取出鍵值對(duì) get myKey
7) Linux 下安裝
下載并安裝:
- 直接下載
$ wget http://download.redis.io/releases/redis-3.2.6.tar.gz
- 解壓縮
$ tar -zxvf redis-3.2.6.tar.gz
- 切換到相應(yīng)目錄
$ cd redis-3.2.6
- 安裝linux
$ make
-在執(zhí)行make 命令時(shí),可能出現(xiàn)如下錯(cuò)誤
cd src && make all
make[1]: Entering directory `/home/redis-3.0.4/src'
rm -rf redis-server redis-sentinel redis-cli redis-benchmark redis-check-dump redis-check-aof *.o *.gcda *.gcno *.gcov redis.info lcov-html
(cd ../deps && make distclean)
make[2]: Entering directory `/home/redis-3.0.4/deps'
(cd hiredis && make clean) > /dev/null || true
(cd linenoise && make clean) > /dev/null || true
(cd lua && make clean) > /dev/null || true
(cd jemalloc && [ -f Makefile ] && make distclean) > /dev/null || true
(rm -f .make-*)
make[2]: Leaving directory `/home/redis-3.0.4/deps'
(rm -f .make-*)
echo STD=-std=c99 -pedantic >> .make-settings
echo WARN=-Wall -W >> .make-settings
echo OPT=-O2 >> .make-settings
echo MALLOC=jemalloc >> .make-settings
echo CFLAGS= >> .make-settings
echo LDFLAGS= >> .make-settings
echo REDIS_CFLAGS= >> .make-settings
echo REDIS_LDFLAGS= >> .make-settings
echo PREV_FINAL_CFLAGS=-std=c99 -pedantic -Wall -W -O2 -g -ggdb -I../deps/hiredis -I../deps/linenoise -I../deps/lua/src -DUSE_JEMALLOC -I../deps/jemalloc/include >> .make-settings
echo PREV_FINAL_LDFLAGS= -g -ggdb -rdynamic >> .make-settings
(cd ../deps && make hiredis linenoise lua jemalloc)
make[2]: Entering directory `/home/redis-3.0.4/deps'
(cd hiredis && make clean) > /dev/null || true
(cd linenoise && make clean) > /dev/null || true
(cd lua && make clean) > /dev/null || true
(cd jemalloc && [ -f Makefile ] && make distclean) > /dev/null || true
(rm -f .make-*)
(echo "" > .make-ldflags)
(echo "" > .make-cflags)
MAKE hiredis
cd hiredis && make static
make[3]: Entering directory `/home/redis-3.0.4/deps/hiredis'
gcc -std=c99 -pedantic -c -O3 -fPIC -Wall -W -Wstrict-prototypes -Wwrite-strings -g -ggdb net.c
make[3]: gcc:命令未找到
make[3]: *** [net.o] 錯(cuò)誤 127
make[3]: Leaving directory `/home/redis-3.0.4/deps/hiredis'
make[2]: *** [hiredis] 錯(cuò)誤 2
make[2]: Leaving directory `/home/redis-3.0.4/deps'
make[1]: [persist-settings] 錯(cuò)誤 2 (忽略)
CC adlist.o
/bin/sh: cc: command not found
make[1]: *** [adlist.o] 錯(cuò)誤 127
make[1]: Leaving directory `/home/redis-3.0.4/src'
make: *** [all] 錯(cuò)誤 2
這是由于Linux中沒(méi)有g(shù)cc環(huán)境導(dǎo)致.
Centos支持使用yum安裝渠旁,安裝軟件一般格式為yum install .......攀例,注意安裝時(shí)要先成為root用戶,且在聯(lián)網(wǎng)的狀態(tài)下顾腊。
使用yum安裝gcc:yum install gcc即可粤铭。
使用:which gcc 查看是否安裝成功
- make完后,redis-3.2.6目錄下會(huì)出現(xiàn)編譯后的redis服務(wù)程序redis-server,還有用于測(cè)試的客戶端程序redis-cli,兩個(gè)程序位于安裝目錄 src 目錄下:
- 在redis-3.2.6同級(jí)目錄中新建myRedis文件夾,并將redis-3.2.6目錄下的redis.conf文件復(fù)制到myRedis文件夾下
- 修改myRedis目錄下的redis.conf,將紅色部分no修改為yes
- 查看redis是否啟動(dòng)
下面啟動(dòng)redis服務(wù).
- 切換到redis的src目錄下,輸入如下命令
- 如果daemonize設(shè)置為no,啟動(dòng)redis,顯示如下,為yes則不顯示
- 切換到redis客戶端
- 啟動(dòng)redis服務(wù)進(jìn)程后,就可以使用測(cè)試客戶端程序redis-cli和redis服務(wù)交互了杂靶。 比如:
8) Ubuntu 下安裝
- 在 Ubuntu 系統(tǒng)安裝 Redi 可以使用以下命令:
$sudo apt-get update$sudo apt-get install redis-server
啟動(dòng) Redis
$ redis-server
查看 redis 是否啟動(dòng)梆惯?
$ redis-cli
以上命令將打開以下終端:
redis 127.0.0.1:6379>
127.0.0.1 是本機(jī) IP 酱鸭,6379 是 redis 服務(wù)端口。現(xiàn)在我們輸入 PING 命令垛吗。
redis 127.0.0.1:6379> ping
PONG
以上說(shuō)明我們已經(jīng)成功安裝了redis
關(guān)閉
單實(shí)例關(guān)閉:redis-cli shutdown
多實(shí)例關(guān)閉凹髓,指定端口關(guān)閉:redis-cli -p 6379 shutdown