source: chapter05/creatingdirs.xml@ 5d3dcef

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_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 5d3dcef was 6925e03, checked in by Marc Heerdink <gimli@…>, 22 years ago

Fixed a very very tiny typo that looks a bit weird in the book.

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

  • Property mode set to 100644
File size: 2.8 KB
Line 
1<sect1 id="ch05-creatingdirs">
2<title>Creating directories</title>
3<?dbhtml filename="creatingdirs.html" dir="chapter05"?>
4
5<para>Let's now create the directory tree on the LFS partition based on
6the FHS standard, which can be found at
7<ulink url="http://www.pathname.com/fhs/">http://www.pathname.com/fhs/</ulink>.
8Issuing the following commands will create a default directory layout:</para>
9
10<para><screen><userinput>cd $LFS &amp;&amp;
11mkdir -p bin boot dev/pts etc/opt home lib mnt proc root sbin tmp var opt &amp;&amp;
12for dirname in $LFS/usr $LFS/usr/local
13<literal>&nbsp;&nbsp;&nbsp;do</literal>
14&nbsp;&nbsp;&nbsp;mkdir $dirname
15&nbsp;&nbsp;&nbsp;cd $dirname
16&nbsp;&nbsp;&nbsp;mkdir bin etc include lib sbin share src var
17&nbsp;&nbsp;&nbsp;ln -s share/man
18&nbsp;&nbsp;&nbsp;ln -s share/doc
19&nbsp;&nbsp;&nbsp;ln -s share/info
20&nbsp;&nbsp;&nbsp;cd $dirname/share
21&nbsp;&nbsp;&nbsp;mkdir dict doc info locale man nls misc terminfo zoneinfo
22&nbsp;&nbsp;&nbsp;cd $dirname/share/man
23&nbsp;&nbsp;&nbsp;mkdir man{1,2,3,4,5,6,7,8}
24done &amp;&amp;
25cd $LFS/var &amp;&amp;
26mkdir -p lock log mail run spool tmp opt cache lib/misc local &amp;&amp;
27cd $LFS/opt &amp;&amp;
28mkdir bin doc include info lib man &amp;&amp;
29cd $LFS/usr &amp;&amp;
30ln -s ../var/tmp</userinput></screen></para>
31
32<para>Normally, directories are created with permission mode 755, which isn't
33desired for all directories. The first change is a mode 0750 for the
34$LFS/root directory. This is to make sure that not just everybody can
35enter the /root directory (the same a user would do with /home/username
36directories). The second change is a mode 1777 for the tmp
37directories. This way, any user can write data to the /tmp or /var/tmp
38directory but cannot remove another user's files (the latter is caused
39by the so-called "sticky bit" - bit 1 of the 1777 bit mask).</para>
40
41<para><screen><userinput>cd $LFS &amp;&amp;
42chmod 0750 root &amp;&amp;
43chmod 1777 tmp var/tmp</userinput></screen></para>
44
45<para>Now that the directories are created, copy the source files that were
46downloaded in chapter 3 to some subdirectory under $LFS/usr/src (you
47will need to create the desired directory yourself).</para>
48
49<sect2>
50<title>FHS compliance notes</title>
51
52<para>The FHS stipulates that the /usr/local directory should contain the
53bin, games, include, lib, man, sbin, and share subdirectories. You can
54alter your /usr/local directory yourself if you want your system to be
55FHS-compliant.</para>
56
57<para>Also, the standard says that there should exist a /usr/share/games
58directory, which we don't much like for a base system. But feel free to
59make your system FHS-compliant if you wish. The FHS isn't precise as
60to the structure of the /usr/local/share subdirectories, so we took the
61liberty of creating the directories that we felt needed.</para>
62
63</sect2>
64
65</sect1>
66
Note: See TracBrowser for help on using the repository browser.