CentOS系统下Redis安装和自启动配置的步骤_Redis

一. 安装Redis

Redis的安装其实相当简单,推荐的方式是下载redis的源码,并在本机编译后安装。

首次进入主文件夹的下载目录下,执行wget下载源码

[zhxilin@localhost ~]$ cd 下载
[zhxilin@localhost 下载]$ wget http://download.redis.io/redis-stable.tar.gz

接下来解压之后,移动到/usr/redis目录下

[zhxilin@localhost 下载]$ tar -zxvf redis-stable.tar.gz
[zhxilin@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-serverredis-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进行测试

[zhxilin@localhost ~]$ redis-server
[zhxilin@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服务运行时加载的配置,我们先观察一下其中的内容

[zhxilin@localhost redis]$ vi redis.conf 

此文件内容非常长,但是大部分是注释,我们重点关注其中的几个设置daemonizepidfile

其中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 zhxilin]# chkconfig redisd on

然后就会发现报了一个错误:服务 redisd 不支持 chkconfig ?

 这是因为我们需要在redis_init_script的开头加一个小改动:

#!/bin/sh
# chkconfig: 2345 90 10
# description: Redis is a persistent key-value database

保存完重新拷贝到/etc/init.d/redisd后,再运行chkconfig就完成了。

一切就绪之后,可以执行以下命令检验service是否设置成功:

[root@localhost zhxilin]# service redisd start
[root@localhost zhxilin]# service redisd stop

等价于

[root@localhost zhxilin]# /etc/init.d/redisd start
[root@localhost zhxilin]# /etc/init.d/redisd stop

总结

最后重启一下系统吧,进入系统之后直接运行redis-cli检验redis服务是否已经自动运行了。以上就是这篇文章的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流。

以上是小编为您精心准备的的内容,在的博客、问答、公众号、人物、课程等栏目也有的相关内容,欢迎继续使用右上角搜索按钮进行搜索centos
, redis
, 自启动
, 安装配置
redis安装配置
centos7 redis 自启动、centos redis 自启动、centos7系统安装步骤、redis开机自启动、redis 自启动,以便于您获取更多的相关知识。

时间: 2024-11-03 21:05:17

CentOS系统下Redis安装和自启动配置的步骤_Redis的相关文章

CentOS系统下Redis安装配置教程

这里参考了太多教程已经忘了在哪一篇配置成功的了,总之还是编译安装大法. 首先下载: wget http://download.redis.io/releases/redis-2.8.13.tar.gz 解压缩 tar zxvf redis-2.8.13.tar.gz 切换目录 cd redis-2.8.13 执行make命令,最后几行的输出结果 Hint: To run 'make test' is a good idea ;) make[1]: Leaving directory `/opt/

CentOS系统下MongoDB安装及配置教程_MongoDB

一.准备工作:运行yum命令查看MongoDB的包信息 复制代码 代码如下: [root@vm ~]# yum info mongo-10gen (提示没有相关匹配的信息,) 说明你的centos系统中的yum源不包含MongoDB的相关资源,所以要在使用yum命令安装MongoDB前需要增加yum源,也就是在 /etc/yum.repos.d/目录中增加 *.repo yum源配置文件,以下分别是针对centos 64位和32位不同的系统的MongoDB yum 源配置内容: 我们这里就将该文

CentOS 6.4系统下编译安装LNMP和配置PHP环境

  一.准备工作 上pkgs.org下载rmpforge.rpmforge是一个第三方yum源. 选择相应的版本下载安装. // 安装成功后,清空yum list 并 重新获取 [root@pangou Desktop]# yum clean all Loaded plugins: fastestmirror, refresh-packagekit, security Cleaning repos: base extras rpmforge updates Cleaning up Everyth

centos系统下php5安装curl扩展两种方法

php5.3 安装curl扩展  代码如下 复制代码 tar zxf 解压 ./configure --prefix=/usr/local/curl make make install 进入PHP的源码包,没有的话,重新下载php5.3.tar.gz解压即可.  代码如下 复制代码 cd ext/curl 运行一下phpize /usr/local/php5/bin/phpize 配置curl  代码如下 复制代码 ./configure --with-php-config=/usr/local

CentOS系统下编译安装MySQL以及设置相关yum源的教程_Mysql

编译安装软件通常会遇到各种问题,尤其是在编译lamp这样的多种软件协同工作时各软件还相互影响,尤其是之前安装的软件会影响后边程序的编译安装,出现这种问题常常是之前安装的软件没有导出库文件和头文件,因而导致后面的软件在安装是需要指定前面安装程序的路径时常常提示找不到文件之类的错误,下面以mysql为例 1.安装开发环境 yum groupinstall "Development tools" 2.解决软件包依赖包 安装编译代码需要的包 yum -y install make gcc-c+

CENTOS系统中YUM安装SUBVERSION做SVN服务器步骤

svn(subversion)是近年来崛起的版本管理工具,是cvs的接班人.目前,绝大多数开源软件都使用svn作为代码版本管理软件. 下面记录subversion的安装过程. 1.安装subversion.Apache及svn扩展. 直接使用Centos安装源里的包安装,会自动解决依赖. yum install subversion httpd mod_dav_svn -y 2.设定开机启动. 通过 [root@bak var]# chkconfig --list|grep svn svnser

Redis 安装及主从配置的步骤详解

Redis是一个开源.支持网络.基于内存.键值对存储数据库.与其他非关系型数据库主要不同在于,Redis中值的类型不仅限于字符串(Strings),还支持如下抽象数据类型:(列表)Lists.(集合)Sets.(有序集合)Sorted sets .(哈希)Hashes.Redis 通过 RDB.AOF 两种方式来实现数据的持久化.   安装Redis   Redis 源码包保存路径 /usr/local/src   Redis 软件安装路径 /usr/local/redis   编译 Redis

XP系统下怎样安装传真服务

XP系统下怎样安装传真服务   步骤/方法 首先,确认Modem支持通过系统自带传真组件(也有的还支持第三方传真应用软件). 确认Modem(TM-IP5600)已正确安装在电脑上.电话线路正常并已与Modem连接好. 安装XP系统的传真服务:控制面板->添加或删除程序->添加/删除Windows组件,进入Windows XP的组件向导. 勾选传真服务,按照提示操作最后完成添加向导. 实际是需要复制完整版XP下的fxsocm.dll及fxsocm.inf. 当然也可以插入WINDOWS的安装光

Linux下Redis安装配置教程_Redis

redis作为NoSQL数据库的一种应用,响应速度和命中率上还是比较高效的.项目中需要用集中式可横向扩展的缓存框架,做了一点调研,即便redis.memcached存在效率上的差异(具体比较参考http://timyang.net/data/mcdb-tt-redis/),但其实都能满足目前项目的需求:但是redis还是比较风骚的,支持链表和集合操作,支持正则表达式查找key,目前项目缓存的结果大多是链表,如果链表新增或者修改数据的话,redis就体现出了极大的优势(memcached只能重新加