3 W, X) [# V$ X" A$ u- p 第一个字段是一个任意指定的标签; 4 F' ?, w% [% i% B& I 7 n0 i' ]( f+ w; m, H 第二个字段表示这一行适用于运行那个级别(这里是2); " N. M) }$ ]2 p& J& P4 q/ W& p& ^. l& T0 T2 u9 E
第三个字 段表示进入运行级别时,init应该运行第四个字段内的命令一次,而且init应该等待该命令结束。/etc/init.d/rc命令运行启动和终止输入以便进入运行级别2时所需的任何命令。 6 C R) _* O' h1 L
# [7 P2 U! O& X! ]3 G 第四个字段中的命令执行设置运行级别时的一切“杂活”。它启动已经没有运行的服务,终止不应该再在新运行级别内运行的服务。根据Linux版本的不同,采用的具体命令也不同,而且运行级别的配置也是有差别的。 1 h: g1 K, z. F6 c8 v
% L) m% I: V' ]* U6 e+ n" M+ ]9 B
init启动时,它会在/etc/inittab内查找一个代码行,这一行指定了默认的运行级别: 5 X2 f% r' n) P# `& \6 E% q " a* g% a; y8 Q id : 2 : initdefault : ' J: f# Z3 O9 n0 R4 e
% u1 E9 M6 W9 e' j3 A9 ^
你可以要求init在启动时,进入非默认运行级别,这是通过为内核指定一个“single”或“emergency” 命令行参数来实现的。比如说,内核命令行参数的指定可通过LILO来执行。这样一来,你就可以选择单用户模式了(即运行级别1)。 4 L# [) }+ T. s5 I9 T9 l/ |3 F2 A3 `! v
' b B8 z: m7 e2 E3 J) l( z 系统正在运行时,telinit命令可更改运行级别。运行级别发生变化时, init 就会从/etc/inittab运行相应的命令。 5 D8 h5 |- g5 _( ^. _' U ! ~. w0 l6 x5 h) T+ b# e( a 四、/etc/inittab中的特殊配置 4 x9 k+ H% G! l5 c
4 S7 m9 M9 Z6 g& S8 M5 H
/etc/inittab中,有几个特殊的特性,允许init重新激活特殊事件。这些特殊特性都是用第三个字段中的特殊关键字标记出来的。比如: . D! b) |5 r1 D% t2 n; E
% j1 C" p- g( |: X: k- G. I
1. powerwait 0 E% o" e1 [8 [ k2 L8 G! p6 a8 |; a- L7 e; e4 \8 x 允许init在电源被切断时,关闭系统。其前提是具有U P S和监视U P S并通知init电源已被切断的软件。 9 P7 Z+ R/ G8 N6 X }
) U J7 t ^' c1 a w5 ] 2. ctrlaltdel 1 g8 O# _2 h | ) P+ j- d! h4 _! a: l' |+ Z9 H 允许init在用户于控制台键盘上按下C t r l + A l t + D e l组合键时,重新启动系统。注意,如果该系统放在一个公共场所,系统管理员可将C t r l + A l t + D e l组合键配置为别的行为,比如忽略等。 ; U. u9 s" g. F( R
4 q2 K v# ~4 w J& T, R3. sysinit 3 l/ s! J/ E: l! @ 2 y) k5 ~# P& W1 ~5 \( e, E 系统启动时准备运行的命令。比如说,这个命令将清除/tmp。 * A/ b, k6 p# E, g7 `# A) f7 u3 D- [+ [5 G
上面列出的特殊关键字尚不完整。其他的关键字及其使用详情,可参考你的inittab手册页。 0 N$ b; T* I; ^7 j, {
4 v. F: H6 `/ Y 五、在单用户模式下引导 . O6 C# j! e8 M1 N! g
+ A- _3 Q' P9 a0 c/ a( Q- e
一个重要的运行级别就是单用户模式(运行级别1),该模式中,只有一个系统管理员使用特定的机器,而且尽可能少地运行系统服务,其中包含登录。单用户模式对少数管理任务(比如在/usr分区上运行fsck)而言,是很有必要的,因为这需要卸载分区,但这是不可能的,除非所有的服务系统已被杀死。 9 {, {" n& p6 u9 A4 y7 ^/ \8 ]
7 a% U) s) ~# i. r/ ~, t9 ?+ K' g
一个正在运行的系统可以进入单用户模式,具体做法是利用init,请求运行级别1。内核启动时,在内核命令行指定single或emergency关键字,就可进入运行级别1了。内核同时也为init指定命令行, init从关键字得知自己不应该采用默认的运行级别(内核命令行的输入方式和你启动系统的方式有关)。 ) ?7 x) m- q1 ]
G" o3 x r; N" n/ Z 有时,以单用户模式进行启动是必要的,这样一来,用户在装入分区之前,或至少在装入分散的/usr分区之前,能手工运行fsck(在分散的文件系统上,任何活动都可能使其更为分散,所以应该尽可能地运行fsck)。 * N2 ~. S' \4 o8 s% I- I# A
# k+ L, d8 Q: C' I: T" T | ` 如果自动化的fsck在启动时失败了,启动脚本init的运行将自动进入单用户模式。这样做是为了防止系统使用不连贯的文件系统,这个文件系统是f s c k不能自动修复的。文件系统不连贯的现象极为少见,而且通常会导致硬盘的不连贯或实验性的内核释放,但最好能做到防患于未然。 ( I5 k3 n% P r2 ^ " b2 B# N+ g m 由于安全上的考虑,在单用户模式下,启动外壳脚本之前,配置得当的系统会要求用户提供root密码。否则,它会简单地为L I L O输入合适的一行代码,以r o o t的身份登录(当然,如果/etc/passwd已经由于文件系统的问题而不连贯了,就不适合这里的原则了,为对付这种情况,你最好随时准备一张启动盘)。 # v: C! H1 `- \* O
% J" L5 N( x* C- p1 f; E+ O 不同的运行级有不同的用处,也应该根据自己的不同情形来设置。 $ B. ?9 l% M0 X' V; Z
- ]/ Z2 L- C! C' f6 b/ b
例如,如果丢失了root口令,那么可以让机器启动进入单用户状态。在启动后的 lilo 提示符下输入: % U. U. Y1 B% G1 Z% I2 [: Q
9 T. G% I1 l% h8 q! [
init=/bin/sh rw 使机器进入运行级1 ,并把 root 文件系统挂为读写。他会跳过所有系统认证,让你可以使用passwd 程序来改变root口令,然后启动到一个新的运行级。