1、最近在Android系统里使用自带的dnsmasq来作为网口连接时的DHCP和DNS服务器,发现将其放至init.rc里作为service来启动,会占用CPU一个核心的资源。
2、使用top命令会发现,单核CPU占100%,双核占50%,四核占25%。
3、很怪异,发现ps命令里该项的WCHAN全为0,这个睡眠时用到的地址空间在内核态,永远睡不了啊,然后其状态一直是R,即一直处于运行状态。
4、但发现如果在命令行执行dnsmasq命令则不会出现该问题,并且其状态为S,WCHAR为非0值。
5、上网查了下,发现该问题为Fix problem if dnsmasq is started without the stdin, stdout and stderr file descriptors open.This can manifest itself as 100% CPU use.
6、经对比,发现Android自带的2.51版本的与该网址提到的2.60代码相差太多。
7、于是将2.60移植过来,再次运行发现问题解决了。