脚本功能:
实现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 #指定服务在3、4、5级别运行
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:对象属性 这种格式来给数据取名字