第八章 目标系统的环境设置

在完成临时系统的搭建之后,接下来我们开始正式进入目标系统的搭建。

在搭建目标系统之前,我们首先需要设置一下目标系统的环境。

目标系统的制作需要主系统的root用户权限,所以务必确认当前是否为root权限。


1.制作目标系统不再需要lfs用户,所以使用以下命令重新设置目录权限

chown -R root:root $LFS/tools

这样做是因为切换到临时系统后lfs已经不存在,为了避免文件访问权限问题,我们将临时系统中所以文件的所属权都交给root用户。
  • -R 递归式地改变指定目录及其下的所有子目录和文件的拥有者。

2.创建三个重要的特殊目录
mkdir -pv $LFS/{dev,proc,sys}

这三个目录都是根目录下的目录

  • /dev目录用户存放各种设备文件
  • /proc和/sys目录用于存放和内核数据相关的内容
这三个目录在接下来软件包的编译过程中将会被使用到。

3.创建目标系统所必须的两个设备文件

mknod -m 600 $LFS/dev/console c 5 1
mknod -m 666 $LFS/dev/null c 1 3

  • -m 指定创建文件的权限
  • 600表示只有所有者有读写权限
  • 666表示所有者、组用户和其他用户都有读写权限
  • c(字符型设备) x x 前面的x表示主设备号 后面的x表示次设备号
4.利用主系统加载几个重要的文件系统
mount -vt devpts devpts $LFS/dev/pts
mount -vt tmpfs shm $LFS/dev/shm
mount -vt proc proc $LFS/proc
mount -vt sysfs sysfs $LFS/sys
  • 使用mount的bind参数建立/dev到$LFS/dev的镜像映射
  • 挂载2个内核的虚拟文件系统到/dev的pts和shm目录
  • 挂载proc和sys文件系统
5.复制源码包
  • 为了方便源码包的使用,将lfs-sources里面所有的源码包复制到$LFS/sources目录
cp -a /lfs-sources/* $LFS/sources/

6.切换到目标系统
chroot "$LFS" /tools/bin/env -i \
HOME=/root TERM="$TERM" PS1='\u:\w\$ ' \
PATH=/bin:/usr/bin:/sbin:/usr/sbin:/tools/bin \
/tools/bin/bash --login +h
  • 切换到目标系统的目录下,避免受到主系统的影响
  • "$LFS":指定切换目录,切换后该目录成为系统的根目录
  • HOME=/root:指定切换后增加一个HOME变量,并取值为"/root",HOME变量用于指定当前用户的主目录
  • TERM="$TERM":指定切换后增加一个TERM环境变量。TERM的用处是使一些终端操作比较密集的程序(如vim和less等)能正常执行
  • PS1='\u:\w\$':设置切换后的PS1的取值,PS1变量的用处是设置命令行的提示符。"\u"表示显示用户名、"\w"表示显示当前目录、"\$"是特殊的提示符号,例如root用户显示#,其他用户显示$
  • PATH=/bin:/usr/bin:/sbin:/usr/sbin:/tools/bin:设置切换后的PATH内容,这是一个很重要的环境变量,在运行不明路径的命令时将按照该环境变量中的目录设置顺序查找
  • /tools/bin/bash --login +h:使chroot在切换后运行/tools/bin/bash命令而进入用户交互状态。"--login"使bash以登录方式启动(bash的登录方式与非登录方式区别是:登录方式会去执行/etc/profile和~/.bash_profile文件,非登录方式只执行~/.bashrc),bash具有记住命令执行路径的功能,该功能开启时,再次执行同一条命令将不再根据PATH中的顺序进行搜索,这个功能会影响到目标系统的制作,使用"+h"参数强制关闭该功能
系统的/etc/passwd还未创建,因此无法显示用户名,切换到临时系统后会显示为"I have no name"。

7.建立目标系统的目录结构
这一步我们按照Linux系统规范来创建较为标准的系统目录结构
mkdir -pv /{bin,boot,etc/opt,home,lib,mnt,opt}
mkdir -pv /{media/{floppy,cdrom},sbin,srv,var}
install -dv -m 0750 /root
install -dv -m 1777 /tmp /var/tmp
mkdir -pv /usr/{,local/}{bin,include,lib,sbin,src}
mkdir -pv /usr/{,local/}share/{doc,info,locale,man}
mkdir -pv /usr/{,local/}share/{misc,terminfo,zoneinfo}
mkdir -pv /usr/{,local/}share/man/man{1..8}
for dir in /usr /usr/local; do
ln -sv share/{man,doc,info} $dir
done
mkdir -pv /var/{lock,log,mail,run,spool}
mkdir -pv /var/{opt,cache,lib/{misc,locate},local}
  • install -dv -m 0750 /root install命令可以用来复制文件、创建目录等。
  • 参数d:创建目录,目录名由用户指定
  • 参数m:设置访问权限
  • 参数v:显示命令完成的结果

8.创建必要的链接
ln -sv /tools/bin/{bash,cat,echo,grep,pwd,stty} /bin
ln -sv /tools/bin/perl /usr/bin
ln -sv /tools/lib/libgcc_s.so{,.1} /usr/lib
ln -sv /tools/lib/libstdc++.so{,.6} /usr/lib
ln -sv bash /bin/sh
touch /etc/mtab
在编译软件包目标系统的过程中,部分编译程序会使用绝对路径来寻找命令或文件
  • ln -sv /tools/bin/{bash,cat,echo,grep,pwd,stty} /bin
  • ln -sv /tools/bin/perl /usr/bin
  • 以上两个命令将/tools/bin下指定的文件在/bin目录下建立同名链接文件
  • ln -sv /tools/lib/libgcc_s.so{,.1} /usr/lib
  • ln -sv /tools/lib/libstdc++.so{,.6} /usr/lib
  • 以上两个命令将编译过程中会使用的几个共享库链接到目标系统中
  • touch /etc/mtab 存放当前文件系统的挂载情况,需要提前创建
  • touch命令可以用来生成新的空文件、修改文件的时间戳

9.创建root及nobody用户和必要的组
cat > /etc/passwd << "EOF"
root:x:0:0:root:/root:/bin/bash
nobody:x:99:99:Unprivileged User:/dev/null:/bin/false
EOF
cat > /etc/group << "EOF"
root:x:0:
bin:x:1:
sys:x:2:
kmem:x:3:
tty:x:4:
tape:x:5:
daemon:x:6:
floppy:x:7:
disk:x:8:
lp:x:9:
dialout:x:10:
audio:x:11:
video:x:12:
utmp:x:13:
usb:x:14:
cdrom:x:15:
mail:x:34:
nogroup:x:99:
EOF
exec /tools/bin/bash --login +h
  • /etc/passwd中存放当前系统的用户列表以及用户基本的设置信息,文件中的每一行对应一个用户信息,用户信息用":"来分隔,含义如下:
  • 用户名:用户密码:用户id:用户组id:备注:用户主目录:用户登录程序
  • /etc/group文件中存放的是当前系统的用户组以及用户列表,这里建立了18个基本用户组
  • 设置好/etc/passwd和/etc/group之后文件系统已经具备有效用户及为用户组,重新运行bash即可正常使用用户名

10.创建临时文件和日志文件
touch /var/run/utmp /var/log/{btmp,lastlog,wtmp}
chgrp -v utmp /var/run/utmp /var/log/lastlog
chmod -v 664 /var/run/utmp /var/log/lastlog
  • login及init等程序会使用日志文件来记录信息,若日志文件不存在,程序则无法写入。提前创建他们并且设置合适的访问权限
至此,目标系统的环境设置已经完成,即创建目标系统的准备工作已经基本完成。
下一章开始介绍目标系统的软件包的安装。
  • 2
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值