分佈式緩存Redis Centos下單節點安裝

聲明: 網上關於分佈式緩存Redis的學習資料很多,大家可以去網上找些資料去學習。

另外 JEESZ框架面向企業的大型互聯網分佈式企業架構,分佈式緩存是必不可少的,故這邊總結了一些關於分佈式緩存Redis的實戰文章作爲後期JEESZ分佈式框架的教程,希望也可以幫助到大家,請勿吐槽。

Redis官網:http://redis.io

獨立緩存服務器:IP:xxx.xxx.xxx.xxx

安裝環境:CentOS 6.6

Redis 版本:redis-3.0(因爲 Redis3.0 在集羣和性能提升方面的特性,rc 版爲正式版的候選版,請在安裝時去官網選用最新版)

用戶:root

安裝目錄:/usr/local/redis

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

編譯和安裝所需的包:

#yum install gcc tcl

提醒:下載 3.0 版 Redis(當前最新版 redis-3.0.0-rc5.tar.gz,請在安裝時去官網選用最新版)

#cd /usr/local/src

#wgethttps://github.com/antirez/redis/archive/3.0.0-rc5.tar.gz

提醒:此路徑可以通過官網去下載目錄copy

創建安裝目錄:

#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 目錄下有一個 bin 目錄,bin 目錄裏就是 redis 的命令腳本:

redis-benchmark redis-check-aof redis-check-dump redis-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

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 --dport 6379 -j ACCEPT

重啓防火牆:

#service iptables restart

修改 redis 配置文件設置:

#vi /usr/local/redis/conf/6379.conf

修改如下配置

daemonizeno改爲 daemonizeyes

備註:如果不改爲yes,pid文件是不會生成,start、stop命令是不會生效的(依賴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 指定一個

驗證密碼

歡迎大家一起學習研究相關技術,更多詳細源碼參考來源貳零四貳八四九貳叄柒

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