* Y0 N3 [. y L( K K 允许init在用户于控制台键盘上按下C t r l + A l t + D e l组合键时,重新启动系统。注意,如果该系统放在一个公共场所,系统管理员可将C t r l + A l t + D e l组合键配置为别的行为,比如忽略等。 ! E' e1 {% r d. ?( M' ~' f 5 S% E. z7 Y ~3. sysinit ; s; o, i1 ^$ q2 m1 i* ]/ B
9 Q7 @ f- g- S" L; x
系统启动时准备运行的命令。比如说,这个命令将清除/tmp。 , S, Z/ r, Y: v. e& B ) u# a. n7 T4 D: W( y, w* ~ 上面列出的特殊关键字尚不完整。其他的关键字及其使用详情,可参考你的inittab手册页。 % I5 G8 Z5 c* E& C9 `$ a& {/ x6 K ; \7 m, |& x6 U: @ 五、在单用户模式下引导 3 S* E8 @# T4 m+ h6 h, D
; T8 v' x. H6 Z9 j5 n3 Y
一个重要的运行级别就是单用户模式(运行级别1),该模式中,只有一个系统管理员使用特定的机器,而且尽可能少地运行系统服务,其中包含登录。单用户模式对少数管理任务(比如在/usr分区上运行fsck)而言,是很有必要的,因为这需要卸载分区,但这是不可能的,除非所有的服务系统已被杀死。 ! p, M) W! j; D2 ~2 Z& D 3 N. W0 L! v+ m2 Y 一个正在运行的系统可以进入单用户模式,具体做法是利用init,请求运行级别1。内核启动时,在内核命令行指定single或emergency关键字,就可进入运行级别1了。内核同时也为init指定命令行, init从关键字得知自己不应该采用默认的运行级别(内核命令行的输入方式和你启动系统的方式有关)。 3 l) G1 E' K. S3 u
* q, R4 P7 \$ C' ]5 E 有时,以单用户模式进行启动是必要的,这样一来,用户在装入分区之前,或至少在装入分散的/usr分区之前,能手工运行fsck(在分散的文件系统上,任何活动都可能使其更为分散,所以应该尽可能地运行fsck)。 . ^% G K( b" \( s) m 9 `/ _0 {$ a2 ?$ v2 q, @, o/ O 如果自动化的fsck在启动时失败了,启动脚本init的运行将自动进入单用户模式。这样做是为了防止系统使用不连贯的文件系统,这个文件系统是f s c k不能自动修复的。文件系统不连贯的现象极为少见,而且通常会导致硬盘的不连贯或实验性的内核释放,但最好能做到防患于未然。 7 c3 L# Z7 U& M" ^" A ^' @
8 q8 w8 A: w( d7 q3 h0 ? 由于安全上的考虑,在单用户模式下,启动外壳脚本之前,配置得当的系统会要求用户提供root密码。否则,它会简单地为L I L O输入合适的一行代码,以r o o t的身份登录(当然,如果/etc/passwd已经由于文件系统的问题而不连贯了,就不适合这里的原则了,为对付这种情况,你最好随时准备一张启动盘)。 / w& ?6 h' C7 i& ]; ~' R( l: x
不同的运行级有不同的用处,也应该根据自己的不同情形来设置。 4 a/ ^6 v' [2 e" e! V- }; s7 c- k2 b' @
! K0 m, B. w3 {0 I( U& S& H
例如,如果丢失了root口令,那么可以让机器启动进入单用户状态。在启动后的 lilo 提示符下输入: + `8 Z+ O; `2 K4 \2 _9 p+ O
3 m- e+ }9 t! @
init=/bin/sh rw 使机器进入运行级1 ,并把 root 文件系统挂为读写。他会跳过所有系统认证,让你可以使用passwd 程序来改变root口令,然后启动到一个新的运行级。