[f45b1953] | 1 | <sect2>
|
---|
| 2 | <title>Command explanations</title>
|
---|
| 3 |
|
---|
| 4 | <para>The first thing to understand in installing any package written
|
---|
| 5 | by Daniel J. Bernstein, and
|
---|
[c8010baf] | 6 | this includes qmail, djbdns and ucspi-tcp in addition to daemontools, is
|
---|
[f45b1953] | 7 | that he is willing to completely disregard standards if his idea of the
|
---|
| 8 | correct thing to do differs from an particular standard. Professor
|
---|
| 9 | Bernstein is a standards body unto himself when it comes to his own
|
---|
| 10 | software. </para>
|
---|
| 11 |
|
---|
| 12 | <para>It is therefore necessary to make quite a few changes to the
|
---|
| 13 | installation commands for his packages to get them to install in a manner
|
---|
| 14 | that is compliant with the Filesystem Hierarchy Standard (FHS). Most of
|
---|
| 15 | the following commands are due to this difficulty.</para>
|
---|
| 16 |
|
---|
[4e2ef6e5] | 17 | <para><userinput>cd admin/daemontools-0.76</userinput> : First off, the
|
---|
[0d1379a] | 18 | package is unpacked in an <filename>admin</filename> directory. You will find the actual
|
---|
[f45b1953] | 19 | packages two directory levels below this.</para>
|
---|
| 20 |
|
---|
[4e2ef6e5] | 21 | <para><userinput>package/compile</userinput> : This command actually
|
---|
[8e6d39f1] | 22 | compiles the source and prepares the binaries.</para>
|
---|
[f45b1953] | 23 |
|
---|
[0d1379a] | 24 | <para>Since we are installing the binaries in
|
---|
| 25 | <filename>/usr/sbin</filename> rather than creating
|
---|
[8e6d39f1] | 26 | a non-standard <filename>/command</filename> directory, several paths have to be changed:</para>
|
---|
[f45b1953] | 27 | <para><screen><userinput>sed 's|command|usr/sbin|' boot.inittab > boot.inittab~</userinput>
|
---|
| 28 | <userinput>mv boot.inittab~ boot.inittab</userinput></screen></para>
|
---|
[0d1379a] | 29 | <para>In <filename>boot.inittab</filename>,
|
---|
| 30 | <filename>/command/svscanboot</filename> is changed to
|
---|
| 31 | <filename>/usr/sbin/svscanboot</filename>.</para>
|
---|
[c8010baf] | 32 |
|
---|
| 33 | <para><screen><userinput>sed -e 's|/command:/usr/local/bin:/usr/local/sbin:||' \</userinput>
|
---|
| 34 | <userinput> -e 's|command|usr/sbin|' \</userinput>
|
---|
| 35 | <userinput> -e 's|/service|/etc/service|g' svscanboot > svscanboot~ &&</userinput></screen></para>
|
---|
| 36 | <para>Here various paths are adjusted in the svscanboot script. In our setup svscan
|
---|
[0d1379a] | 37 | will check the <filename>/etc/service</filename> directory instead of
|
---|
| 38 | the <filename>/service</filename> directory for
|
---|
[c8010baf] | 39 | daemons to run.</para>
|
---|
[f45b1953] | 40 |
|
---|
[4e2ef6e5] | 41 | <para><userinput>cp * /usr/sbin</userinput> : We must manually copy the
|
---|
[0d1379a] | 42 | binaries to the <filename>/usr/sbin</filename> directory.</para>
|
---|
[f45b1953] | 43 |
|
---|
| 44 | <para><screen><userinput>cat /etc/inittab boot.inittab > /etc/inittab~</userinput>
|
---|
[4e2ef6e5] | 45 | <userinput>mv -f /etc/inittab~ /etc/inittab</userinput></screen>
|
---|
[0d1379a] | 46 | These commands append a line to <filename>/etc/inittab</filename> so that init will launch
|
---|
[c8010baf] | 47 | the svscanboot script.</para>
|
---|
| 48 |
|
---|
[4e2ef6e5] | 49 | <para><userinput>mkdir /etc/service</userinput> : This command creates
|
---|
[c8010baf] | 50 | the daemontools control directory, which - even if empty - needs to exist for
|
---|
| 51 | daemontools to run properly.</para>
|
---|
[f45b1953] | 52 |
|
---|
[4e2ef6e5] | 53 | <para><userinput>telinit Q</userinput> : This command tells the init
|
---|
[f45b1953] | 54 | process to re-read its configuration file (inittab) and act upon any
|
---|
[c8010baf] | 55 | changes that have been made. The svscanboot script is started.</para>
|
---|
[f45b1953] | 56 |
|
---|
| 57 |
|
---|
| 58 | </sect2>
|
---|
| 59 |
|
---|