今日分享redis设置开机自启动。

Redis是一款开源的内存数据结构存储系统,它可以用作数据库、缓存和消息代理,在许多应用场景中,Redis都发挥着重要的作用,有时候我们希望在系统启动时自动运行Redis,以便及时处理一些初始化任务或者提供实时的数据服务,本文将介绍如何设置Redis开机自启动。

一、检查Redis是否已经安装

在设置Redis开机自启动之前,我们需要确保Redis已经正确安装并配置好,可以通过以下命令检查Redis是否已经安装:

今日分享redis设置开机自启动。

redis-cli --version

如果显示出Redis的版本信息,说明Redis已经安装成功,如果没有安装成功,请参考Redis官方文档进行安装:

二、创建Redis配置文件

为了让Redis在开机时自动启动,我们需要创建一个配置文件,配置文件通常位于`/etc/redis/redis.conf`,如果该文件不存在,可以手动创建一个,在配置文件中,我们需要设置以下几个参数:

1. `daemonize no`:这个参数表示让Redis以非守护进程方式运行,这样在后台运行时不会影响到系统的正常运行。

2. `pidfile /var/run/redis_6379.pid`:这个参数表示设置Redis的进程ID文件路径,当Redis作为守护进程运行时,需要使用这个PID文件来管理进程。

今日分享redis设置开机自启动。

3. `port 6379`:这个参数表示设置Redis监听的端口号,默认为6379,可以根据实际需求修改端口号。

4. `bind 127.0.0.1`:这个参数表示设置Redis只能监听本地回环地址,不能接受外部连接,如果需要让其他设备访问Redis,可以将此参数注释掉或者修改为相应的IP地址。

5. `loglevel notice`:这个参数表示设置Redis的日志级别为notice,这样只会输出警告和错误信息,方便排查问题。

三、创建开机自启动脚本

为了让Redis在开机时自动启动,我们需要创建一个开机自启动脚本,在`/etc/init.d`目录下创建一个名为`redis_6379`的脚本文件:

今日分享redis设置开机自启动。

sudo touch /etc/init.d/redis_6379
sudo chmod +x /etc/init.d/redis_6379

接下来,编辑`redis_6379`脚本文件,添加以下内容:

#!/bin/sh
### BEGIN INIT INFO
# Provides:         redis_6379
# Required-Start:    $remote_fs $syslog
# Required-Stop:     $remote_fs $syslog
# Default-Start:     2 3 4 5
# Default-Stop:      0 1 6
# Short-Description: Start Redis on boot
# Description:       Enable service provided by redis.service.
### END INIT INFO

case "$1" in
  start)
    echo "Starting Redis ..."
    /etc/init.d/redis-server start >> /var/log/redis_start.log 2>&1 & echo $! > /var/run/redis_6379.pid
    ;;
  stop)
    echo "Stopping Redis ..."
    /etc/init.d/redis-server stop >> /var/log/redis_stop.log 2>&1 & kill $(cat /var/run/redis_6379.pid) && echo $? > /var/run/redundant_shutdown_status.txt || echo "failed to stop Redis"
    rm -f /var/run/redis_6379.pid
    ;;
  *)
    echo "Usage: $0 start|stop" >&2
    exit 1
    ;;
esac
exit 0

保存文件后,给脚本文件添加可执行权限:

sudo chmod +x /etc/init.d/redis_6379

四、创建开机自启动链接

为了让系统在启动时自动加载我们的开机自启动脚本,我们需要创建一个链接,在`/etc/rc.local`文件中添加以下内容:

#!/bin/sh -e
### BEGIN INIT INFO
# Provides:          rc-local update script (required for systemctl)
# Required-Start:     $remote_fs $syslog $network $named $time $syslogd $tmpfs $tcpdump $udpdump icmp $rtcwake $crond $syslogd $maildrop $messagebus *
# Required-Stop:     $remote_fs $syslog $network $named $time $syslogd $tmpfs $tcpdump $udpdump icmp $rtcwake $crond $syslogd $maildrop $messagebus *
# Default-Start:     2 3 4 5
# Default-Stop:      0 1 6
# Short-Description: Run custom scripts at startup before normal process startup.
# Description:       This script is executed at the end of each multiuser runlevel.
### END INIT INFO
if [ "$RUNLEVEL" == "0" ]; then # After this level, all processes not listed below will be stopped.${PATH=~^(?::/usr/localbin:)${PATH}} 
       [ "$TERM" != "dumb" ] && exec sudo su --login --command "${PATH=~^(?::/usr/localbin:)${PATH}} date; 
               $HOME/apps/redis_6379 start" &>> "$HOME"/apps/logs/redis_startup.log & disown # Add any command specific options above this line if needed.${PATH=~^(?::/usr/localbin:)${PATH}} 
       [ "$TERM" = "dumb" ] && exec sh <<EOF # Otherwise, do nothing and continue with normal startup of shell or other process.${PATH=~^(?::/usr/localbin:)${PATH}} 
           while true; do sleep 10; doneEOF &>> "$HOME"/apps/logs/redis_startup.log & disown # This ensures that the container does not get locked (in case of CPU or memory constraints).${PATH=~^(?::/usr/localbin:)${PATH}} 
fi # End script execution if it runs successfully (success means that the last command executed returned a zero exit code).${PATH=~^(?::/usr/localbin:)${PATH}} 
exit 0 # Exit status of the script (0 indicates success).${PATH=~^(?::/usr/localbin:)${PATH}} 

本文来自投稿,不代表重蔚自留地立场,如若转载,请注明出处https://www.cwhello.com/427727.html

如有侵犯您的合法权益请发邮件951076433@qq.com联系删除

(0)
夏雨夏雨订阅用户
上一篇 2024年6月18日 13:03
下一篇 2024年6月18日 13:03

相关推荐

  • 我来教你Storm的Topology怎么配置「storm topology」。

    Storm是一个开源的分布式实时计算系统,它能够处理大量的数据流并进行实时分析,在Storm中,Topology是数据处理的核心概念,它定义了数据的流动路径和处理逻辑,配置一个Storm的Topology需要以下几个步骤: 1. 定义…

    2024年6月14日
    02
  • PHP中使用Redis实现批量操作。

    Redis是一款非常流行的高性能的内存数据库,在PHP开发中,使用Redis可以实现诸如缓存、锁等应用场景。本文将介绍如何使用Redis实现批量操作。一、Redis批量操作概述Redis提供了一系列的批量命令,可以在一次请求中…

    2023年5月21日
    07
  • 小编分享ubuntu安装redis教程。

    在Ubuntu上安装Redis非常简单直接。Redis 5.0被包含在默认的Ubuntu 20.04软件源中。想要安装它,以root或者其他sudo身份运行下面的命令:sudo apt update sudo apt install redis-server。一旦安装完成,Redis服务…

    2024年7月15日
    01
  • Redis在PHP中的应用:文章结束统计。

    Redis是一种高性能的内存数据库,它具有快速响应、高并发、高可扩展性等优点,已经广泛应用于各种互联网应用场景中。而在PHP中,Redis也是非常流行的一种缓存和数据存储解决方案。本文就来介绍一下Redis在PHP中的应…

    2023年5月21日
    02
  • 教你如何安装redis数据库。

    Redis-dump 是一个用于备份和还原 Redis 数据库的工具,以下是如何安装 redis-dump 的详细步骤: 1、检查系统环境 在开始之前,确保你的系统满足以下条件: 安装了 Redis。 安装了 Node.js,redis-dump 是一个 Node…

    2024年7月14日
    03
  • Redis与Memcache有什么区别?

    Redis是一个完全开源免费的高性能key-value数据库,它具有丰富的数据类型,可以支持数据的持久化,将内存中的数据保存在磁盘中,当重启服务器时可以再次加载使用。Memcache是一个高性能的分布式内存对象缓存系统,…

    2023年5月8日
    01
  • centos创建用户。

    在CentOS中创建用户,我们通常使用`useradd`命令,这个命令的基本格式是:`useradd [选项] 用户名`,选项可以包括:`-d`, `-g`, `-G`, `-s`, `-u`, `-r`, `-m`, `-K`, `-U`, `-c`, `-p`, `-e`, `-f`, `-n`, `-h`, `…

    2024年6月16日
    01
  • PHP中使用Redis实现分布式定时任务

    Redis是一种高性能的内存数据库,它具有快速的读写速度、支持一定级别的持久性和丰富的数据类型等优点。Redis常被用于缓存、消息队列、实时排行榜等场景。在开发中,我们有时会需要实现分布式的定时任务,比如:发…

    2023年5月19日
    01

联系我们

QQ:951076433

在线咨询:点击这里给我发消息邮件:951076433@qq.com工作时间:周一至周五,9:30-18:30,节假日休息