ubuntu upstart启动流程分析

简介

最近做Linux课程设计(内核裁剪和文件系统定制),选择了ubuntu10.10作为实验的平台。不同的Linux发行版,用户态的初始化机制有所差别,ubuntu自从6.10版本之后就使用了较新的upstart机制来进行系统的初始化。

upstart是一种基于事件驱动的服务启动机制,可以使多个系统任务在保持依赖关系的前提下并发启动(据说这样这样启动会比较快,理论上应当如此)。使用upstart机制时,我们通过/etc/init下的一系列 *.conf 配置文件来指定各种系统服务的依赖关系(启动时机)。系统启动时,upstart主进程/sbin/init会解析这些配置文件,按照指定的依赖关系并发启动各种服务与应用。

主要程序

upstart有三个主要的进程:

init: upstart主进程,是Linux系统中的“应用程序管理器”,是其他所有进程的源头(PID为1),它会读取配置文件,处理各种服务和应用程序的依赖关系,根据事件(信号)来启动这些功能与服务,并动态地进行管理。
initctl:upstart事件管理器,可以被应用程序进程用来通知init哪些事件(信号)发生。
telinit:管理运行级别(运行级别,为了兼容其他旧的发行版而保留,在upstart里面,运行级别的改变被当成某种事件来处理)。

配置文件

每个服务的conf配置文件通常指明了执行依赖的事件(信号)、执行的环境、执行的任务属性、执行的任务内容等。

如下面这一典型的脚本,指明了执行的任务是启动名为tty2的终端,依赖于startup事件,console owner表示执行时输出定向到控制台,respawn属性指定了如果进程终结将重新启动。

1
2
3
4
5
6
7
start on startup
 
respawn
 
console owner
 
exec /sbin/getty -8 38400 tty2

启动流程

对于ubuntu发行版,启动/sbin/init之后upstart会经过以下启动流程:

1. upstart内部初始化之后,启动startup事件,ubuntu系统开始初始化;

2. 依赖于startup事件的任务启动,其中最重要的是mountall,它进行了硬盘和文件系统的挂载,并依次触发了一系列事件,包括:local-filesystems, vitual-filesystems, all-swaps等;

3. vitual-filesystems事件触发了udev相关的系列任务,用于设备事件管理。其中。upstart-udev-bridge把设备事件转化为upstart事件,而udevtrigger对于已经挂载的设备重新触发设备事件(因为udevd启动的时候很多设备事件已经错过了)。

4. udevtrigger会触发本地回环的网络接口启动(net-device-up)事件,经过这一阶段本地回环(127.0.0.1)可用;

5. 等到文件系统挂载完成,本地回环的网络接口启动,依赖于这两个事件的的rc-sysinit在万众瞩目中正式启动,调用telinit设置了系统的运行级别,系统进入runlevel管理的新时代!!!

从startup到runlevel的过程见下图:

upstart启动流程图

upstart启动流程图

rc-sysinit中,使用telinit为系统设置了运行级别,触发runlevel事件,依赖于runlevel事件的服务启动,其中有非常重要的tty,而一些服务的关闭,系统的关机、重启等动作也依赖于runlevel的变化。

tty1.conf中,任务内容为exec /sbin/getty -8 38400 tty1,即使用getty程序开启名为tty1的终端,getty会调用login启动登陆认证,login从/etc/passwd获取账户信息,从/etc/shadow进行密码验证,如果登陆成功则启动一个shell给登录的用户,这时候你就可以开始工作啦!

如果你更喜欢使用putty登录,那么系统需要安装sshd,安装之后/etc/init下会多出一个ssh.conf,它定义了守护进程sshd的启动时机,sshd的启动依赖于filesystem事件,如下图所示。

upstart启动runlevel处理

upstart启动runlevel处理

在upstart机制下,如果你希望系统开机启动一项新的服务,只需往/etc/init里面增加自己定义的.conf配置文件即可。

(全文完)

介绍的比较详细。

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Ubuntu启动流程可以分为以下几个步骤: 1. BIOS/UEFI:计算机开机时首先会执行基本输入输出系统(BIOS)或统一固件接口(UEFI),进行硬件自检和初始化,并加载操作系统引导程序。 2. 引导加载程序(Bootloader):BIOS/UEFI会加载引导加载程序,最常用的引导加载程序是GRUB(GRand Unified Bootloader)。GRUB会显示启动菜单,让用户选择要启动的操作系统。 3. 内核加载:一旦用户选择了要启动Ubuntu操作系统,引导加载程序会加载Linux内核(vmlinuz),并将控制权交给内核。 4. 初始化RAM文件系统(initramfs):内核会加载一个临时文件系统(initramfs),其中包含了启动所需的驱动程序和工具。initramfs会在启动过程中被挂载为根文件系统。 5. init进程:内核启动后,会执行第一个用户空间进程init。在Ubuntu中,init进程是systemd或Upstart。init进程负责启动其他系统服务和进程。 6. 系统初始化:init进程会根据配置文件启动各种系统服务,如网络管理、登录管理、时间同步等。此阶段还会进行硬件初始化、加载驱动程序等操作。 7. 用户登录:一旦系统初始化完成,登录管理器(如GDM或LightDM)会显示登录界面,用户可以输入用户名和密码登录到桌面环境。 8. 桌面环境启动:一旦用户成功登录,桌面环境(如GNOME、KDE等)会启动,并加载用户配置和应用程序。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值