Linux守护进程脚本:自动化管理服务 (linux 守护进程 脚本)

Linux是一个充满活力和快速变化的操作系统。在新的应用程序和软件,并不是每时每刻都处于活跃状态。在许多情况下,您需要将应用程序设置为在服务器重启后自动运行,以确保服务的稳定性和持久性。这可以通过使用守护进程脚本来实现。

守护进程是Linux系统中运行在后台的一类特殊进程,通常是以root权限运行的进程。它的作用是在系统启动时自动运行,并且一直在后台运行,接受来自用户或其他程序的信息,并运行相应的操作。通常,一个守护进程监测指定的文件夹或端口,当有请求到达时,它会采取相应的措施来处理它。

使用守护进程脚本,您可以自动化管理服务,确保它们一直运行,并在需要时进行重启。下面是如何创建并管理守护进程脚本的几个步骤。

1. 编写脚本

编写脚本是创建守护进程脚本的之一步。在脚本中,您需要指定您要管理的应用程序的路径、运行参数和名称。脚本应该可以接受命令行参数,以便在需要时可以动态更改参数。以下是一个示例脚本:

“`

#!/bin/bash

APP_NAME=”myapp”

APP_PATH=”/usr/local/bin/$APP_NAME”

LOG_FILE=”/var/log/$APP_NAME.log”

PID_FILE=”/var/run/$APP_NAME.pid”

case “$1” in

start)

if [ -f $PID_FILE ]; then

echo “$APP_NAME is already running.”

exit 1

fi

nohup $APP_PATH –log-file $LOG_FILE –pid-file $PID_FILE &

;;

stop)

if [ ! -f $PID_FILE ]; then

echo “$APP_NAME is not running.”

exit 1

fi

kill -9 `cat $PID_FILE`

rm $PID_FILE

;;

restart)

$0 stop

sleep 2

$0 start

;;

*)

echo “Usage: $0 start|stop|restart”

exit 1

esac

exit 0

“`

在这个示例脚本中,我们设定了应用程序的名称、路径、日志文件和PID文件。在每种情况下,我们都检查应用程序是否正在运行,并根据需要执行相应的操作。守护进程应该总是以后台模式运行,并且在启动时应该将输出重定向到一个日志文件中。

2. 将脚本保存到/etc/init.d目录中

当脚本编写完成后,您需要将其保存到Linux系统中的/etc/init.d 目录中。这个目录中包含了系统启动时需要运行的所有服务和程序的脚本。

假设您已经完成了一个名为myapp的守护进程脚本,你可以使用以下命令将脚本文件复制到/etc/init.d目录中。

“`

cp myapp /etc/init.d/

“`

3. 添加执行权限并使用update-rc.d进行管理

您需要为该脚本添加执行权限以便它能在系统启动时自动运行。您可以使用以下命令来添加权限:

“`

chmod +x /etc/init.d/myapp

“`

然后,使用“update-rc.d”命令来添加或删除守护进程脚本以确保它在系统启动时自动运行。例如,您可以使用以下命令添加myapp服务:

“`

sudo update-rc.d myapp defaults

“`

要删除myapp服务,请运行以下命令:

“`

sudo update-rc.d -f myapp remove

“`

守护进程脚本是自动化管理Linux服务的一种强大工具,可以避免手动管理服务的潜在问题。这个过程中,您可以轻松地编写、保存、管理、添加执行权限并自动运行脚本。

相关问题拓展阅读:

怎么将脚本作为linux的systemd

传统方式,Unix和Linux服务(daemons)由SysV的init脚本启动.这些服务写成Bourne Shell脚本,通常驻留在像/etc/rc.d/init.d/这样的目录里,调用时有一个或几个参数,比如start, stop或restart, 用来控制服务的开始,停止和重启. 开始服务包括调用守护程序的代码, 守护程序再fork一个后台进程.Shell脚本很慢,难以阅读,冗长而脆弱. 尽管shell脚本极其灵活(毕竟,脚本本身就是代码)有些事儿很难拿脚本来完成,比如:安排并发执行的顺序,正确的监督进程或只是详尽的配置执行上下文. systmed可以与脚本兼容, 但下面我们马上就会提到,在安装所有守护进程的时候推荐安装原生的systemd服务文件. SysV 的启动脚本需要根据发行版的不同做出调整,systemd的服务文件则兼容任何发行版中运行的systemd. 接下来是一个简洁的入门手册:如何把SysV的shell脚本转换成一个systemd服务文件。理想情况下,上位的软件应该在tar包里发行和安装systemd的服务文件. 如果你已经根据入门手册成功的把某个上位软件SysV脚本转换成功了,一个不错的做法是把转换成功的文件作为补丁提交给那个上位软件. 后续的文章将会讨论如何准备这样一个补丁, 现在可以告诉你的是systemd的daemon(7)用户手册中有与之相关的很多有用信息.

开始吧,作为例子,我们将把ABRT守护进程的init脚本转换成systemd的服务文件。ABRT是每个Fedora安装版的标准组件,它是自动Bug报告工具(Automatic Bug Reporting Tool)的缩写,比如,它提供收据crash dumps服务。它的SysV脚本上传到这里了。

Linux设置定时任务

《使用PSSH批量管理Linux》 一文中,已经学习了使用p

.sh

批量管理linux的技巧。而很多时候,我们需要定时执行一些任务,或者需要定时执行一些批量任务。因此,本文就来研究一下linux设置定时任务的方法。

主要参考 Linux Crontab 定时任务 、 Linux定时任务Crontab命令详解 和 Linux 定时任务详解 。

cron(crond)是linux下用来周期性的执行某种任务或等待处理某些事件的一个守护进程。

linux系统

上面原本就有非常多的计划性工作,因此这个系统服务是默认启动的。crond进程每分钟会定期检查是否有要执行的任务,如果有要执行的任务,则自动执行该任务。另外,由于使用者自己也可以设置计划任务,所以,linux系统做裂也提供了使用者控制计划任务的命令:crontab命令。

crontab命令是cron table的简写,它是cron的配置文件,也可以叫它作业列表,我们可以在以下文件夹内找到相关配置文件。

linux下的任务调度分为两类,系统任务调度和用户任务调度。

系统任务调度:系统周期性所要执行的工作,比如写缓存数据到硬盘、日志清理等。 /etc/crontab 文件就是系统任务调度的配置文件。

用户任务调度:用户定期要执行的工作,比如用户数据备份、定时邮件提醒等。用户可以使用 crontab 工具来定制自己的计划任务。所有用户定义的crontab文件都被保存在 /var/spool/cron/crontabs/ 目录中,其文件名与用户名一致。

假设我们使用的是Ubuntu14.04.5 Server版,查看 /etc/crontab ,内容为:

之一行SHELL变量指定了系统要使用哪个shell;第二行PATH变量指定了系统执行 命令的路径。

接下来的命令格式为:

m h dom mon dow user command

英文全拼为:

minute hour day month week user commond

注意, /var/spool/cron 目录中的用户调度任务,没有user一项,因为文件名已经代表了user。

在以上各个字段中,还可以使用以下

特殊字符

crontab命令格式为:

crontab

设置定时任务和时间紧密相关,如果服务器的时区时间设置和本地不同,就不能保证计划任务帆胡宴的正确执行。所以使用crontab的之一步,是调节好服务器的时间。

下面参考 Ubuntu 16.04将系统时间写入到硬件时间BIOS ,对服务器时间进行调节。

时间是有时区的,无论硬态银件时间还是操作系统时间。hwclock的时区在/etc/default/rcS文件中设置,里面有一个参数UTC,默认值为yes,表示使用UTC时区,如果设置为no,那表示使用osclock的时区。建议hwclock与osclock设置相同的时区,也就是no。

1、查看服务器硬件时间

sudo hwclock -r ,看到的时间格式为: Wed 23 May:02:17 AM HKT -0.seconds

2、查看服务器系统时间

date ,看到的时间格式为: Wed May 23 11:02:41 HKT 2023

3、设置hwclock和osclock时区相同

sudo vim /etc/default/rcS ,找到:

修改为:

4、将系统时间写入硬件时间

sudo hwclock -w

5、修改系统时区

osclock的时区配置文件为/etc/timezone,不建议直接修改配置文件。

如果你想修改为CST时间,那么执行 sudo tzselect 命令时,选择Asia->China->Beijing Time即可,这时会提示使用Asia/Shanghai时区。(ubuntu和centos通用)

6、设置即刻生效

执行 date ,发现时区没有变化,依然是HKT。

sudo cp /usr/share/zoneinfo/Asia/Shanghai /etc/localtime

sudo ntpdate time.windows.com

如果执行ntpdate报错:ntpdate: no server suitable for synchronization found ,那么就换一个时间同步工具。

sudo apt-get install rdate

sudo rdate -s time-b.nist.gov

再次执行 date ,发现时区已经变成了CST。

7、硬件时间同步

sudo hwclock -r ,发现硬件时间落后。

sudo hwclock -w ,再次把系统时间写入硬件时间,同步完成。

实例1:每分钟、每小时、每天、每周、每月、每年执行

实例2:每小时的第3和第15分钟执行

3,15 * * * * myCommand

实例3:在上午8点到11点的第3和第15分钟执行

3,* * * myCommand

实例4:每隔两天的上午8点到11点的第3和第15分钟执行

3,*/2 * * myCommand

实例5:每周一上午8点到11点的第3和第15分钟执行

3,* * 1 myCommand

实例6:每晚的21:30重启b

* * * /etc/init.d/b restart

实例7:每月1、10、22日的4 : 45重启b

,10,22 * * /etc/init.d/b restart

实例8:每周六、周日的1 : 10重启b

* * 6,0 /etc/init.d/b restart

实例9:每天18 : 00至23 : 00之间每隔30分钟重启b

0,* * * /etc/init.d/b restart

实例10:每星期六的晚上11 : 00 pm重启b

* * 6 /etc/init.d/b restart

实例11:每一小时重启b

0 * * * * /etc/init.d/b restart

实例12:晚上11点到早上7点之间,每隔一小时重启b

/1 * * * /etc/init.d/b restart

实例13:每月的4号与每周一到周三的11点重启b

* mon-wed /etc/init.d/b restart

实例14:一月一号的4点重启b

jan * /etc/init.d/b restart

实例15:每小时执行/etc/cron.hourly目录内的脚本

* * * * root run-parts /etc/cron.hourly

run-parts这个参数了,如果去掉这个参数的话,后面就可以写要运行的某个脚本名,而不是目录名了。

目标:每分钟查看一下ganglia的状态,并保存到/tmp/log/ganglia目录。

1、创建/tmp/log/ganglia目录

sudo mkdir -p /tmp/log/ganglia

sudo chmod a+w /tmp/log/ganglia

2、编辑crontab

crontab -e ,选择编辑器为vim

3、在crontab文件中添加一行

4、查看crontab任务

crontab -l ,看到任务已经添加成功。

5、等待了五分钟,发现/tmp/log/ganglia目录下啥也没有。

sudo service cron status ,状态正常。

sudo /etc/init.d/cron restart ,重启cron试试。

又等待了五分钟,发现/tmp/log/ganglia目录下依然空空。

莫非是因为pssh没有使用绝对路径? whereis pssh ,找到pssh路径为 /usr/lib/pssh ,修改crontab为:

然而,并没有用。

还是查看下crontab日志吧!

以下主要参考 Ubuntu下用crontab 部署定时任务 。

1、编辑50-default.conf

sudo vim /etc/rsyslog.d/50-default.conf

2、把cron前的

井号

去掉,也就是修改为:

3、重启rsyslog服务

sudo service rsyslog restart

4、重启crontab服务

sudo service cron restart

5、查看crontab日志

less /var/log/cron.log

果然发现了问题:

也就是说,命令确实按时执行了,只不过没有执行完,被

百分号

截断了,导致log文件没有正常生成!

修改crontab为:

终于,log文件成功生成,nice!但是,文件内容是空的!因为, /usr/lib/pssh 是一个目录,不是pssh命令!真正的pssh命令是parallel-ssh,找到它的位置为 /usr/bin/parallel-ssh ,修改crontab:

至此,问题圆满解决。

实际使用的时候,一天获取一次ganglia的状态就够了,所以crontab改成:

以上,每天执行一次定时任务,抓取ganglia的运行状态保存到日志文件中。紧接着,我们的目标是使用脚本检查当天的日志文件,如果发现ganglia运行异常,则产生一个错误日志。

1、假设日志文件ganglia.log的内容为:

2、参考 grep命令最经常使用的功能总结 ,编写脚本checkganglia.sh

3、执行

chmod a+x checkganglia.sh

./checkganglia.sh

如果所有客户机的ganglia运行正常,就会输出All services are runing!。如果有的客户机ganglia进程不存在,则会在/tmp/log/ganglia/目录下生成当天的错误日志。

4、设置定时运行

因为日志的检查工作要在日志生成之后,所以时间上延后十分钟。

上面的脚本,还有很多要改进的地方。比如有的客户机宕机了,上面的脚本检查不出来。比如有的客户机ganglia服务没有启动,那么具体是哪几台?针对这两个问题,下面进行改进。假设已经知道客户机的数量为10。

参考 csplit命令 ,checkganglia.sh脚本修改为:

以上脚本,实现了当客户机数量不为10的时候,进行报错;当客户机ganglia服务没有启动时,进行报错,并且筛选出所有没有启动ganglia的客户机。

本文中,我们先学习了crontab的基础知识和基本用法。然后通过监控ganglia这一个应用场景来具体学习crontab的详细使用方法,包括查看cron日志的方法,crontab中命令转义的方法,定时执行脚本的方法,以及审阅日志脚本的编写和进阶。

关于linux 守护进程 脚本的介绍到此就结束了,不知道你从中找到你需要的信息了吗 ?如果你还想了解更多这方面的信息,记得收藏关注本站。


数据运维技术 » Linux守护进程脚本:自动化管理服务 (linux 守护进程 脚本)