source: chapter07/usage.xml@ f12213a

10.0 10.0-rc1 10.1 10.1-rc1 11.0 11.0-rc1 11.0-rc2 11.0-rc3 11.1 11.1-rc1 11.2 11.2-rc1 11.3 11.3-rc1 12.0 12.0-rc1 12.1 12.1-rc1 6.0 6.1 6.1.1 6.3 6.4 6.5 6.6 6.7 6.8 7.0 7.1 7.2 7.3 7.4 7.5 7.5-systemd 7.6 7.6-systemd 7.7 7.7-systemd 7.8 7.8-systemd 7.9 7.9-systemd 8.0 8.1 8.2 8.3 8.4 9.0 9.1 arm bdubbs/gcc13 ml-11.0 multilib renodr/libudev-from-systemd s6-init trunk v3_0 v3_1 v3_2 v3_3 v4_0 v4_1 v5_0 v5_1 v5_1_1 xry111/arm64 xry111/arm64-12.0 xry111/clfs-ng xry111/lfs-next xry111/loongarch xry111/loongarch-12.0 xry111/loongarch-12.1 xry111/mips64el xry111/pip3 xry111/rust-wip-20221008 xry111/update-glibc
Last change on this file since f12213a was b822811, checked in by Mark Hymers <markh@…>, 23 years ago

XML changes

git-svn-id: http://svn.linuxfromscratch.org/LFS/trunk/BOOK@827 4aa44e1e-78dd-0310-a6d2-fbcd4c07a689

  • Property mode set to 100644
File size: 3.8 KB
RevLine 
[0ad6d9a]1<sect1 id="ch07-usage">
2<title>How does the booting process with these scripts work?</title>
3
[b822811]4<para>Linux uses a special booting facility named SysVinit. It's based on a
[0ad6d9a]5concept of <emphasis>runlevels</emphasis>. It can be widely different
[53b5ccf]6from one system to another, so it can not be assumed that because things
[0ad6d9a]7worked in &lt;insert distro name&gt; they should work like that in LFS
8too. LFS has it's own way of doing things, but it respects generally
[b822811]9accepted standards.</para>
[0ad6d9a]10
[b822811]11<para>SysVinit (which we'll call <emphasis>init</emphasis> from now on) works
[a4d9786b]12using a runlevels scheme. There are 7 (from 0 to 6) runlevels
13(actually, there are more runlevels but they are for special cases and
[53b5ccf]14generally not used. The init man page describes those details), and each
15one of those corresponds to the things the computer is supposed to do when
[a4d9786b]16it starts up. The default runlevel is 3. Here are the descriptions of the
[b822811]17different runlevels as they are often implemented:</para>
[0ad6d9a]18
[b822811]19<literallayout>0: halt the computer
[0ad6d9a]201: single-user mode
212: multi-user mode without networking
223: multi-user mode with networking
234: reserved for customization, otherwise does the same as 3
[3ccc1df]245: same as 4, it is usually used for GUI login (like X's xdm or KDE's kdm)
[b822811]256: reboot the computer</literallayout>
[0ad6d9a]26
[b822811]27<para>The command used to change runlevels is <userinput>init
[443aab7]28&lt;runlevel&gt;</userinput> where &lt;runlevel&gt; is
[53b5ccf]29the target runlevel. For example, to reboot the computer, a user would issue
[0ad6d9a]30the init 6 command. The reboot command is just an alias, as is the halt
[b822811]31command an alias to init 0.</para>
[0ad6d9a]32
[b822811]33<para>The /etc/init.d/rcS script is run at every startup of the computer,
[0ad6d9a]34before any runlevel is executed and runs the scripts listed in
[b822811]35/etc/rcS.d</para>
[0ad6d9a]36
[b822811]37<para>There are a number of directories under /etc that look like like rc?.d
[53b5ccf]38where ? is the number of the runlevel and rcS.d. A user might take a look
39at one of
40them (after this chapter is finished, right now there's nothing
[0ad6d9a]41there yet). There are a number of symbolic links. Some begin with an K,
42the others begin with an S, and all of them have three numbers following
43the initial letter. The K means to stop (kill) a service, and the S means
44to start a service. The numbers determine the order in which the scripts
45are run, from 000 to 999; the lower the number the sooner it gets
46executed. When init switches to another runlevel, the appropriate
[b822811]47services get killed and others get started.</para>
[0ad6d9a]48
[b822811]49<para>The real scripts are in /etc/init.d. They do all the work, and the
[9aab9f5]50symlinks all point to them. Killing links and starting
[0ad6d9a]51links point to the same script in /etc/init.d. That's because the scripts
52can be called with different parameters like start, stop, restart, reload,
53status. When a K link is encountered, the appropriate script is run with
54the stop argument. When a S link is encountered, the appropriate script
[b822811]55is run with the start argument.</para>
[0ad6d9a]56
[b822811]57<para>These are descriptions of what the arguments make the
58scripts do:</para>
[b2c0c79]59
60<itemizedlist>
61
[b822811]62<listitem><para><emphasis>start</emphasis>: The service is
63started.</para></listitem>
[b2c0c79]64
[b822811]65<listitem><para><emphasis>stop</emphasis>: The service is
66stopped.</para></listitem>
[b2c0c79]67
[b822811]68<listitem><para><emphasis>restart</emphasis>: The service is
69stopped and then started again.</para></listitem>
[b2c0c79]70
[b822811]71<listitem><para><emphasis>reload</emphasis>: The configuration
72of the service is updated.
[53b5ccf]73This is used after the configuration file of a service was modified, when
[b822811]74the service doesn't need to be restarted.</para></listitem>
[b2c0c79]75
[b822811]76<listitem><para><emphasis>status</emphasis>: Tells if the service
77is running and with which PID's.</para></listitem>
[b2c0c79]78
79</itemizedlist>
[0ad6d9a]80
[b822811]81<para>Feel free to modify the way the boot process works (after all it's your
[53b5ccf]82LFS system, not ours). The files here are just an example of how it can be
[b822811]83done in a nice way (well what we consider nice anyway. You may hate it).</para>
[0ad6d9a]84
85</sect1>
86
Note: See TracBrowser for help on using the repository browser.