# x% V. N/ h2 C9 K# V& q2 j 第三个字 段表示进入运行级别时,init应该运行第四个字段内的命令一次,而且init应该等待该命令结束。/etc/init.d/rc命令运行启动和终止输入以便进入运行级别2时所需的任何命令。 " o) ^. x. v6 P) t9 {% d8 |7 b* x! H7 a2 l
第四个字段中的命令执行设置运行级别时的一切“杂活”。它启动已经没有运行的服务,终止不应该再在新运行级别内运行的服务。根据Linux版本的不同,采用的具体命令也不同,而且运行级别的配置也是有差别的。 3 Z4 X' e! _4 w6 O
+ m9 i1 \, v( Q2 ?5 D z
init启动时,它会在/etc/inittab内查找一个代码行,这一行指定了默认的运行级别: 2 P1 x. R" e. B5 G9 I
' E! J$ ?5 e* r( x T1 y ], P$ A id : 2 : initdefault : / C% S; r7 t; v) p 5 J& I1 H1 O7 W% n w 你可以要求init在启动时,进入非默认运行级别,这是通过为内核指定一个“single”或“emergency” 命令行参数来实现的。比如说,内核命令行参数的指定可通过LILO来执行。这样一来,你就可以选择单用户模式了(即运行级别1)。 ; a% n) V8 v$ o/ S) n4 B/ O/ d9 v% m. h; F' b9 k* \ ^
系统正在运行时,telinit命令可更改运行级别。运行级别发生变化时, init 就会从/etc/inittab运行相应的命令。 " j/ a& i" M+ }( L9 U5 n5 v2 K
/ i( Z0 Y; A; q# c3 O
四、/etc/inittab中的特殊配置 & q5 @9 E1 \2 t ! `' E/ S6 I* \( G6 ` /etc/inittab中,有几个特殊的特性,允许init重新激活特殊事件。这些特殊特性都是用第三个字段中的特殊关键字标记出来的。比如: ' q* G8 l6 ]( a3 {0 j3 `- F0 W ) N" u5 F; _: D/ V+ [; Q% e8 O 1. powerwait % e/ s+ u6 T$ U. F. ^
0 W3 s& C+ N$ R3 i
允许init在电源被切断时,关闭系统。其前提是具有U P S和监视U P S并通知init电源已被切断的软件。 3 l( H8 W6 G9 {; }
" X# q) @, V4 V0 d" C' Y
2. ctrlaltdel 6 C" i4 E$ ]. b1 L$ p( J' f' L* Y; ] 8 l" @" ?" \ X# F 允许init在用户于控制台键盘上按下C t r l + A l t + D e l组合键时,重新启动系统。注意,如果该系统放在一个公共场所,系统管理员可将C t r l + A l t + D e l组合键配置为别的行为,比如忽略等。 0 p% X% s5 f" S6 k
) r) ?8 Z. H+ t" g3. sysinit 6 n7 Z: C4 S( X1 Q. z: L% O0 m6 Q 3 P; O# ^ u' {7 k 系统启动时准备运行的命令。比如说,这个命令将清除/tmp。 7 Q# R7 r, F7 ` % t4 q5 P! Y8 _+ F 上面列出的特殊关键字尚不完整。其他的关键字及其使用详情,可参考你的inittab手册页。 ) O- o# K, M+ e! A" D7 ?4 k( b Z0 I! | G
五、在单用户模式下引导 7 S0 j4 `# J' \4 d7 k . t" V s6 P9 b: y0 D 一个重要的运行级别就是单用户模式(运行级别1),该模式中,只有一个系统管理员使用特定的机器,而且尽可能少地运行系统服务,其中包含登录。单用户模式对少数管理任务(比如在/usr分区上运行fsck)而言,是很有必要的,因为这需要卸载分区,但这是不可能的,除非所有的服务系统已被杀死。 , z* ?' z4 }: F& ]' e
9 ~+ V! v8 R0 h( v
一个正在运行的系统可以进入单用户模式,具体做法是利用init,请求运行级别1。内核启动时,在内核命令行指定single或emergency关键字,就可进入运行级别1了。内核同时也为init指定命令行, init从关键字得知自己不应该采用默认的运行级别(内核命令行的输入方式和你启动系统的方式有关)。 / I1 O% t D, i* U5 [4 e' s
; u" h7 }5 E4 w+ W4 t: ]0 @ 有时,以单用户模式进行启动是必要的,这样一来,用户在装入分区之前,或至少在装入分散的/usr分区之前,能手工运行fsck(在分散的文件系统上,任何活动都可能使其更为分散,所以应该尽可能地运行fsck)。 $ }" d! U0 Y, Q, C, R) m
4 R5 x% V; n# H6 z1 C8 | 如果自动化的fsck在启动时失败了,启动脚本init的运行将自动进入单用户模式。这样做是为了防止系统使用不连贯的文件系统,这个文件系统是f s c k不能自动修复的。文件系统不连贯的现象极为少见,而且通常会导致硬盘的不连贯或实验性的内核释放,但最好能做到防患于未然。 / R7 ]7 V9 O: G) [0 ]/ l" c& M& R6 K. g- ?" y* A) S2 q
由于安全上的考虑,在单用户模式下,启动外壳脚本之前,配置得当的系统会要求用户提供root密码。否则,它会简单地为L I L O输入合适的一行代码,以r o o t的身份登录(当然,如果/etc/passwd已经由于文件系统的问题而不连贯了,就不适合这里的原则了,为对付这种情况,你最好随时准备一张启动盘)。 $ w+ U+ e8 o% d5 g5 y. \/ k : k) z8 p/ V& D& L; @, }9 P9 d- H9 u' G 不同的运行级有不同的用处,也应该根据自己的不同情形来设置。 " J& k* c) v+ x+ f7 X+ L6 y1 c$ w
4 {2 R e7 E( c2 K5 p7 D 例如,如果丢失了root口令,那么可以让机器启动进入单用户状态。在启动后的 lilo 提示符下输入: 2 C7 z g) P5 y5 f" M& A. T; K, h
1 ^7 o2 ^5 o' t) u P' e, C: q; ?. k0 c
init=/bin/sh rw 使机器进入运行级1 ,并把 root 文件系统挂为读写。他会跳过所有系统认证,让你可以使用passwd 程序来改变root口令,然后启动到一个新的运行级。