centos6服务启动脚本
centos6的服务启动脚本都放在/etc/rc.d/init.d/下,/etc/init.d/是/etc/rc.d/init.d/的软链接; centos6的服务启动脚本都有两行描述: # chkconfig:定义默认在哪个级别下启动(runlevels)、启动优先次序(SS)、关闭的优先次序(KK);当chkconfig命令来为此脚本在rc#.d目录下创建链接 时,runlevels表示默认创建为S开头的链接,-表示,没有级别默认为S开头的链接,除此之外的级别都默认创建为K开头的链接;S后面的启动优先级 为SS所表示的数字;K后面的关闭优先次 序为KK所表示的数字;S开头的软链接表示为on,K开头的表示为off状态的; # description:用于说明此脚本的简单功能;\,表示为续行; 虽然这两行是注释,但是chkconfig命令会读取这两行; 守护进程:可以管理在哪个级别下启动或者关闭的服务; /etc/rc.d/rc.local:系统开机最后启动的一个服务,准确说,应该执行的一个脚本;可以把开机想执行的一些命令(创建或者删除等操作)放到此脚本中;
自创建服务脚本
#!/bin/bash # chkconfig: 2345 77 22 #优先启动次序数值越大,则越先关闭;反之,先启动(数值小),则后关闭;服务之间有依赖关系,有的服务需要先启动 # description: Test Service LOCKFILE=/var/lock/subsys/myservice #服务脚本启动后,都会在锁目录下创建一个服务对应的文件 function STATUS { if [ -e $LOCKFILE ];then echo "Running..." else echo "Stopping..." fi } function usage { echo "`basename $0` (start|stop|restart|status)" } case $1 in start) echo "starting..." touch $LOCKFILE ;; stop) echo "stopping..." rm -f $LOCKFILE &>/dev/null ;; restart) echo "restarting..." rm -f $LOCKFILE &>/dev/null touch $LOCKFILE ;; status) STATUS ;; *) usage ;; esac
chkconfig命令
[root@centos6 ~]# chkconfig --list #查看所有独立守护服务(守护进程)的启动设定 [root@centos6 ~]# chkconfig --list SERVICE_NAME #查看某一个独立守护服务(守护进程)的启动设定 [root@centos6 ~]# chkconfig --add SERVICE_NAME #把某个服务脚本添加到chkconfig可控制的服务列表中(创建S开头的软链接) [root@centos6 ~]# chkconfig --del SERVICE_NAME #删除服务的链接文件 [root@centos6 ~]# chkconfig [--level RUNLEVELS] SERVICE_NAME (on|off) #指定服务在哪个级别下开启或者关闭 #如果省略级别指令,默认为2345级别;
/etc/inittab的任务:
1、设定默认运行级别: 2、运行系统初始化脚本; 3、运行指定运行级别对应的目录下的脚本(S开头的都为start,K开头的都为stop); 4、设定Ctrl+Alt+Del组合键的操作; 5、定义UPS电源在电源故障/恢复时执行的动作; 6、启动虚拟终端(2345级别下启动); 7、启动图形终端(只在5级别下启动);
守护进程类型
独立守护进程 瞬时守护进程:不需要关联至运行级别(没有运行级别概念); xinetd:超级守护进程;负责管理所有的瞬时守护进程;超级守护进程需要关联至运行级别; xinetd与瞬时守护进程的关系: 瞬时守护进程平时是不需要打开的,只需要开启超级守护进程即可,由超级守护进程(xinetd)进行统一管理;当有用户访问瞬时守护进程时,xinetd会激活用户所访问的瞬时守护进程,用户访问完毕后,再关闭瞬时守护进程; [root@centos6 ~]# chkconfig PROCESS_NAME on #启动瞬时守护进程;前提是先得安装xinetd;yum install xinetd -y
系统启动流程
1、POST加电自检;计算机启动时,系统会载入一段程序,将程序映射到CPU能够寻址的地址空间去,让CPU能够执行其中的指令,这些指令用来系统检测用; 2、检测完成后,如果基本、核心硬件如果没问题则进入下一步; 3、根据BIOS中所设定的系统启动流程去找对应存储设备上的MBR;如果MBR存在,会读取MBR中的bootloader(一段程序;MBR留给bootloader用的空间为446byte); 4、BootLoader中配置了所要引导的系统内核的位置;因此当BIOS加载到内存中后,将控制权限转交给bootloader后,bootloader接收了整个系统的控制权限; 5、根据用户的选择,读取相应操作系统的内核; 6、将内核加载到内存中的合适位置进行解压缩并完成内核初始化后,bootloader会将权限转交给内核; 内核初始化: 硬件探测 装载驱动:驱动程序可能在内核中,也可能在另一个辅助程序中:initramfs,initramfs中有内核所依赖到的其他设备的驱动及根文件系统驱动 挂载根文件系统 启动用户空间中的第一个进程init 注意: 内核要完成初始化依赖于驱动程序,如果驱动程序不在内核当中,需要到某个文件系统下去装载驱动程序;但是在根文件系统被挂载之前,如果内核访问根文 件系统需要用到驱动程序,但内核中没有,需要去文件系统中寻找驱动,但是文件系统还未挂载,所以就需要用到initramfs为内核提供访问真正的根文件系 统所需的基本驱动程序;initramfs是一个辅助性过渡性的中间层,它能够实现kernel和真正的根文件系统连接起来;内核挂载根文件系统默认是以只读方式 挂载; 7、执行init进程,init在centos6上虽然还叫init,但是本身实际是upstart程序;init(upstart)本身的配置文件:/etc/inittab和/etc/init/*(所有).conf; 8、/etc/initab所需要执行:设定运行级别、系统初始化脚本(/etc/rc.d/rc.sysinit)、运行指定级别的服务脚本、执行最后一个脚本(/etc/rc.d/rc.local)、启动虚拟终端、图形终端; /etc/rc.d/rc.sysinit初始化脚本的作用: 检测,并且以读写方式重新挂载根文件系统; 设定主机名; 检测并挂载/etc/fstab中的其他文件系统; 启用swap分区; 初始化外围硬件设备的驱动; 根据/etc/sysctl.conf设定内核参数; 激活LVM和RAID设备; 清理过期的锁和PID文件; 激活键映射;(键盘每个键的具体功能) BIOS:基本输入输出系统;他保存着计算机最重要的基本输入输出的程序 、开机后自检程序和系统自启动程序;