source: chapter06/chroot.xml@ 1a017db

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.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 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 1a017db was 81fd230, checked in by Gerard Beekmans <gerard@…>, 19 years ago

Trunk is now identical to Testing

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

  • Property mode set to 100644
File size: 2.8 KB
Line 
1<?xml version="1.0" encoding="ISO-8859-1"?>
2<!DOCTYPE sect1 PUBLIC "-//OASIS//DTD DocBook XML V4.4//EN" "http://www.oasis-open.org/docbook/xml/4.4/docbookx.dtd" [
3 <!ENTITY % general-entities SYSTEM "../general.ent">
4 %general-entities;
5]>
6<sect1 id="ch-system-chroot">
7<title>Entering the Chroot Environment</title>
8<?dbhtml filename="chroot.html"?>
9
10<para>It is time to enter the chroot environment to begin
11building and installing the final LFS system. As user
12<emphasis>root</emphasis>, run the following command to enter the
13realm that is, at the moment, populated with only the temporary
14tools:</para>
15
16<screen><userinput>chroot "$LFS" /tools/bin/env -i \
17 HOME=/root TERM="$TERM" PS1='\u:\w\$ ' \
18 PATH=/bin:/usr/bin:/sbin:/usr/sbin:/tools/bin \
19 /tools/bin/bash --login +h</userinput></screen>
20
21<para>The <parameter>-i</parameter> option given to the
22<command>env</command> command will clear all variables of the chroot
23environment. After that, only the <envar>HOME</envar>,
24<envar>TERM</envar>, <envar>PS1</envar>, and
25<envar>PATH</envar> variables are set again. The
26<parameter>TERM=$TERM</parameter> construct will set the
27<envar>TERM</envar> variable inside chroot to the same value as
28outside chroot. This variable is needed for programs like
29<command>vim</command> and <command>less</command> to operate
30properly. If other variables are needed, such as
31<envar>CFLAGS</envar> or <envar>CXXFLAGS</envar>, this is
32a good place to set them again.</para>
33
34<para>From this point on, there is no need to use the
35<envar>LFS</envar> variable anymore, because all work will be
36restricted to the LFS file system. This is because the Bash shell is
37told that <filename class="directory">$LFS</filename> is now the root
38(<filename class="directory">/</filename>) directory.</para>
39
40<para>Notice that <filename class="directory">/tools/bin</filename>
41comes last in the <envar>PATH</envar>. This means that a
42temporary tool will not be used anymore as soon as its final version
43is installed. This occurs when the shell does not <quote>remember</quote> the
44locations of executed binaries&mdash;for this reason, hashing is switched
45off by passing the <parameter>+h</parameter> option to <command>bash</command>.</para>
46
47<para>It is important that all the commands throughout the remainder
48of this chapter and the following chapters be run from within the
49chroot environment. If you leave this environment for any reason
50(rebooting for example), remember to first mount the <systemitem
51class="filesystem">proc</systemitem> and <systemitem
52class="filesystem">devpts</systemitem> file systems (discussed in the
53previous section) and enter chroot again before continuing with the
54installations.</para>
55
56<para>Note that the bash prompt will say <quote>I have no
57name!</quote> This is normal because the
58<filename>/etc/passwd</filename> file has not been created yet.</para>
59
60</sect1>
61
Note: See TracBrowser for help on using the repository browser.