设为首页 收藏本站
查看: 843|回复: 0

[经验分享] CentOS系统下Redis安装和自启动配置的步骤

[复制链接]

尚未签到

发表于 2017-11-15 20:45:43 | 显示全部楼层 |阅读模式
相信大家都知道Redis是一个C实现的基于内存、可持久化的键值对数据库,在分布式服务中常作为缓存服务。所以这篇文章将详细介绍在CentOS系统下如何从零开始安装到配置启动服务。有需要的可以参考借鉴。
  一. 安装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源码




?


[iyunv@localhost 下载]# cd /usr/redis/
[iyunv@localhost redis]# make
  编译完成之后,在src目录下有2个重要程序生成,一个是redis-server,另一个是redis-cli;接着进入src目录,执行make install,这时会把这些可执行程序拷贝到/usr/local/bin目录下,由于/usr/local/bin是在系统的环境变量$PATH下定义的,因此终端在任意位置就可以执行redis-server和redis-cli了。




?


[iyunv@localhost redis]# cd src/
[iyunv@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
  此文件内容非常长,但是大部分是注释,我们重点关注其中的几个设置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




?


[iyunv@localhost utils]# cd /etc
[iyunv@localhost etc]# mkdir redis
[iyunv@localhost etc]# cp /usr/redis/redis.conf /etc/redis/6379.conf
  接着将redis_init_script脚本拷贝到/etc/init.d/redisd




?


[iyunv@localhost etc]# cp /usr/redis/utils/redis_init_script /etc/init.d/redisd
  在/etc/init.d下的脚本都是可以在系统启动是自动启动的服务,而现在还缺一个系统启动时的配置:




?


[iyunv@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是否设置成功:




?


[iyunv@localhost zhxilin]# service redisd start
[iyunv@localhost zhxilin]# service redisd stop
  等价于




?


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

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-407339-1-1.html 上篇帖子: linux系统Centos环境下搭建SVN服务器及权限配置 下篇帖子: Linux学习-CentOS 7.x 预设启动的服务简易说明
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表