怎么样重定向到/dev/null的?

 

按官方的说法系统启动时每一个进程的STDIO都被定向到了/dev/null。而logwrapper可以让一个进程启动时STDIO重定向到log结点,然后通过logcat查看。这里记录一下它的实现机制。

 

init.c中的service_start方法中有这么一句:

needs_console = (svc->flags & SVC_CONSOLE) ? 1 : 0;

如果needs_console的值是1,就会调用open_console();为当前启动的这个服务打开控制台作为其STDIO。如果是0的话,就调用zap_stdio();打开/dev/null作为其STDIO。

参照init_parser.c中的parse_line_service和lookup_keyword两个方法可以知道,svc->flags由init.rc中service的命令选项console控制。

 

关于init.rc中service的命令选项,可以参照这篇翻译

http://blog.csdn.net/a345017062/archive/2011/03/11/6239204.aspx

这里可以看到,sh启动时STDIO是重定向到console的

http://blog.csdn.net/yimiyangguang1314/archive/2011/03/30/6288172.aspx

 

你可能感兴趣的:(service)