linux启动加载(linux 自启动)

linux 开机启动 会依次加载哪些脚本

1、相关基础知识点

1)redhat的启动方式和执行次序是:

加载内核

执行init程序

/etc/rc.d/rc.sysinit#由init执行的第一个脚本

/etc/rc.d/rc$RUNLEVEL#$RUNLEVEL为缺省的运行模式

/etc/rc.d/rc.local#相应级别服务启动之后、在执行该文件(其实也可以把需要执行的命令写到该文件中)

/sbin/mingetty#等待用户登录

在Redhat中,/etc/rc.d/rc.sysinit主要做在各个运行模式中相同的初始化工作,包括:

调入keymap以及系统字体

启动swapping

设置主机名

设置NIS域名

检查(fsck)并mount文件系统

打开quota

装载声卡模块

设置系统时钟

等等。

/etc/rc.d/rc则根据其参数指定的运行模式(运行级别,你在inittab文件中可以设置)来执行相应目录下的脚本。凡是以Kxx开头的,都以stop为参数来调用;凡是以Sxx开头的,都以start为参数来调用。调用的顺序按xx从小到大来执行。(其中xx是数字、表示的是启动顺序)例如,假设缺省的运行模式是3,/etc/rc.d/rc就会按上述方式调用/etc/rc.d/rc3.d/下的脚本。

值得一提的是,Redhat中的运行模式2、3、5都把/etc/rc.d/rc.local做为初始化脚本中的最后一个,所以用户可以自己在这个文件中添加一些需要在其他初始化工作之后,登录之前执行的命令。

init在等待/etc/rc.d/rc执行完毕之后(因为在/etc/inittab中/etc/rc.d/rc的

action是wait),将在指定的各个虚拟终端上运行/sbin/mingetty,等待用户的登录。

至此,LINUX的启动结束。

2、init运行级别及指令

一、什么是INIT:

init是Linux系统操作中不可缺少的程序之一。

所谓的init进程,它是一个由内核启动的用户级进程。

内核自行启动(已经被载入内存,开始运行,并已初始化所有的设备驱动程序和数据结构等)之后,就通过启动一个用户级程序init的方式,完成引导进程。所以,init始终是第一个进程(其进程编号始终为1)。

内核会在过去曾使用过init的几个地方查找它,它的正确位置(对Linux系统来说)是/sbin/init。如果内核找不到init,它就会试着运行/bin/sh,如果运行失败,系统的启动也会失败。

二、运行级别

那么,到底什么是运行级呢?

简单的说,运行级就是操作系统当前正在运行的功能级别。这个级别从1到6,具有不同的功能。

不同的运行级定义如下

# 0-停机(千万不能把initdefault设置为0)

# 1-单用户模式# s init s= init 1

# 2-多用户,没有 NFS

# 3-完全多用户模式(标准的运行级)

# 4-没有用到

# 5- X11多用户图形模式(xwindow)

# 6-重新启动(千万不要把initdefault设置为6)

这些级别在/etc/inittab文件里指定。这个文件是init程序寻找的主要文件,最先运行的服务是放在/etc/rc.d目录下的文件。在大多数的Linux发行版本中,启动脚本都是位于/etc/rc.d/init.d中的。这些脚本被用ln命令连接到/etc/rc.d/rcn.d目录。(这里的n就是运行级0-6)

3):chkconfig命令(redhat操作系统下)

不像DOS或者 Windows,Linux可以有多种运行级。常见的就是多用户的2,3,4,5,很多人知道 5是运行 X-Windows的级别,而 0就

是关机了。运行级的改变可以通过 init命令来切换。例如,假设你要维护系统进入单用户状态,那么,可以使用 init 1来切换。在 Linux的运行级的切换过程中,系统会自动寻找对应运行级的目录/etc/rc[0-6].d下的K和 S开头的文件,按后面的数字顺序,执行这

些脚本。对这些脚本的维护,是很繁琐的一件事情,Linux提供了chkconfig命令用来更新和查询不同运行级上的系统服务。

语法为:

chkconfig--list [name]

chkconfig--add name

chkconfig--del name

chkconfig [--level levels] name

chkconfig [--level levels] name

chkconfig有五项功能:添加服务,删除服务,列表服务,改变启动信息以及检查特定服务的启动状态。

chkconfig没有参数运行时,显示用法。如果加上服务名,那么就检查这个服务是否在当前运行级启动。如果是,返回 true,否则返回false。--level选项可以指定要查看的运行级而不一定是当前运行级。

如果在服务名后面指定了on,off或者 reset,那么 chkconfig会改变指定服务的启动信息。on和 off分别指服务在改变运行级时的启动和停止。reset指初始化服务信息,无论有问题的初始化脚本指定了什么。

对于 on和 off开关,系统默认只对运行级 3,4, 5有效,但是 reset可以对所有运行级有效。指定--level选项时,可以选择特定的运行级。

需要说明的是,对于每个运行级,只能有一个启动脚本或者停止脚本。当切换运行级时,init不会重新启动已经启动的服务,也不会再次去停止已经停止的服务。

选项介绍:

--level levels

指定运行级,由数字 0到 7构成的字符串,如:

--level 35表示指定运行级3和5。

要在运行级别3、4、5中停运 nfs服务,使用下面的命令:chkconfig--level 345 nfs off

--add name

这个选项增加一项新的服务,chkconfig确保每个运行级有一项启动(S)或者杀死(K)入口。如有缺少,则会从缺省的init脚本自动

建立。

--del name

用来删除服务,并把相关符号连接从/etc/rc[0-6].d删除。

--list name

列表,如果指定了name那么只是显示指定的服务名,否则,列出全部服务在不同运行级的状态。

运行级文件

每个被chkconfig管理的服务需要在对应的init.d下的脚本加上两行或者更多行的注释。

第一行告诉 chkconfig缺省启动的运行级以及启动和停止的优先级。如果某服务缺省不在任何运行级启动,那么使用-代替运行级。

第二行对服务进行描述,可以用跨行注释。

例如,random.init包含三行:

# chkconfig: 2345 20 80

# description: Saves and restores system entropy pool for

# higher quality random number generation.

表明 random脚本应该在运行级 2, 3, 4, 5启动,启动优先权为20,停止优先权为 80。

好了,介绍就到这里了,去看看自己目录下的/etc/rc.d/init.d下的脚本吧。

设置自启动服务:chkconfig--level 345 nfs on

2.实例介绍:

1、在linux下安装了apache服务(通过下载二进制文件经济编译安装、而非rpm包)、apache服务启动命令:/server/apache/bin/apachectl start。让apache服务运行在运行级别3下面。

命令如下:

1)touch/etc/rc.d/init.d/apache

vi/etc/rc.d/init.d/apache

chown-R root/etc/rc.d/init.d/apache

chmod 700/etc/rc.d/init.d/apache

ln-s/etc/rc.d/init.d/apache/etc/rc.d/rc3.d/S60apache#S是start的简写、代表启动、K是kill的简写、代表关闭。60数字

代表启动的顺序。(对于iptv系统而言、许多服务都是建立在数据库启动的前提下才能够正常启动的、可以通过该数字就行调整脚本的启动顺序))

apache的内容:

#!/bin/bash

#Start httpd service

/server/apache/bin/apachectl start

至此 apache服务就可以在运行级别3下随机自动启动了。(可以结合chkconfig对启动服务进行相应的调整)。

由于相关变量定义不同,所以以下启动顺序仅供参考

在Redhat Redflag centos fc linux系统里面脚本的启动

先后:

第一步:通过/boot/vm进行启动 vmlinuz

第二步:init/etc/inittab

第三步:启动相应的脚本,并且打开终端

rc.sysinit

rc.d(里面的脚本)

rc.local

第四步:启动login登录界面 login

第五步:在用户登录的时候执行sh脚本的顺序:每次登录的时候都会完全执行的

/etc/profile.d/file

/etc/profile

/etc/bashrc

/root/.bashrc

/root/.bash_profile

编者注:

Ntsysv命令也可以实现根据不同运行级别启动不同的服务,但是一定要注意,使用ntsysv命令,默认采用图形的方式管理服务的启动,但是在这种情况下设置的服务,只对当前的运行级别有效果!因此,建议最好还是使用 chkconfig来进行服务的管理。

Linux 内核启动及文件系统加载过程

Linux内核启动及文件系统加载过程

在u-boot引导Linux内核开始执行bootcmd命令后,Linux内核启动过程便开始。普通Linux内核启动通常分为三个阶段。本文将根据项目中使用的linux-2.6.37源码,详细描述内核启动的全过程。

第一阶段为内核自解压过程。在启动过程中,可以看到内核自解压界面。压缩和解压缩代码位于kernel/arch/arm/boot/compressed目录下。编译后产生head.o、misc.o、piggy.gzip.o、vmlinux、decompress.o等文件。BootLoader将系统引导至内核内存后,调用do_bootm_linux(),若内核未被压缩,直接启动;如被压缩,则进行解压。压缩内核头部包含解压程序,入口文件位于arch/arm/boot/compressed/head.S。

decompress_kernel()函数在misc.c文件中实现,调用proc_decomp_setup()、arch_decomp_setup()进行设置。解压缩过程开始后,打印“Uncompressing Linux...”信息,调用gunzip()解压并放置指定位置。内核解压完成后,返回head.S的583行,启动内核。

第二阶段主要工作包括设置ARM处理器工作模式、启用MMU、设置一级页表等。汇编代码通过查找处理器内核类型和机器码类型调用相应的初始化函数,建立页表,跳转至start_kernel()函数开始内核初始化。处理器类型检测在汇编子函数__lookup_processor_type中完成,机器码类型检测在__lookup_machine_type中。建立页表后,跳转至C程序入口start_kernel()。

第三阶段由start_kernel函数开始,这是所有Linux平台进入系统内核初始化后的入口。它完成与硬件平台相关的初始化工作,调用init进程并等待执行,完成Linux内核启动。

启动init服务并挂载根文件系统

在启动init服务前,需要挂载根文件系统。根文件系统至少包含五大目录。以只读方式挂载,防止内核不稳定时破坏数据或延长开机时间。

挂载根文件系统后,执行init服务。Linux内核依据/etc/inittab文件中设置进行初始化系统环境。init启动后,表示Linux内核成功启动。

在启动init服务时,init会读取/etc/inittab文件,执行rc.sysinit、rc、rc.local等脚本进行系统初始化。rc.sysinit主要功能包括启动udev、设置内核参数、系统时间、启用交换内存、检查并挂载文件系统、初始化硬件设备、管理串行端口、清除过期锁定文件、建立用户接口等。

整个Linux内核启动过程至此完成。

请教linux的启动过程

第一步、加载内核

操作系统接管硬件以后,首先读入/boot目录下的内核文件。

以我的电脑为例,/boot目录下面大概是这样一些文件:

$ ls/boot

config-3.2.0-3-amd64

config-3.2.0-4-amd64

grub

initrd.img-3.2.0-3-amd64

initrd.img-3.2.0-4-amd64

System.map-3.2.0-3-amd64

System.map-3.2.0-4-amd64

vmlinuz-3.2.0-3-amd64

vmlinuz-3.2.0-4-amd64

第二步、启动初始化进程

内核文件加载以后,就开始运行第一个程序/sbin/init,它的作用是初始化系统环境。

由于init是第一个运行的程序,它的进程编号(pid)就是1。其他所有进程都从它衍生,都是它的子进程。

第三步、确定运行级别

许多程序需要开机启动。它们在Windows叫做"服务"(service),在Linux就叫做"守护进程"(daemon)。

init进程的一大任务,就是去运行这些开机启动的程序。但是,不同的场合需要启动不同的程序,比如用作服务器时,需要启动Apache,用作桌面就不需要。Linux允许为不同的场合,分配不同的开机启动程序,这就叫做"运行级别"(runlevel)。也就是说,启动时根据"运行级别",确定要运行哪些程序。

Linux预置七种运行级别(0-6)。一般来说,0是关机,1是单用户模式(也就是维护模式),6是重启。运行级别2-5,各个发行版不太一样,对于Debian来说,都是同样的多用户模式(也就是正常模式)。

init进程首先读取文件/etc/inittab,它是运行级别的设置文件。如果你打开它,可以看到第一行是这样的:

id:2:initdefault:

initdefault的值是2,表明系统启动时的运行级别为2。如果需要指定其他级别,可以手动修改这个值。

那么,运行级别2有些什么程序呢,系统怎么知道每个级别应该加载哪些程序呢?......回答是每个运行级别在/etc目录下面,都有一个对应的子目录,指定要加载的程序。

/etc/rc0.d

/etc/rc1.d

/etc/rc2.d

/etc/rc3.d

/etc/rc4.d

/etc/rc5.d

/etc/rc6.d

上面目录名中的"rc",表示run command(运行程序),最后的d表示directory(目录)。下面让我们看看/etc/rc2.d目录中到底指定了哪些程序。

$ ls/etc/rc2.d

README

S01motd

S13rpcbind

S14nfs-common

S16binfmt-support

S16rsyslog

S16sudo

S17apache2

S18acpid

...

可以看到,除了第一个文件README以外,其他文件名都是"字母S+两位数字+程序名"的形式。字母S表示Start,也就是启动的意思(启动脚本的运行参数为start),如果这个位置是字母K,就代表Kill(关闭),即如果从其他运行级别切换过来,需要关闭的程序(启动脚本的运行参数为stop)。后面的两位数字表示处理顺序,数字越小越早处理,所以第一个启动的程序是motd,然后是rpcbing、nfs......数字相同时,则按照程序名的字母顺序启动,所以rsyslog会先于sudo启动。

这个目录里的所有文件(除了README),就是启动时要加载的程序。如果想增加或删除某些程序,不建议手动修改/etc/rcN.d目录,最好是用一些专门命令进行管理(参考这里和这里)。

第四步、加载开机启动程序

前面提到,七种预设的"运行级别"各自有一个目录,存放需要开机启动的程序。不难想到,如果多个"运行级别"需要启动同一个程序,那么这个程序的启动脚本,就会在每一个目录里都有一个拷贝。这样会造成管理上的困扰:如果要修改启动脚本,岂不是每个目录都要改一遍?

Linux的解决办法,就是七个/etc/rcN.d目录里列出的程序,都设为链接文件,指向另外一个目录/etc/init.d,真正的启动脚本都统一放在这个目录中。init进程逐一加载开机启动程序,其实就是运行这个目录里的启动脚本。

下面就是链接文件真正的指向。

$ ls-l/etc/rc2.d

README

S01motd->../init.d/motd

S13rpcbind->../init.d/rpcbind

S14nfs-common->../init.d/nfs-common

S16binfmt-support->../init.d/binfmt-support

S16rsyslog->../init.d/rsyslog

S16sudo->../init.d/sudo

S17apache2->../init.d/apache2

S18acpid->../init.d/acpid

...

这样做的另一个好处,就是如果你要手动关闭或重启某个进程,直接到目录/etc/init.d中寻找启动脚本即可。比如,我要重启Apache服务器,就运行下面的命令:

$ sudo/etc/init.d/apache2 restart

/etc/init.d这个目录名最后一个字母d,是directory的意思,表示这是一个目录,用来与程序/etc/init区分。

第五步、用户登录

开机启动程序加载完毕以后,就要让用户登录了。

一般来说,用户的登录方式有三种:

(1)命令行登录

(2)ssh登录

(3)图形界面登录

这三种情况,都有自己的方式对用户进行认证。

(1)命令行登录:init进程调用getty程序(意为get teletype),让用户输入用户名和密码。输入完成后,再调用login程序,核对密码(Debian还会再多运行一个身份核对程序/etc/pam.d/login)。如果密码正确,就从文件/etc/passwd读取该用户指定的shell,然后启动这个shell。

(2)ssh登录:这时系统调用sshd程序(Debian还会再运行/etc/pam.d/ssh),取代getty和login,然后启动shell。

(3)图形界面登录:init进程调用显示管理器,Gnome图形界面对应的显示管理器为gdm(GNOME Display Manager),然后用户输入用户名和密码。如果密码正确,就读取/etc/gdm3/Xsession,启动用户的会话。

第六步、进入 login shell

所谓shell,简单说就是命令行界面,让用户可以直接与操作系统对话。用户登录时打开的shell,就叫做login shell。

Debian默认的shell是Bash,它会读入一系列的配置文件。上一步的三种情况,在这一步的处理,也存在差异。

(1)命令行登录:首先读入/etc/profile,这是对所有用户都有效的配置;然后依次寻找下面三个文件,这是针对当前用户的配置。

~/.bash_profile

~/.bash_login

~/.profile

需要注意的是,这三个文件只要有一个存在,就不再读入后面的文件了。比如,要是~/.bash_profile存在,就不会再读入后面两个文件了。

(2)ssh登录:与第一种情况完全相同。

(3)图形界面登录:只加载/etc/profile和~/.profile。也就是说,~/.bash_profile不管有没有,都不会运行。

第七步,打开 non-login shell

老实说,上一步完成以后,Linux的启动过程就算结束了,用户已经可以看到命令行提示符或者图形界面了。但是,为了内容的完整,必须再介绍一下这一步。

用户进入操作系统以后,常常会再手动开启一个shell。这个shell就叫做 non-login shell,意思是它不同于登录时出现的那个shell,不读取/etc/profile和.profile等配置文件。

non-login shell的重要性,不仅在于它是用户最常接触的那个shell,还在于它会读入用户自己的bash配置文件~/.bashrc。大多数时候,我们对于bash的定制,都是写在这个文件里面的。

你也许会问,要是不进入 non-login shell,岂不是.bashrc就不会运行了,因此bash也就不能完成定制了?事实上,Debian已经考虑到这个问题了,请打开文件~/.profile,可以看到下面的代码:

if [-n"$BASH_VERSION" ]; then

if [-f"$HOME/.bashrc" ]; then

."$HOME/.bashrc"

fi

fi

上面代码先判断变量$BASH_VERSION是否有值,然后判断主目录下是否存在.bashrc文件,如果存在就运行该文件。第三行开头的那个点,是source命令的简写形式,表示运行某个文件,写成"source~/.bashrc"也是可以的。

因此,只要运行~/.profile文件,~/.bashrc文件就会连带运行。但是上一节的第一种情况提到过,如果存在~/.bash_profile文件,那么有可能不会运行~/.profile文件。解决这个问题很简单,把下面代码写入.bash_profile就行了。

if [-f~/.profile ]; then

.~/.profile

fi

这样一来,不管是哪种情况,.bashrc都会执行,用户的设置可以放心地都写入这个文件了。

Bash的设置之所以如此繁琐,是由于历史原因造成的。早期的时候,计算机运行速度很慢,载入配置文件需要很长时间,Bash的作者只好把配置文件分成了几个部分,阶段性载入。系统的通用设置放在/etc/profile,用户个人的、需要被所有子进程继承的设置放在.profile,不需要被继承的设置放在.bashrc。

顺便提一下,除了Linux以外, Mac OS X使用的shell也是Bash。但是,它只加载.bash_profile,然后在.bash_profile里面调用.bashrc。而且,不管是ssh登录,还是在图形界面里启动shell窗口,都是如此。

阅读剩余
THE END