本文主要来自$Android_SOURCE/system/init/readme.txt的翻译.
1 简述
Android init.rc文件由系统第一个启动的init程序解析,此文件由语句组成,主要包含了四种类型的语句:Action,Commands,Services,Options.在init.rc文件中一条语句通常是占据一行.单词之间是通过空格符来相隔的.如果需要在单词内使用空格,那么得使用转义字符"\",如果在一行的末尾有一个反斜杠,那么是换行折叠符号,应该和下一行合并成一起来处理,这样做主要是为了避免一行的字符太长,与C语言中的含义是一致的。注释是以#号开头。 Action和services显式声明了一个语句块,而commands和options属于最近声明的语句块。在第一个语句块之前 的commands和options会被忽略.
在具体讲解这之前,有些关键词得先了解.
2 关键字
token: 计算机语言中的一个单词,就跟英文中的单词差不多一人概念.
Section: 语句块,相当于C语言中大括号内的一个块。一个Section以Service或On开头的语句块.以Service开头的Section叫做服务,而以On开头的叫做动作(Action).
services: 服务.
Action: 动作
commands:命令.
options:选项.
trigger:触发器,或者叫做触发条件.
class: 类属,即可以为多个service指定一个相同的类属,方便操作同时启动或停止.
如何将ramdisk.img 编译进内核和修改init.rc http://www.linuxidc.com/Linux/2013-07/87026.htm
Android init 进程 init.rc init.*.rc http://www.linuxidc.com/Linux/2013-01/77884.htm
Android: 启动init.rc 中service的权限问题 http://www.linuxidc.com/Linux/2011-04/35014.htm
Android分析之init.rc http://www.linuxidc.com/Linux/2011-02/32762.htm
Android启动脚本init.rc http://www.linuxidc.com/Linux/2010-09/28637.htm
3 语句解析
3.1 动作(Action)
动作表示了一组命令(commands)组成.动作包含一个触发器,决定了何时执行这个动作。当触发器的条件满足时,这个动作会被加入到已被执行的队列尾。如果此动作在队列中已经存在,那么它将不会执行.
一个动作所包含的命令将被依次执行。动作的语法如下所示:
on <trigger>
<command>
<command>
<command>
3.2 服务(services)
服务是指那些需要在系统初始化时就启动或退出时自动重启的程序.
它的语法结构如下所示:
service <name> <pathname> [ <argument> ]*
<option>
<option>
...
3.3 选项(options)
选项是用来修改服务的。它们影响如何及何时运行这个服务.
选项 | 描述 |
critical | 据设备相关的关键服务,如果在4分钟内,此服务重复启动了4次,那么设备将会重启进入还原模式。 |
disabled | 服务不会自动运行,必须显式地通过服务器来启动。 |
setenv <name> <value> | 设置环境变量 |
socket <name> <type> <perm> [ <user> [ <group> ] ] | 在/dev/socket/下创建一个unix domain的socket,并传递创建的文件描述符fd给服务进程.其中type必须为dgram或stream,seqpacket.用户名和组名默认为0 |
user <username> | 在执行此服务之前先切换用户名。当前默认为root. |
group <groupname> [ <groupname> ]* | 类似于user,切换组名 |
oneshot | 当此服务退出时不会自动重启. |
class <name> | 给服务指定一个类属,这样方便操作多个服务同时启动或停止.默认情况下为default. |
onrestart | 当服务重启时执行一条指令, |
3.4 触发器(trigger)
触发器用来描述一个触发条件,当这个触发条件满足时可以执行动作.
触发器 | 描述 |
boot | 当init程序执行,并载入/init.conf文件时触发. |
<name>=<value> | 当属性名对应的值设置为指定值时触发. |
device-added-<path> | 当添加设备时触发. |
device-removed-<path> | 当设备移除时触发. |
service-exited-<name> | 当指定的服务退出时触发. |
3.5 命令(commands)
3.6 属性(Properties)
init程序在运行时会更新属性系统的一些属性,提供程序内部正在执行的信息.
属性名 | 描述 |
init.action | 当前正在执行的动作,如果没有则为空字符串"" |
init.command | 当前正在执行的命令.没有则为空字符串. |
init.svc.<name> | 当前某个服务的状态,可为"stopped", "running", "restarting" |
4 一个 init.conf例子
# not complete -- just providing some examples of usage
#
on boot
export PATH /sbin:/system/sbin:/system/bin
export LD_LIBRARY_PATH /system/lib
mkdir /dev
mkdir /proc
mkdir /sys
mount tmpfs tmpfs /dev
mkdir /dev/pts
mkdir /dev/socket
mount devpts devpts /dev/pts
mount proc proc /proc
mount sysfs sysfs /sys
write /proc/cpu/alignment 4
ifup lo
hostname localhost
domainname localhost
mount yaffs2 mtd@system /system
mount yaffs2 mtd@userdata /data
import /system/etc/init.conf
class_start default
service adbd /sbin/adbd
user adb
group adb
service usbd /system/bin/usbd -r
user usbd
group usbd
socket usbd 666
service zygote /system/bin/app_process -Xzygote /system/bin --zygote
socket zygote 666
service runtime /system/bin/runtime
user system
group system
on device-added-/dev/compass
start akmd
on device-removed-/dev/compass
stop akmd
service akmd /sbin/akmd
disabled
user akmd
group akmd
5 调试注意事项
在默认情况下,通过init程序启动的程序的标准输出stdout和标准错误输出stderr会重定向到/dev/null.如:
service akmd /system/bin/logwrapper /sbin/akmd
为了更方便调试你的程序,你可以使用Android的log系统,标准输出和标准错误输出会重定义到Android的log系统中来.