之所以在最开始阐述本文编写的目的,是因为在绝大多数情况下,Linux系统运维工程师遇到开机自动执行特定脚本之需求时,往往会采用在/etc/rc.local的文件中写命令行或脚本执行命令的方式来实现,然而现在对于多数Linux发行版而言,默认是没有/etc/rc.local这个文件的,取而代之的/etc/rcX.d这个文件,如果想要rc.local这个文件,就需要通过手工去创建相关的配置文件和服务,而相比于使用主流自带的/etc/rcX.d来说,其创建过程会相对繁琐一些,而目前网络上针对于/etc/rcX.d实现开机自动执行脚本的文章表述并不是那么清楚,因此本文出于这个目的讲解/etc/rcX.d的配置方式。
本文的rcX.d并不是指这个文件夹就是叫rcX.d,这其中的X对应是0~6这7个数字,不同的数字对应着不同的级别,这些文件夹在主流的Linux系统中存放于/etc目录下,如下图所示:
以上数字所代表的级别,其实对应的就是Linux系统的启动级别level,Linux一定会以一个启动级别来运行,在正常运行的Linux系统里面,我们可以通过runlevel
这个命令来查看当前系统的启动级别,如下所示:
从上图我们可以看出,当前运行的Linux系统是在3这个启动级别运行的,如果想要在这个启动级别里面实现开机自动执行特定脚本,那么我们的配置一定是在/etc/rc3.d中进行的。如果查看到的级别是5,那我们就应该在/etc/rc5.d这里面进行配置。因为rcX.d中X的不同对应不同的级别,因此这个X的含义与Linux启动级别含义是一致的,这决定了rcX.d级别的不同代表了不同使用场景,如下所示:
启动级别(X所代表的数字) | 启动级别所代表的含义 |
---|---|
0 | 停机(不能使用) |
1 | 单用户模式 |
2 | 多用户模式,但不能使用NFS等 |
3 | 完整的多用户模式 |
4 | 系统保留(未使用) |
5 | 图形化界面模式 |
6 | 重启模式(不能使用) |
我们以一台带有KDE桌面环境的debian系统为例,因为该debian系统带有KDE图形化桌面,因此正常启动时的启动级别为5,然后我们通过ls /etc/rc5.d
可以看到,/etc/rc5.d下有很多链接文件,如下图所示:
这些链接文件无一例外是指向/etc/init.d中的shell脚本或者其他可执行文件,它们的命名方式基本都是以“S”或者“K”开头,其后紧跟一个数字,数字后则是链接文件的名字,这个名字可以自行定义。关于这个命名含义,如下图所示:
依照上图,假如链接文件的命名为“K01xrdp”,那么执行该链接时,就等同于开机执行“/etc/init.d/xrdp stop
”,也就是说“S”传入的参数是“start” ,“K”传入的参数是“stop”,对于链接文件的优先级,通常情况下是越小越优先。
前文以xrdp为例提到,/etc/rc5.d/S01xrdp
等同于开机自动执行“/etc/init.d/xrdp start
”命令。在老版本的Linux系统中,是没有我们现在所熟知的systemctl和service命令的,因此对于服务的启动和停止依赖于/etc/init.d。例如在RedHat5.7或者是WSL的各个发行版中,对于ssh的开启、状态查看和关闭是“/etc/init.d/sshd
”,而不是现在的“systemctl
”或“service sshd
”,因此rcX.d有些类似于“Linux服务进程管理+开机自启”这样的产物。
现有一个需求,要求开机时自动实现创建一个/root/test1.txt的文件,且文件中会有“I Love Tina!!”的文字,实现方式如下:
1、 先在/etc/init.d目录下创建一个test.sh脚本,并编写该脚本,相关代码如下:
#!/bin/bash
case $1 in
start)
touch /root/test1.txt
echo "I Love Tina!!" > /root/test1.txt
;;
stop)
touch /root/test1.txt
echo "Tina Love me, too!!!" > /root/test1.txt
;;
esac
(从代码中我们可以看出,该脚本通过一个case语句实现了对外部的start和stop参数的接收,从而执行对应的代码块)
2、 查看当前Linux系统的启动级别,如下图所示,能看到当前Linux系统启动级别为3:
3、 进入/etc/rc3.d文件夹中,通过命令“ln -s /etc/init.d/test.sh S99test
”创建软链接指向/etc/init.d/test.sh脚本
4、 输入命令“shutdown -h now
”或者“poweroff
”关机,然后手动重启(最好不用reboot,因为配置完成后,第一次可能会出现重启不生效,之后就可以了),此时该脚本实现了开机自动启动:
需要注意的是,如果上一个步骤中软链接的名字为“K99test”时,那么传入的参数为stop,这就意味着,系统重启后,/root/test1.txt的内容为“Tina Love me, too!!!”,如下图:
对于rcX.d和rc.local的比较,主要可以用以下几点概括:
1、 rcX.d可以细化到启动级别上的进行开机自动执行特定脚本,而rc.local还不行;
2、 rcX.d因为需要传送start或者stop参数,因此对于需要自动执行的脚本本身,需要使用case和$1等语句来接收这些参数,而rc.local则不用,因此rc.local在脚本编写上更简单。