创建/etc目录
1 先vi inittab,写入
::sysinit:/etc/rc.d/rcS
::respawn:-/bin/ash
::ctrlaltdel:/sbin/reboot
::shutdown:/etc/rc.d/rcS stop
::shutdown:/bin/umount -a -r
::shutdown:/sbin/swapoff -a
::restart:/sbin/init
注意,/bin/ash为你BUSYBOX的shell,所以名字可能有所不同。然后再chmod +x。这个inittab文件是有格式的--identifier : run_level : action : process
四个字段解释如下:
identifier 登记项标识符,最多为4个字符。用于惟一地标识/etc/inittab文件中的每一个登记项
run_level 系统运行级,即执行登记项的init级别。用于指定相应的登记项适用于哪一个运行级,即在哪一个运行级中被处理。如果该字段为空,那么相应的登记项将适用于所有的运行级。在该字段中,可以同时指定一个或多个运行级,其中各运行级分别以数字0.1.2.3.4.5.6或字母a、b、c表示,且无需对其进行分隔。
action 动作关键字。用于指定init(M)命令或进程对相应进程(在“process”字段定义)所实施的动作。具体动作包括:
1、boot:只有在引导过程中,才执行该进程,但不等待该进程的结束;当该进程死亡时,也不重新启动该进程。
2、bootwait:只有在引导过程中,才执行该进程,并等待进程的结束:当该进程死亡时,也不重新启动该进程。实际上,只有在系统被引导后,并从单用户方式进入多用户方式时 ,这些登记项才被处理;如果系统的默认运行级设置为2(即多用户方式),那么这些登记项在系统引导后将马上被处理。
3、initdefault:指定系统的默认运行级。系统启动时,init将首先查找该登记项。如果存在init将据此决定系统最初要进入的运行级。具体来说,init将指定登记项“run_level" 字段中的最大数字(即最高运行级)为当前系统的默认运行级;如果该字段为空,那么将其解释为“0123456”,并以“6”作为默认运行级。如果不存在该登记项,那么init将要求用户 在系统启动时指定一个最初的运行级。
4、off:如果相应的进程正在运行,那么就发出一个警告信号,等待20秒后,再通过杀死信号强行终止该进程。如果相应的进程并不存在那么就忽略该登记项。
5、once:启动相应的进程,但不等待该进程结束便继续处理/etc/inittab文件中的下一个登记项;当该进程死亡时,init也不重新启动该进程。注意:在从一个运行级进入另一个 运行级时,如果相应的进程仍然在运行,那么init就不重新启动该进程。
6、ondemand:与“respawn”的功能完全相同,但只用于运行级为a、b或c的登记项。
7、powerfail:只在init接收到电源失败信号时执行相应的进程,但不等待该进程结束。
8、powerwait:只在init接收到电源失败信号时执行相应的进程,并在继续对/etc/inittab文件进行任何处理前等待该进程结束。
9、respawn:如果相应的进程还不存在,那么init就启动该进程,同时不等待该进程的结束就继续扫描/etc/inittab文件;当该进程死亡时,init将重新启动该进程。如果相应的进 程已经存在,那么init将忽略该登记项并继续扫描/etc/inittab文件。
10、sysinit:只有在启动或重新启动系统并首先进入单用户时,init才执行这些登记项。而在系统从运行级1-6进入单用户方式时,init并不执行这些登记项。"action”字段为“sy sinit”的登记项在“run_level”字段不指定任何运行级。
11、wait:启动进程并等待其结束,然后再处理/etc/inittab文件中的下一个登记项。
process 所要执行的shell命令。任何合法的shell语法均适用于该字段。
但busybox它忽略前两个字段,所以我们可以看到inittab中的每行都有两个::
3 创建fstab文件:
#
# /etc/fstab: static file system information.
#
# /proc and /sys need to be mounted very early for udev.
#
# file system mount type options dump pass
#/dev/rom0 / romfs rw 0 1
ramfs /tmp ramfs rw 0 0
ramfs /var ramfs rw 0 0
proc /proc proc rw 0 0
#/dev/sdisk14m /mnt/sdisk14m vfat rw 0 0
shm /mnt/docbp/dev/shm tmpfs rw 0 0
tmpfs /dev/shm tmpfs defaults 0 0
sys /sys sysfs defaults 0 0
/dev/mtdblock3 /usr yaffs2 defaults 0 0
这样,当我们在脚本中调用mount -a时,它会去找这个fstab文件,执行挂载操作
4 创建账户相关的文件:passwd shadow group
关于这些文件的说明网上GOOGLE一下一大把。
5 创建shell系统登陆时的环境变量设置文件,vi profile
PS1="zenith# "
export PS1
alias ls='ls --color'
alias ll='ls -l'
export HISTFILE=/usr/root/.ash_history
这个profile文件中的PS1即为登陆后shell左边的输入提示符,HISTFILE这里设置的是shell命令的历史记录文件。
2 mkdir rc.d, cd rc.d, vi rcS写入
# load the configuration information
#/etc/rc.d/rc.conf
#/etc/host
hostname localhost
arg=${1:-start}
if [ $arg = "start" ];then
if [ -x /etc/rc.d/init.d/init.sys ]
then
. /etc/rc.d/init.d/init.sys
fi
else
if [ -f /usr/etc/reboot.script ]
then
. /usr/etc/reboot.script
fi
fi
注意,这里脚本配置,shell没有传入任何参数给rcS时,arg的值为"start",也就是说这时它会运行init.sys脚本,反之会运行reboot.script脚本,这个reboot.script的设计是用来在系统人为重启的时候保存一些设置的,我们可以自行添加。
6 mkdir init.d, cd init.d 创建初始脚本 init.sys
#!/bin/sh
mount -a
# echo "Mounting /proc and /sys "
#mount -t tmpfs tmpfs /mnt/docbp/dev
#start udev to create dev node
if [ -x /etc/rc.d/init.d/udev ]
then
echo "starting udev"
fi
#setup loopback network device
ifconfig lo 127.0.0.1
route add -net 127.0.0.0 netmask 255.0.0.0 lo
#start telnet server
mount -t devpts devpts /dev/pts
telnetd & #-l /bin/login
#load usr profile to set evirement for user space program such as QT
#if [ -x /usr/root/.profile ]
#then
# source /usr/root/.profile
#fi
#run user init scripts to start user program
if [ -f /usr/init/script/Startusrinit.script ]
then
echo "now run usrinit script"
. /usr/init/script/Startusrinit.script
else
ifconfig eth0 192.168.123.101 up
fi
到这里,就把系统运行权交到/usr/init/script/Startusrinit.script脚本里去了。也就是一些应用程序的脚本。
mtab与fstab的关系:
fstab为启动的时候mount -a读取的配置文件,而mtab为指向/proc/mounts的软件链接,每当 mount 挂载分区、umount 卸载分区,都会动态更新 mtab,mtab 总是保持着当前系统中已挂载的分区信息,fdisk、df 这类程序,必须要读取 mtab 文件,才能获得当前系统中的分区挂载情况。
阅读(568) | 评论(0) | 转发(0) |