JEESZ-Redis分佈式緩存安裝和使用

獨立緩存服務器: Linux CentOS

Redis 版本: 3.0

下面我們針對於
Redis安裝做下詳細的記錄:

編譯和安裝所需的包:
yum install gcc tcl
創建安裝目錄:
mkdir /usr/local/redis
   
解壓:
tar -zxvf 3.xx.tar.gz
mv redis-3.xx redis3.0
cd redis3.0
安裝(使用 PREFIX 指定安裝目錄)
make PREFIX=/usr/local/redis install
安裝完成後,可以看到/usr/local/redis 目錄下有一個 bin 目錄,bin目錄裏就是 redis 的命令腳本:
redis-benchmark redis-check-aof redis-check-dumpredis-cli redis-server
  
Redis 配置成服務:
按上面的操作步驟,Redis 的啓動腳本爲:/usr/local/src/redis3.0/utils/redis_init_script
將啓動腳本複製到/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,修改相應配置,使之能註冊成爲服務:
# 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 服務腳本,關注標爲橙色的幾個屬性,做如下幾個修改的準備:
(1) 
在腳本的第一行後面添加一行內容如下:
     #chkconfig: 2345 80 90
    
提醒:如果不添加上面的內容,在註冊服務時會提示:service redis does not support chkconfig
(2) REDISPORT 
端口保持 6379 不變;(特別注意:端口名將與下面的配置文件名有關)
(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) 
配置文件設置:
創建redis 配置文件目錄
mkdir /usr/local/redis/conf
複製redis 配置文件/usr/local/src/redis3.0/redis.conf /usr/local/redis/conf 目錄並按端口號重命名爲6379.conf
cp /usr/local/src/redis3.0/redis.conf/usr/local/redis/conf/6379.conf
做了以上準備後,再對 CONF 屬性作如下調整:
CONF="/etc/redis/${REDISPORT}.conf"
改爲CONF="/usr/local/redis/conf/${REDISPORT}.conf"
(6) 
更改redis 開啓的命令,以後臺運行的方式執行:
$EXEC $CONF &
   #“&”作用是將服務轉到後面運行

修改後的/etc/rc.d/init.d/redis 服務腳本內容爲:
#!/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 註冊成爲服務:
chkconfig --add redis

防火牆中打開對應的端口
vi /etc/sysconfig/iptables
添加:
-A INPUT -m state --state NEW -m tcp -p tcp --dport6379 -j ACCEPT
重啓防火牆:
service iptables restart

修改redis 配置文件設置:
vi /usr/local/redis/conf/6379.conf
修改如下配置
daemonize no 
改爲 daemonize yes
備註:如果不改爲yespid文件是不會生成,startstop命令是不會生效的(依賴pid文件)
pidfile /var/run/redis.pid 
改爲 pidfile /var/run/redis_6379.pid

啓動Redis 服務
service redis start

Redis 添加到環境變量中:
vi /etc/profile
在最後添加以下內容:
## Redis env
export PATH=$PATH:/usr/local/redis/bin

使配置生效:
source /etc/profile

當前可以直接使用 redis-cli redis 命令了:
redis-cli
圖片
關閉Redis 服務
service redis stop
提醒:默認情況下,Redis 開啓安全認證,可以通過/usr/local/redis/conf/6379.conf  requirepass 指定一個驗證密碼 

在jeesz中主要使用redis做分佈式緩存,存儲登錄用戶信息,做session共享管理

圖片

源碼來源:原文出處請點擊這裏

歡迎大家一起學習研究相關技術,源碼獲取請加求求(企鵝): 2042849237

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章