android init.rc命令快速对照表

注1:另外还讲述了怎样输出log:

 

Debugging notes
---------------
By default, programs executed by init will drop stdout and stderr into
/dev/null. To help with debugging, you can execute your program via the
Andoird program logwrapper. This will redirect stdout/stderr into the
Android logging system (accessed via logcat).
For example
service akmd /system/bin/logwrapper /sbin/akmd
 注2:讲述了一个新的命令

 

 

sysclktz <mins_west_of_gmt>
   Set the system clock base (0 if system clock ticks in GMT)
 

 

注3:triggers

 

boot
   This is the first trigger that will occur when init starts
   (after /init.conf is loaded)
<name>=<value>
   Triggers of this form occur when the property <name> is set
   to the specific value <value>.
device-added-<path>
device-removed-<path>
   Triggers of these forms occur when a device node is added
   or removed.
service-exited-<name>
   Triggers of this form occur when the specified service exits.

------------------------------------------ 

 

 

init 由如下四种类型语句组成: 

  • Actionn       :行为
  • Commands  
  • Services
  • Options
语法(language syntax)结构如下:

 

  • 每一个语句占据一行,并且各个关键字被空格分开。c规范中的(如 )反斜杠将被忽略(backslash escapes)而被认为是一个空格 ,双引号用来保证空格不会把一个文字串分分为多个关键字。行最后的反斜杠用作续行。
  • 由 # (前面允许有空格)开始的行都是注释行(comment)
  • 一个actions 或 services 的开始隐含声明了一个新的段,所有commands 或 options 属于最近的声明。在第一个段之前的 commands 或 options 都会被忽略
  • 每一个actions 和 services 都有不同的名字。后面与前面发生重名的,那么这个后面重名的将被忽略或被认为是一个错误 
Actions

Actions其实就是一组被命名的命令序列。actions 都有一个触发条件,触发条件决定了action何时执行。当一个事件发生如果匹配action的触发条件,那么这个action将会被添加到预备执行队列的尾部(除非它已经在队列当中) 

每一个action中的命令将被顺序执行。init进程负责在其它activities(如:设备创建/销毁,属性设置,进程重启)之间执行这些命令序列。

 

action 的格式如下
on <trigger>   <command>   <command>   <command> 

 

Services

 services 是一些由init 启动 和 重新(如果有需要)启动的程序,当然这些程序如果是存在的。

 

services 的格式如下:
  service <name> <pathname> [ <argument> ]*   <option>   <option>   ...  

 


Options

options 是service的修饰符,用来告诉init 怎样及何时启动service。

 

OptionDescription
disabledThis service will not automatically start with its class. It must be explicitly started by name.
socket <type> <name> <perm> [ <user> [ <group> ] ]

Create a unix domain socket named /dev/socket/<name>and pass its fd to the launched process. Valid<type>dgram and streamuser and group default to 0.(type 实际中是放在name之后)

values include
user <username>Change to username before exec'ing this service. Currently defaults to root.
group <groupname> [ <groupname> ]*Change to groupname before exec'ing this service.  Additional  groupnames beyond the first, which is required, are used to set additional groups of the process (with setgroups()). Currently defaults to root.
capability [ <capability> ]+Set linux capability before exec'ing this service
oneshotDo not restart the service when it exits.
class <name>Specify a class name for the service.  All services in a named class must start and stop together. A service is considered of class "default" if one is not specified via the class option.

 

 

 Triggers

Triggers are strings used to match certain kinds of events that cause an action to occur.

TriggerDescription
bootThis is the first trigger that occurs when init starts (after /init.conf is loaded).
<name>=<value>Triggers of this form occur when the property <name> is set to the specific value<value>.
device-added-<path>
device-removed-<path>
Triggers of these forms occur when a device node is added or removed.
service-exited-<name>Triggers of this form occur when the specified service exits.


Commands

CommandDescription
exec <path> [ <argument> ]*Fork and execute a program (<path>). This will block until the program completes execution. Try to avoid exec. Unlike thebuiltin commands, it runs the risk of getting init "stuck".
export <name> <value>Set the environment variable <name> equal to <value> in the global environment (which will be inherited by all processes started after this command is executed).
ifup <interface>Bring the network interface <interface> online.
import <filename>Parse an init config file, extending the current configuration.
hostname <name>Set the host name.
class_start <serviceclass>Start all services of the specified class if they are not already running.
class_stop <serviceclass>Stop all services of the specified class if they are currently running.
domainname <name>Set the domain name.
insmod <path>Install the module at <path>.
mkdir <path>Make a directory at <path>.
mount <type> <device> <dir> [ <mountoption> ]*Attempt to mount the named device at the directory <dir><device>. This may be of the form mtd@name to specify a mtd block device by name.
setkey- currenlty undefined -
setprop <name> <value>Set system property <name> to <value>.
setrlimit <resource> <cur> <max>Set the rlimit for a resource.
start <service>Start a service running if it is not already running.
stop <service>Stop a service from running if it is currently running.
symlink <target> <path>Create a symbolic link at <path> with the value <target>.
write <path> <string> [ <string> ]*Open the file at <path> and write one or more strings to it with write(2).

Properties

Init updates some system properties to provide some insight into 
what it's doing:
PropertyDescription
init.actionEqual to the name of the action currently being executed or "" if none.
init.commandEqual to the command being executed or "" if none.
init.svc.<name>State of a named service ("stopped", "running", or "restarting").

 init.rc中使用属性的范例如下:

setprop ro.FOREGROUND_APP_MEM 1536

setprop ro.VISIBLE_APP_MEM 2048

on property:ro.kernel.qemu=1

start adbd

setprop用于设置属性,on property可以用于判断属性,这里的属性在整个Android系统运行中都是一致的。

 init脚本中的关键字可以参考:system/core/init/keywords.h

原文地址:https://www.cnblogs.com/muhuacat/p/8016931.html