共计 9141 个字符,预计需要花费 23 分钟才能阅读完成。
Redis 是一个 C 实现的基于内存、可持久化的键值对数据库,在分布式服务中常作为缓存服务。本篇将介绍在 CentOS 下如何从零开始安装到配置启动服务。
一. 安装 Redis
Redis 的安装其实相当简单,推荐的方式是下载 redis 的源码,并在本机编译后安装。
首次进入主文件夹的下载目录下,执行 wget 下载源码
[linuxidc@localhost ~]$ cd 下载
[linuxidc@localhost 下载]$ wget http://download.redis.io/redis-stable.tar.gz
接下来解压之后,移动到 /usr/redis 目录下
[linuxidc@localhost 下载]$ tar -zxvf redis-stable.tar.gz
[linuxidc@localhost 下载]$ su mv redis-stable /usr/redis
然后进入 redis 目录,执行 make 命令,编译 redis 源码
[root@localhost 下载]# cd /usr/redis/
[root@localhost redis]# make
编译完成之后,在 src 目录下有 2 个重要程序生成,一个是 redis-server,另一个是 redis-cli;接着进入 src 目录,执行 make install,这时会把这些可执行程序拷贝到 /usr/local/bin 目录下,由于 /usr/local/bin 是在系统的环境变量 $PATH 下定义的,因此终端在任意位置就可以执行 redis-server 和 redis-cli 了。
[root@localhost redis]# cd src/
[root@localhost src]# make install
至此安装 redis 的工作就完成了。
我们来看看编译出来的几个程序分别是干什么的:
redis-server:顾名思义,redis 服务
redis-cli:redis client,提供一个 redis 客户端,以供连接到 redis 服务,进行增删改查等操作
redis-sentinel:redis 实例的监控管理、通知和实例失效备援服务
redis-benchmark:redis 的性能测试工具
redis-check-aof:若以 AOF 方式产生日志,当意外发生时用来快速修复
redis-check-rdb:若以 RDB 方式产生日志,当意外发生时用来快速修复
安装完成之后,启动 redis-server,并运行 redis-cli 进行测试
[linuxidc@localhost ~]$ redis-server
[linuxidc@localhost ~]$ redis-cli
127.0.0.1:6379> PING
PONG
127.0.0.1:6379>
如此说明 redis 服务已经正常工作,如果 redis 服务未启动,则运行 redis-cli 时会报 Could not connect to Redis at 127.0.0.1:6379: Connection refused 的错误。
二. 配置自启动
为了让 redis-server 能在系统启动时自动运行,需要将 redis 服务作为守护进程(daemon)来运行,我们回到 /usr/redis/ 目录中找到一个 redis.conf 的文件,这个文件是 redis 服务运行时加载的配置,我们先观察一下其中的内容
[linuxidc@localhost redis]$ vi redis.conf
此文件内容非常长,但是大部分是注释,我们重点关注其中的几个设置 daemonize 和pidfile:
其中 daemonize 默认值是 false,pidfile 默认值是 pidfile /var/run/redis_6379.pid
第一个表示是否 daemon 化,显然我们要把它改成daemonize yes;
第二个表示当服务以守护进程方式运行时,redis 默认会把 pid 写入 /var/run/redis_6379.pid 文件,服务运行中该文件就存在,服务一旦停止该文件就自动删除,因而可以用来判断 redis 是否正在运行。
保存后退出。
有了基本配置,redis 还需要有一个管理启动、关闭、重启的一个脚本。redis 源码里其实已经提供了一个初始化脚本,位置在/usr/redis/utils/redis_init_script。
我们来看看这个脚本做了些什么:
#!/bin/sh#
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
脚本中指定了端口、server 路径、cli 路径、pidfile 路径以及 conf 路径,上述标黄的地方都需要正确配置,多说一句,如果在安装时执行了 make install,那么这里的脚本不需要做多大改动,因为 make install 把 server 和 cli 都拷到 /usr/local/bin 下面了。
另外看到这里 conf 的路径,我们需要把 redis 目录下的 redis.conf 文件拷贝到/etc/redis/6379.conf
[root@localhost utils]# cd /etc
[root@localhost etc]# mkdir redis
[root@localhost etc]# cp /usr/redis/redis.conf /etc/redis/6379.conf
接着将 redis_init_script 脚本拷贝到/etc/init.d/redisd
[root@localhost etc]# cp /usr/redis/utils/redis_init_script /etc/init.d/redisd
在 /etc/init.d 下的脚本都是可以在系统启动是自动启动的服务,而现在还缺一个系统启动时的配置:
[root@localhost linuxidc]# chkconfig redisd on
然后就会发现报了一个错误:服务 redisd 不支持 chkconfig?
参考这篇文章,这是因为我们需要在 redis_init_script 的开头加一个小改动:
#!/bin/sh
# chkconfig: 2345 90 10
# description: Redis is a persistent key-value database
至于这里 2345 90 10 分别代表什么意思,请参考上面的文章链接。
保存完重新拷贝到 /etc/init.d/redisd 后,再运行 chkconfig 就完成了。
一切就绪之后,可以执行以下命令检验 service 是否设置成功:
[root@localhost linuxidc]# service redisd start
[root@localhost linuxidc]# service redisd stop
等价于
[root@localhost linuxidc]# /etc/init.d/redisd start
[root@localhost linuxidc]# /etc/init.d/redisd stop
最后重启一下系统吧,进入系统之后直接运行 redis-cli 检验 redis 服务是否已经自动运行了。
下面关于 Redis 的文章您也可能喜欢,不妨参考下:
Ubuntu 14.04 下 Redis 安装及简单测试 http://www.linuxidc.com/Linux/2014-05/101544.htm
Redis 主从复制基本配置 http://www.linuxidc.com/Linux/2015-03/115610.htm
Redis 集群明细文档 http://www.linuxidc.com/Linux/2013-09/90118.htm
Ubuntu 12.10 下安装 Redis(图文详解)+ Jedis 连接 Redis http://www.linuxidc.com/Linux/2013-06/85816.htm
Redis 系列 - 安装部署维护篇 http://www.linuxidc.com/Linux/2012-12/75627.htm
CentOS 6.3 安装 Redis http://www.linuxidc.com/Linux/2012-12/75314.htm
Redis 安装部署学习笔记 http://www.linuxidc.com/Linux/2014-07/104306.htm
Redis 配置文件 redis.conf 详解 http://www.linuxidc.com/Linux/2013-11/92524.htm
Redis 的详细介绍:请点这里
Redis 的下载地址:请点这里
本文永久更新链接地址:http://www.linuxidc.com/Linux/2016-09/135399.htm
service redis does not support chkconfig 的解决办法
问题解决办法如下:
必须把下面两行注释放在 /etc/init.d/redis 文件靠前的注释中(加入以下注释):
# chkconfig: 2345 90 10
# description: Redis is a persistent key-value database
上面的注释的意思是,redis 服务必须在运行级 2,3,4,5 下被启动或关闭,启动的优先级是 90,关闭的
优先级是 10。
linux 运行级别
运行级别就是操作系统当前正在运行的功能级别。这个级别从 0 到 6,具有不同的功能。这些级别
在 /etc/inittab 文件里指定。这个文件是 init 程序寻找的主要文件,最先运行的服务是那些放
在 /etc/rc.d 目录下的文件。
不同的运行级定义如下:(可以参考 Linux 里面的 /etc/inittab)
# 缺省的运行级,RHS 用到的级别如下:
0:关机
1:单用户模式
2:无网络支持的多用户模式
3:有网络支持的多用户模式
4:保留,未使用
5:有网络支持有 X -Window 支持的多用户模式
6:重新引导系统,即重启
对各个运行级的详细解释:
0 为停机,机器关闭。
1 为单用户模式,就像 Win9x 下的安全模式类似。
2 为多用户模式,但是没有 NFS 支持。
3 为完整的多用户模式,是标准的运行级。
4 一般不用,在一些特殊情况下可以用它来做一些事情。例如在笔记本 电脑的电池用尽时,可以切换到
这个模式来做一些设置。
5 就是 X11,进到 X Window 系统了。
6 为重启,运行 init 6 机器就会重启。
chkconfig 用法
chkconfig 命令可以用来检查、设置系统的各种服务
使用语法:
chkconfig [–add][–del][–list][系统服务] 或 chkconfig [–level < 等级代号 >][系统服务]
[on/off/reset]
参数用法:
–add 增加所指定的系统服务,让 chkconfig 指令得以管理它,并同时在系统启动的叙述文件内增加相
关数据。
–del 删除所指定的系统服务,不再由 chkconfig 指令管理,并同时在系统启动的叙述文件内删除相关
数据。
–level< 等级代号 > 指定读系统服务要在哪一个执行等级中开启或关毕。
使用范例:
chkconfig –list 列出所有的系统服务
chkconfig –add redis 增加 redis 服务
chkconfig –del redis 删除 redis 服务
chkconfig –level redis 2345 on 把 redis 在运行级别为 2、3、4、5 的情况下都是 on(开启)的状态。
Redis 是一个 C 实现的基于内存、可持久化的键值对数据库,在分布式服务中常作为缓存服务。本篇将介绍在 CentOS 下如何从零开始安装到配置启动服务。
一. 安装 Redis
Redis 的安装其实相当简单,推荐的方式是下载 redis 的源码,并在本机编译后安装。
首次进入主文件夹的下载目录下,执行 wget 下载源码
[linuxidc@localhost ~]$ cd 下载
[linuxidc@localhost 下载]$ wget http://download.redis.io/redis-stable.tar.gz
接下来解压之后,移动到 /usr/redis 目录下
[linuxidc@localhost 下载]$ tar -zxvf redis-stable.tar.gz
[linuxidc@localhost 下载]$ su mv redis-stable /usr/redis
然后进入 redis 目录,执行 make 命令,编译 redis 源码
[root@localhost 下载]# cd /usr/redis/
[root@localhost redis]# make
编译完成之后,在 src 目录下有 2 个重要程序生成,一个是 redis-server,另一个是 redis-cli;接着进入 src 目录,执行 make install,这时会把这些可执行程序拷贝到 /usr/local/bin 目录下,由于 /usr/local/bin 是在系统的环境变量 $PATH 下定义的,因此终端在任意位置就可以执行 redis-server 和 redis-cli 了。
[root@localhost redis]# cd src/
[root@localhost src]# make install
至此安装 redis 的工作就完成了。
我们来看看编译出来的几个程序分别是干什么的:
redis-server:顾名思义,redis 服务
redis-cli:redis client,提供一个 redis 客户端,以供连接到 redis 服务,进行增删改查等操作
redis-sentinel:redis 实例的监控管理、通知和实例失效备援服务
redis-benchmark:redis 的性能测试工具
redis-check-aof:若以 AOF 方式产生日志,当意外发生时用来快速修复
redis-check-rdb:若以 RDB 方式产生日志,当意外发生时用来快速修复
安装完成之后,启动 redis-server,并运行 redis-cli 进行测试
[linuxidc@localhost ~]$ redis-server
[linuxidc@localhost ~]$ redis-cli
127.0.0.1:6379> PING
PONG
127.0.0.1:6379>
如此说明 redis 服务已经正常工作,如果 redis 服务未启动,则运行 redis-cli 时会报 Could not connect to Redis at 127.0.0.1:6379: Connection refused 的错误。
二. 配置自启动
为了让 redis-server 能在系统启动时自动运行,需要将 redis 服务作为守护进程(daemon)来运行,我们回到 /usr/redis/ 目录中找到一个 redis.conf 的文件,这个文件是 redis 服务运行时加载的配置,我们先观察一下其中的内容
[linuxidc@localhost redis]$ vi redis.conf
此文件内容非常长,但是大部分是注释,我们重点关注其中的几个设置 daemonize 和pidfile:
其中 daemonize 默认值是 false,pidfile 默认值是 pidfile /var/run/redis_6379.pid
第一个表示是否 daemon 化,显然我们要把它改成daemonize yes;
第二个表示当服务以守护进程方式运行时,redis 默认会把 pid 写入 /var/run/redis_6379.pid 文件,服务运行中该文件就存在,服务一旦停止该文件就自动删除,因而可以用来判断 redis 是否正在运行。
保存后退出。
有了基本配置,redis 还需要有一个管理启动、关闭、重启的一个脚本。redis 源码里其实已经提供了一个初始化脚本,位置在/usr/redis/utils/redis_init_script。
我们来看看这个脚本做了些什么:
#!/bin/sh#
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
脚本中指定了端口、server 路径、cli 路径、pidfile 路径以及 conf 路径,上述标黄的地方都需要正确配置,多说一句,如果在安装时执行了 make install,那么这里的脚本不需要做多大改动,因为 make install 把 server 和 cli 都拷到 /usr/local/bin 下面了。
另外看到这里 conf 的路径,我们需要把 redis 目录下的 redis.conf 文件拷贝到/etc/redis/6379.conf
[root@localhost utils]# cd /etc
[root@localhost etc]# mkdir redis
[root@localhost etc]# cp /usr/redis/redis.conf /etc/redis/6379.conf
接着将 redis_init_script 脚本拷贝到/etc/init.d/redisd
[root@localhost etc]# cp /usr/redis/utils/redis_init_script /etc/init.d/redisd
在 /etc/init.d 下的脚本都是可以在系统启动是自动启动的服务,而现在还缺一个系统启动时的配置:
[root@localhost linuxidc]# chkconfig redisd on
然后就会发现报了一个错误:服务 redisd 不支持 chkconfig?
参考这篇文章,这是因为我们需要在 redis_init_script 的开头加一个小改动:
#!/bin/sh
# chkconfig: 2345 90 10
# description: Redis is a persistent key-value database
至于这里 2345 90 10 分别代表什么意思,请参考上面的文章链接。
保存完重新拷贝到 /etc/init.d/redisd 后,再运行 chkconfig 就完成了。
一切就绪之后,可以执行以下命令检验 service 是否设置成功:
[root@localhost linuxidc]# service redisd start
[root@localhost linuxidc]# service redisd stop
等价于
[root@localhost linuxidc]# /etc/init.d/redisd start
[root@localhost linuxidc]# /etc/init.d/redisd stop
最后重启一下系统吧,进入系统之后直接运行 redis-cli 检验 redis 服务是否已经自动运行了。
下面关于 Redis 的文章您也可能喜欢,不妨参考下:
Ubuntu 14.04 下 Redis 安装及简单测试 http://www.linuxidc.com/Linux/2014-05/101544.htm
Redis 主从复制基本配置 http://www.linuxidc.com/Linux/2015-03/115610.htm
Redis 集群明细文档 http://www.linuxidc.com/Linux/2013-09/90118.htm
Ubuntu 12.10 下安装 Redis(图文详解)+ Jedis 连接 Redis http://www.linuxidc.com/Linux/2013-06/85816.htm
Redis 系列 - 安装部署维护篇 http://www.linuxidc.com/Linux/2012-12/75627.htm
CentOS 6.3 安装 Redis http://www.linuxidc.com/Linux/2012-12/75314.htm
Redis 安装部署学习笔记 http://www.linuxidc.com/Linux/2014-07/104306.htm
Redis 配置文件 redis.conf 详解 http://www.linuxidc.com/Linux/2013-11/92524.htm
Redis 的详细介绍:请点这里
Redis 的下载地址:请点这里
本文永久更新链接地址:http://www.linuxidc.com/Linux/2016-09/135399.htm