source: chapter03/creatingdirs.xml@ 082acf2

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_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 082acf2 was 082acf2, checked in by Mark Hymers <markh@…>, 23 years ago

add &'s

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

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