1) 什么是Redis
REmote DIctionary Server(Redis) 是一個由Salvatore Sanfilippo寫的key-value存儲系統。
Redis是一個開源的使用ANSI C語言編寫、遵守BSD協議、支持網絡、可基于內存亦可持久化的日志型、Key-Value數據庫,并提供多種語言的API。
它通常被稱為數據結構服務器,因為值(value)可以是 字符串(String), 哈希(Map), 列表(list), 集合(sets) 和 有序集合(sorted sets)等類型。
2) Redis簡介
Redis 是完全開源免費的,遵守BSD協議,是一個高性能的key-value數據庫。
Redis 與其他 key - value 緩存產品有以下三個特點:
- Redis支持數據的持久化,可以將內存中的數據保存在磁盤中,重啟的時候可以再次加載進行使用。
- Redis不僅僅支持簡單的key-value類型的數據,同時還提供list,set,zset,hash等數據結構的存儲。
- Redis支持數據的備份,即master-slave模式的數據備份。
3) Redis用處
定時器、計數器
發布、訂閱消息系統
模擬類似于HttpSession這種需要設定過期時間的功能
取最新N個數據的操作,如:可以將最新的10條評論的ID放在Redis的List集合里面
內存存儲和持久化:redis支持異步將內存中的數據寫到硬盤上,同時不影響繼續服務
4) Redis 優勢
性能極高 – Redis能讀的速度是110000次/s,寫的速度是81000次/s 。
豐富的數據類型 – Redis支持二進制案例的 Strings, Lists, Hashes, Sets 及 Ordered Sets 數據類型操作。
原子 – Redis的所有操作都是原子性的,同時Redis還支持對幾個操作全并后的原子性執行。
豐富的特性 – Redis還支持 publish/subscribe, 通知, key 過期等等特性。
5) Redis與其他key-value存儲有什么不同?
Redis有著更為復雜的數據結構并且提供對他們的原子性操作,這是一個不同于其他數據庫的進化路徑。Redis的數據類型都是基于基本數據結構的同時對程序員透明,無需進行額外的抽象。
Redis運行在內存中但是可以持久化到磁盤,所以在對不同數據集進行高速讀寫時需要權衡內存,因為數據量不能大于硬件內存。在內存數據庫方面的另一個優點是,相比在磁盤上相同的復雜的數據結構,在內存中操作起來非常簡單,這樣Redis可以做很多內部復雜性很強的事情。同時,在磁盤格式方面他們是緊湊的以追加的方式產生的,因為他們并不需要進行隨機訪問
6)Windows下安裝
不建議在Windows下使用Redis
Redis 支持 32 位和 64 位。這個需要根據你系統平臺的實際情況選擇,這里我們下載 Redis-x643.2.100.zip壓縮包到 C 盤,解壓后,將文件夾重新命名為 redis。
打開一個 cmd 窗口 使用cd命令切換目錄到 C:\redis 運行 redis-server.exe redis.windows.conf 。
如果想方便的話,可以把 redis 的路徑加到系統的環境變量(本人測試,未能成功,可能是未配置正確)里,這樣就省得再輸路徑了,后面的那個 redis.windows.conf 可以省略,如果省略,會啟用默認的。輸入之后,會顯示如下界面:
這時候另啟一個cmd窗口,原來的命令窗口不要關閉,不然就無法訪問服務端了。
切換到redis(c:/redis/)目錄下運行 redis-cli.exe -h 127.0.0.1 -p 6379 。
設置鍵值對 set myKey abc
取出鍵值對 get myKey
7) Linux 下安裝
下載并安裝:
- 直接下載
$ wget http://download.redis.io/releases/redis-3.2.6.tar.gz
- 解壓縮
$ tar -zxvf redis-3.2.6.tar.gz
- 切換到相應目錄
$ cd redis-3.2.6
- 安裝linux
$ make
-在執行make 命令時,可能出現如下錯誤
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] 錯誤 127
make[3]: Leaving directory `/home/redis-3.0.4/deps/hiredis'
make[2]: *** [hiredis] 錯誤 2
make[2]: Leaving directory `/home/redis-3.0.4/deps'
make[1]: [persist-settings] 錯誤 2 (忽略)
CC adlist.o
/bin/sh: cc: command not found
make[1]: *** [adlist.o] 錯誤 127
make[1]: Leaving directory `/home/redis-3.0.4/src'
make: *** [all] 錯誤 2
這是由于Linux中沒有gcc環境導致.
Centos支持使用yum安裝,安裝軟件一般格式為yum install .......,注意安裝時要先成為root用戶,且在聯網的狀態下。
使用yum安裝gcc:yum install gcc即可。
使用:which gcc 查看是否安裝成功
- make完后,redis-3.2.6目錄下會出現編譯后的redis服務程序redis-server,還有用于測試的客戶端程序redis-cli,兩個程序位于安裝目錄 src 目錄下:
- 在redis-3.2.6同級目錄中新建myRedis文件夾,并將redis-3.2.6目錄下的redis.conf文件復制到myRedis文件夾下
- 修改myRedis目錄下的redis.conf,將紅色部分no修改為yes
- 查看redis是否啟動
下面啟動redis服務.
- 切換到redis的src目錄下,輸入如下命令
- 如果daemonize設置為no,啟動redis,顯示如下,為yes則不顯示
- 切換到redis客戶端
- 啟動redis服務進程后,就可以使用測試客戶端程序redis-cli和redis服務交互了。 比如:
8) Ubuntu 下安裝
- 在 Ubuntu 系統安裝 Redi 可以使用以下命令:
$sudo apt-get update$sudo apt-get install redis-server
啟動 Redis
$ redis-server
查看 redis 是否啟動?
$ redis-cli
以上命令將打開以下終端:
redis 127.0.0.1:6379>
127.0.0.1 是本機 IP ,6379 是 redis 服務端口。現在我們輸入 PING 命令。
redis 127.0.0.1:6379> ping
PONG
以上說明我們已經成功安裝了redis
關閉
單實例關閉:redis-cli shutdown
多實例關閉,指定端口關閉:redis-cli -p 6379 shutdown