linux下redis的安装及配置启动

脚本功能:

       实现redis单机多实例情况下的正常启动、关闭、重启单个redis实例。完成系统标准服务的以下常用功能:  start|stop|status|restart

   注:redis程序代码屏蔽了HUP信号,不支持在线重载配置文件,故去掉reload功能。

             本脚本优化了redis停止和重启逻辑,解决原redis脚本关闭时会造成数据丢失问题。

 

脚本名称:

        redis           #在多实例里可以按实例端口,:redis-6001命名,以区分不同实例

 

脚本用法:

1./etc/rc.d/init.d/目录下新建redis文件,将脚本内容拷贝进去

2.  chkconfig --add redis   #注册服务

3. chkconfig --level 345 redis on  #指定服务在345级别运行

4.本人redis程序安装在/opt/redis-3.0.3目录下,配置为/opt/redis-3.0.3/redis.conf,如安装在其他目录,请自行修改

===================================================================================

在运行这个脚本的时候,发生了一个小插曲,我在windows下编辑然后再传到debian机器上,结果就报错了
# /etc/init.d/redis start

-bash: /etc/init.d/redis: /bin/sh^M: bad interpreter: No such file or directory
后来发现原因:sh对DOS格式(windows下编辑器默认格式)的文本解析有问题

解决方法:将DOS格式转换为UNIX格式
vim redis 

:set ff    查看当前文本格式
 fileformat=dos 

:set ff=unix 设置当前文本格式
:wq

===================================================================================


脚本参数:

        redis -p [port]  [start|stop|status|restart]

              参数说明:

          -p [port] : 指定redis实例的端口,用于多实例的服务器

         start:启动指定端口的Redis服务

         stop:停止指定端口的Redis服务

        status:进程状态

       restart:先关闭Redis服务,再启动Redis服务

      注:不指定端口时,脚本默认指定启动6379端口的redis

用法实例:

    service redis -p 6381 start  #启动6381端口实例的redis

   /etc/init.d/redis  start  #默认启动6379端口实例的redis

脚本内容:

#!/bin/bash
#chkconfig: 2345 55 25
#description: Starts,stops and restart the redis-server
#Ver:1.1  
#Write by ND chengh(200808)
#usage: ./script_name -p [port] {start|stop|status|restart}

# Source function library.
. /etc/rc.d/init.d/functions

# Source networking configuration.
. /etc/sysconfig/network

# Check networking is up.
[ "$NETWORKING" = "no" ] && exit 0

RETVAL=0
REDIS_PORT=6379
PID=

if [ "$1" = "-p" ]; then
    REDIS_PORT=$2
    shift 2
fi

REDIS_DIR="/opt/redis-3.0.3"
REDIS="${REDIS_DIR}/src/redis-server"
PROG=$(basename $REDIS)

CONF="${REDIS_DIR}/redis-${REDIS_PORT}.conf"

if [ ! -f $CONF ]; then
   if [ -f "${REDIS_DIR}/redis.conf" ];then
      CONF="${REDIS_DIR}/redis.conf"
   else
      echo -n $"$CONF not exist.";warning;echo
      exit 1
   fi
fi

PID_FILE=`grep "pidfile" ${CONF}|cut -d ' ' -f2`
PID_FILE=${PID_FILE:=/var/run/redis.pid}
LOCKFILE="/var/lock/subsys/redis-${REDIS_PORT}"

if [ ! -x $REDIS ]; then
    echo -n $"$REDIS not exist.";warning;echo
    exit 0
fi


start() {

    echo -n $"Starting $PROG: "
    $REDIS $CONF
    RETVAL=$?
    if [ $RETVAL -eq 0 ]; then
        success;echo;touch $LOCKFILE
    else
        failure;echo
    fi
    return $RETVAL

}

stop() {

    echo -n $"Stopping $PROG: "

    if [ -f $PID_FILE ] ;then
       read PID <  "$PID_FILE" 
    else 
       failure;echo;
       echo -n $"$PID_FILE not found.";failure;echo
       return 1;
    fi

    if checkpid $PID; then
     kill -TERM $PID >/dev/null 2>&1
        RETVAL=$?
        if [ $RETVAL -eq 0 ] ;then
                success;echo 
                echo -n "Waiting for Redis to shutdown .."
         while checkpid $PID;do
                 echo -n "."
                 sleep 1;
                done
                success;echo;rm -f $LOCKFILE
        else 
                failure;echo
        fi
    else
        echo -n $"Redis is dead and $PID_FILE exists.";failure;echo
        RETVAL=7
    fi    
    return $RETVAL

}

restart() {
    stop
    start
}

rhstatus() {
    status -p ${PID_FILE} $PROG
}

hid_status() {
    rhstatus >/dev/null 2>&1
}

case "$1" in
    start)
        hid_status && exit 0
        start
        ;;
    stop)
        rhstatus || exit 0
        stop
        ;;
    restart)
        restart
        ;;
    status)
        rhstatus
        RETVAL=$?
        ;;
    *)
        echo $"Usage: $0 -p [port] {start|stop|status|restart}"
        RETVAL=1
esac

exit $RETVAL


基本数据类型及数据命名特点
redis采用key-value的形式存储数据, key就是数据的名字, value就是数据的值。

其中value可以有以下5种类型

(1)string字符串类型 :string可以看作byte 数组,最大上限是 1G字节 ,更多操作见help @string
(2)list列表类型: 每个子元素都是string类型的双向链表,链表的最大长度是 (2的 32次方 -1)  更多操作见help @list
(3)set集合类型 :string类型的无序集合,通过hash table实现的,set元素最大可以包含(2的32 次方-1) 更多操作见help @set
(4)sorted set有序集合类型 :string类型元素的集合,每个元素都会关联一个double类型的score,是skip list 和hash table的混合体 更多操作见help @sorted_set
(5)hash散列类型: 是一个string类型的field和value的映射表,更多操作见help @hash


redis喜欢采用 对象类型:对象ID:对象属性 这种格式来给数据取名字



你可能感兴趣的:(linux)