| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596 | <?xml version="1.0" encoding="ISO-8859-1"?><!DOCTYPE sect1 PUBLIC "-//OASIS//DTD DocBook XML V4.3//EN" "http://www.oasis-open.org/docbook/xml/4.3/docbookx.dtd" [  <!ENTITY % general-entities SYSTEM "../general.ent">  %general-entities;]><sect1 id="ch-scripts-usage"><title>How does the booting process with these scripts work?</title><?dbhtml filename="usage.html"?><indexterm zone="ch-scripts-usage"><primary sortas="a-Bootscripts">Bootscripts</primary><secondary>usage</secondary></indexterm><para>Linux uses a special booting facility named SysVinit. It's based on aconcept of <emphasis>run-levels</emphasis>. It can be widely different from one system to another, so it can't be assumed that because things worked in <insert distro name> they should work like that in LFS too. LFS has its own way of doing things, but it respects generally accepted standards.</para><para>SysVinit (which we'll call <emphasis>init</emphasis> from now on) works using a run-levels scheme. There are 7 (from 0 to 6) run-levels(actually, there are more run-levels but they are for special cases and generally not used. The init man page describes those details), and each one of those corresponds to the things the computer is supposed to do when it starts up. The default run-level is 3. Here are the descriptions of the different run-levels as they are often implemented:</para><literallayout>0: halt the computer1: single-user mode2: multi-user mode without networking3: multi-user mode with networking4: reserved for customization, otherwise does the same as 35: same as 4, it is usually used for GUI login (like X's xdm or KDE's kdm)6: reboot the computer</literallayout><para>The command used to change run-levels is <command>init<runlevel></command> where <runlevel> is the target run-level. Forexample, to reboot the computer, a user would issue the <command>init6</command> command. The <command>reboot</command> command is just an alias forit, as is the <command>halt</command> command an alias for <command>init0</command>.</para><para>There are a number of directories under <filename>/etc/rc.d</filename>that look like like rc?.d (where ? is the number of the run-level) and rcsysinit.dall containing a number of symbolic links. Some begin with a K, the others beginwith an S, and all of them have two numbers following the initial letter. The Kmeans to stop (kill) a service, and the S means to start a service. The numbersdetermine the order in which the scripts are run, from 00 to 99; the lower thenumber the sooner it gets executed. When init switches to another run-level, theappropriate services get killed and others get started.</para><para>The real scripts are in /etc/rc.d/init.d. They do all the work, and thesymlinks all point to them. Killing links and starting links point to the same script in /etc/rc.d/init.d. That's because the scripts can be called with different parameters like start, stop, restart, reload, status. When a K link is encountered, the appropriate script is run with the stop argument. When an S link is encountered, the appropriate script is run with the start argument.</para><para>There is one exception. Links that start with an S in therc0.d and rc6.d directories will not cause anything to be started. Theywill be called with the parameter <emphasis>stop</emphasis> to stopsomething. The logic behind it is that when you are going to reboot orhalt the system, you don't want to start anything, only stop thesystem.</para><para>These are descriptions of what the arguments make the scripts do:</para><itemizedlist><listitem><para><emphasis>start</emphasis>: The service is started.</para></listitem><listitem><para><emphasis>stop</emphasis>: The service is stopped.</para></listitem><listitem><para><emphasis>restart</emphasis>: The service is stopped and then started again.</para></listitem><listitem><para><emphasis>reload</emphasis>: The configuration of the service is updated. This is used after the configuration file of a service was modified, when the service doesn't need to be restarted.</para></listitem><listitem><para><emphasis>status</emphasis>: Tells if the service is running and with which PIDs.</para></listitem></itemizedlist><para>Feel free to modify the way the boot process works (after all, it's your own LFS system). The files given here are just an example of how it can be done in a nice way (well, what we consider nice -- you may hate it).</para></sect1>
 |