redis是一個內存數據庫,比memcache支持更豐富的value類型,新浪微博就使用redis來做緩存。
redis的源碼安裝
復制代碼 代碼如下:
wget http://download.redis.io/redis-stable.tar.gz
tar -zxvf redis-stable.tar.gz
cd redis-stable
make
make test
make install
1.make時可能會報如下錯誤:
復制代碼 代碼如下:
zmalloc.o: In function `zmalloc_used_memory':
/root/redis-stable/src/zmalloc.c:223: undefined reference to `__sync_add_and_fetch_4'
collect2: ld returned 1 exit status
make[1]: *** [redis-server] Error 1
make[1]: Leaving directory `/root/redis-stable/src'
make: *** [all] Error 2
解決辦法:
編輯src/.make-settings里的OPT,改為OPT=-O2 -march=i686。2.make test報錯:
復制代碼 代碼如下:
You need tcl 8.5 or newer in order to run the Redis test
make: *** [test] Error 1
解決辦法安裝tcl
復制代碼 代碼如下:
wget http://downloads.sourceforge.net/tcl/tcl8.6.0-src.tar.gz
cd tcl8.6.0/
cd unix &&
./configure --prefix=/usr /
--mandir=/usr/share/man /
--without-tzdata /
$([ $(uname -m) = x86_64 ] && echo --enable-64bit) &&
make &&
sed -e "s@^/(TCL_SRC_DIR='/).*@/1/usr/include'@" /
-e "/TCL_B/s@='/(-L/)/?.*unix@='/1/usr/lib@" /
-i tclConfig.sh
make install &&
make install-private-headers &&
ln -v -sf tclsh8.6 /usr/bin/tclsh &&
chmod -v 755 /usr/lib/libtcl8.6.so
redis命令介紹Redis 由四個可執行文件:redis-benchmark、redis-cli、redis-server、redis-stat 這四個文件,加上一個redis.conf就構成了整個redis的最終可用包。它們的作用如下:
redis-server:Redis服務器的daemon啟動程序
redis-cli:Redis命令行操作工具。當然,你也可以用telnet根據其純文本協議來操作
redis-benchmark:Redis性能測試工具,測試Redis在你的系統及你的配置下的讀寫性能
redis-stat:Redis狀態檢測工具,可以檢測Redis當前狀態參數及延遲狀況
現在就可以啟動redis了,redis只有一個啟動參數,就是他的配置文件路徑。
啟動redis
復制源碼包里的redis.conf到/etc
復制代碼 代碼如下:
# cd redis-stable
# cp redis.conf /etc/redis.conf
編輯/etc/redis.conf ,修改daemaon no 為daemaon yes ,以守護進程方式啟動進程。
復制代碼 代碼如下:
# redis-server /etc/redis.conf
關閉redis
復制代碼 代碼如下:
# redis-cli shutdown //關閉所有
關閉某個端口上的redis
# redis-cli -p 6397 shutdown //關閉6397端口的redis
說明:關閉以后緩存數據會自動dump到硬盤上,硬盤地址見redis.conf中的dbfilename dump.rdbredis配置
注意,默認復制過去的redis.conf文件的daemonize參數為no,所以redis不會在后臺運行,這時要測試,我們需要重新開一個終端。修改為yes則為后臺運行redis。另外配置文件中規定了pid文件,log文件和數據文件的地址,如果有需要先修改,默認log信息定向到stdout.
下面是redis.conf的主要配置參數的意義:
復制代碼 代碼如下:
daemonize:是否以后臺daemon方式運行
pidfile:pid文件位置
port:監聽的端口號
timeout:請求超時時間
loglevel:log信息級別
logfile:log文件位置
databases:開啟數據庫的數量
save * *:保存快照的頻率,第一個*表示多長時間,第三個*表示執行多少次寫操作。在一定時間內執行一定數量的寫操作時,自動保存快照。可設置多個條件。
rdbcompression:是否使用壓縮
dbfilename:數據快照文件名(只是文件名,不包括目錄)
dir:數據快照的保存目錄(這個是目錄)
appendonly:是否開啟appendonlylog,開啟的話每次寫操作會記一條log,這會提高數據抗風險能力,但影響效率。
appendfsync:appendonlylog如何同步到磁盤(三個選項,分別是每次寫都強制調用fsync、每秒啟用一次fsync、不調用fsync等待系統自己同步)
這時你可以打開一個終端進行測試了,配置文件中默認的監聽端口是6379
redis開機自動啟動
用這個腳本管理之前,需要先配置下面的內核參數,否則Redis腳本在重啟或停止redis時,將會報錯,并且不能自動在停止服務前同步數據到磁盤上:
復制代碼 代碼如下:
# vi /etc/sysctl.conf
vm.overcommit_memory = 1
然后應用生效:
復制代碼 代碼如下: