聲明: 網(wǎng)上關(guān)于分布式緩存Redis的學(xué)習(xí)資料很多,大家可以去網(wǎng)上找些資料去學(xué)習(xí)吞杭。
另外 JEESZ框架面向企業(yè)的大型互聯(lián)網(wǎng)分布式企業(yè)架構(gòu)盏浇,分布式緩存是必不可少的,故這邊總結(jié)了一些關(guān)于分布式緩存Redis的實(shí)戰(zhàn)文章作為后期JEESZ分布式框架的教程芽狗,希望也可以幫助到大家绢掰,請勿吐槽。
Redis官網(wǎng):http://redis.io
獨(dú)立緩存服務(wù)器:IP:xxx.xxx.xxx.xxx
安裝環(huán)境:CentOS 6.6
Redis 版本:redis-3.0(因?yàn)?Redis3.0 在集群和性能提升方面的特性童擎,rc 版為正式版的候選版滴劲,請?jiān)诎惭b時(shí)去官網(wǎng)選用最新版)
用戶:root
安裝目錄:/usr/local/redis
下面我們針對(duì)于Redis安裝做下詳細(xì)的記錄:
編譯和安裝所需的包:
#yum install gcc tcl
提醒:下載 3.0 版 Redis(當(dāng)前最新版 redis-3.0.0-rc5.tar.gz,請?jiān)诎惭b時(shí)去官網(wǎng)選用最新版)
#cd /usr/local/src
#wgethttps://github.com/antirez/redis/archive/3.0.0-rc5.tar.gz
提醒:此路徑可以通過官網(wǎng)去下載目錄copy
創(chuàng)建安裝目錄:
#mkdir /usr/local/redis
解壓:
#tar -zxvf 3.0.0-rc5.tar.gz
#mv redis-3.0.0-rc5 redis3.0
#cd redis3.0
安裝(使用 PREFIX 指定安裝目錄):
#make PREFIX=/usr/local/redis install
安裝完成后顾复,可以看到/usr/local/redis 目錄下有一個(gè) bin 目錄班挖,bin 目錄里就是 redis 的命令腳本:
redis-benchmark redis-check-aof redis-check-dump redis-cli redis-server
將 Redis 配置成服務(wù):
按上面的操作步驟,Redis 的啟動(dòng)腳本為:/usr/local/src/redis3.0/utils/redis_init_script
將啟動(dòng)腳本復(fù)制到/etc/rc.d/init.d/目錄下芯砸,并命名為redis
#cp /usr/local/src/redis3.0/utils/redis_init_script /etc/rc.d/init.d/redis
編輯/etc/rc.d/init.d/redis萧芙,修改相應(yīng)配置,使之能注冊成為服務(wù):
#vi /etc/rc.d/init.d/redis
#!/bin/sh
#
# Simple Redis init.d script conceived to work on Linux systems
# as it does use of the /proc filesystem.
REDISPORT=6379
EXEC=/usr/local/bin/redis-server
CLIEXEC=/usr/local/bin/redis-cli
PIDFILE=/var/run/redis_${REDISPORT}.pid
CONF="/etc/redis/${REDISPORT}.conf"
case "$1" in
start)
if [ -f $PIDFILE ]
then
echo "$PIDFILE exists, process is already running or crashed"
else
echo "Starting Redis server..."
$EXEC $CONF
fi
;;
stop)
if [ ! -f $PIDFILE ]
then
echo "$PIDFILE does not exist, process is not running"
else
PID=$(cat $PIDFILE)
echo "Stopping ..."
$CLIEXEC -p $REDISPORT shutdown
while [ -x /proc/${PID} ]
do
echo "Waiting for Redis to shutdown ..."
sleep 1
done
echo "Redis stopped"
fi
;;
*)
echo "Please use start or stop as first argument"
;;
esac
查看以上 redis 服務(wù)腳本假丧,關(guān)注標(biāo)為橙色的幾個(gè)屬性双揪,做如下幾個(gè)修改的準(zhǔn)備:
(1) 在腳本的第一行后面添加一行內(nèi)容如下:
#chkconfig: 2345 80 90
提醒:如果不添加上面的內(nèi)容,在注冊服務(wù)時(shí)會(huì)提示:service redis does not support chkconfig
(2)REDISPORT端口保持6379不變虎谢;(特別注意:端口名將與下面的配置文件名有關(guān))
(3)EXEC=/usr/local/bin/redis-server 改為EXEC=/usr/local/redis/bin/redis-server
(4)CLIEXEC=/usr/local/bin/redis-cli 改為CLIEXEC=/usr/local/redis/bin/redis-cli
(5) 配置文件設(shè)置:
創(chuàng)建 redis 配置文件目錄
#mkdir /usr/local/redis/conf
復(fù)制 redis 配置文件/usr/local/src/redis3.0/redis.conf到/usr/local/redis/conf目錄并按端口號(hào)重命名為6379.conf
#cp /usr/local/src/redis3.0/redis.conf /usr/local/redis/conf/6379.conf
做了以上準(zhǔn)備后盟榴,再對(duì) CONF 屬性作如下調(diào)整:
CONF="/etc/redis/${REDISPORT}.conf" 改為 CONF="/usr/local/redis/conf/${REDISPORT}.conf"
(6) 更改 redis 開啟的命令,以后臺(tái)運(yùn)行的方式執(zhí)行:
$EXEC $CONF&#“&”作用是將服務(wù)轉(zhuǎn)到后面運(yùn)行
修改后的/etc/rc.d/init.d/redis 服務(wù)腳本內(nèi)容為:
#!/bin/sh
#chkconfig: 2345 80 90
#
# Simple Redis init.d script conceived to work on Linux systems
# as it does use of the /proc filesystem.
REDISPORT=6379
EXEC=/usr/local/redis/bin/redis-server
CLIEXEC=/usr/local/redis/bin/redis-cli
PIDFILE=/var/run/redis_${REDISPORT}.pid
CONF="/usr/local/redis/conf/${REDISPORT}.conf"
case "$1" in
start)
if [ -f $PIDFILE ]
then
echo "$PIDFILE exists, process is already running or crashed"
else
echo "Starting Redis server..."
$EXEC $CONF&
fi
;;
stop)
if [ ! -f $PIDFILE ]
then
echo "$PIDFILE does not exist, process is not running"
else
PID=$(cat $PIDFILE)
echo "Stopping ..."
$CLIEXEC -p $REDISPORT shutdown
while [ -x /proc/${PID} ]
do
echo "Waiting for Redis to shutdown ..."
sleep 1
done
echo "Redis stopped"
fi
;;
*)
echo "Please use start or stop as first argument"
;;
esac
以上配置操作完成后婴噩,便可將 Redis 注冊成為服務(wù):
#chkconfig --add redis
防火墻中打開對(duì)應(yīng)的端口
#vi /etc/sysconfig/iptables
添加:
-A INPUT -m state --state NEW -m tcp -p tcp --dport 6379 -j ACCEPT
重啟防火墻:
#service iptables restart
修改 redis 配置文件設(shè)置:
#vi /usr/local/redis/conf/6379.conf
修改如下配置
daemonizeno改為 daemonizeyes
備注:如果不改為yes,pid文件是不會(huì)生成羽德,start几莽、stop命令是不會(huì)生效的(依賴pid文件)
pidfile /var/run/redis.pid 改為 pidfile /var/run/redis_6379.pid
啟動(dòng) Redis 服務(wù)
#service redis start
將 Redis 添加到環(huán)境變量中:
#vi /etc/profile
在最后添加以下內(nèi)容:
## Redis env
export PATH=$PATH:/usr/local/redis/bin
使配置生效:
#source /etc/profile
當(dāng)前可以直接使用 redis-cli 等 redis 命令了:
#redis-cli
關(guān)閉 Redis 服務(wù)
#service redis stop
提醒:默認(rèn)情況下,Redis 開啟安全認(rèn)證宅静,可以通過/usr/local/redis/conf/6379.conf 的 requirepass 指定一個(gè)
驗(yàn)證密碼
歡迎大家一起學(xué)習(xí)研究相關(guān)技術(shù),更多詳細(xì)源碼參考來源:http://minglisoft.cn/technology