美文网首页Android技术讨论
打通Framework与Kernel-谈谈我对进程管理的理解

打通Framework与Kernel-谈谈我对进程管理的理解

作者: Stan_Z | 来源:发表于2019-08-18 18:15 被阅读0次

Kernel:
Linux学习-进程管理与调度(一)-进程描述及其生命周期
Linux学习-进程管理与调度(二)-进程的创建与销毁
Linux学习-进程管理与调度(三)-调度基础
Linux学习-进程管理与调度(四)-负载均衡与实时性

Framework:
Android进程管理篇(一)-应用进程启动过程
Android进程管理篇(二)-进程查杀方式总结
Android进程管理篇(三)-进程adj算法
Android 进程管理篇(四)-cpu限制
Android 进程管理篇(五)-调度策略与优先级
lowmemorykiller总结

这两个系列的总结,Android进程基本梳理完毕。下面来简单总结下我对Android进程管理的理解:

在用户空间会分所谓的进程线程,但是对于内核看来,都是task_struct,线程只是资源共享的一种特殊进程罢了,所以这里我只说进程了。

一个应用程序进程由zygote copy-on-write 地fork孵化,孵化出来的进程在user space封装为ProcessRecord,而在kernel space同样会有个task_struct与之一一对应。

ProcessRecord会由AMS来统一管理,怎么管理?通过进程的生命周期以及内部的四大组件生命周期来确定你的优先级,而这个优先级专门定义了一套adj类型来匹配。那么这个优先级拿来干嘛?当然就是做进程管理。

这里对应进程管理的策略包括:内存管理、cpu调度限制、调度策略以及优先级管理。

  • 内存管理:AMS为每个现存的进程计算好oomadj,在内存低于min水线时,kswapd0会开始回收不活跃的文件页以及匿名页,回调shrink触发lmk,而lmk会通过 选择一个满足minfree档位并且rss内存占用最大的进程kill掉,来释放内存缓解内存压力。当然,这里也可以通过memory子系统来设置进程组,以及进程组的内存上限等等来做管理。

  • CPU限制、调度策略以及优先级管理:AMS调用android/osProcess相关方法(setProcessGroup/setThreadScheduler/setThreadPriority),JNI到Native对应方法,最后通过调用libcutils.so/libutils.so执行set_cpuset_policy/set_sched_policy/setpriority/sched_setscheduler等系统调用或者直接操作对应cgroup文件节。通过cpu/cpuset/stune子系统,控制进程获得CPU可调度的范围,调度的策略以及CPU执行时间等,以达到对不同优先级进程的控制。控制的最终目的是达到响应优先于吞吐的调度目标,同时尽量保证相对最优的负载均衡。

对于Android这种注重交互体验的操作系统来说,要想保证使用app的交互体验,站在系统资源的角度:一定是保证其进程生命周期更长,内存更稳定,获得的CPU调度范围更大,更容被处理效率更好的核执行,获得执行的时间片更多等等方面去考虑。

相关文章

  • 打通Framework与Kernel-谈谈我对进程管理的理解

    Kernel:Linux学习-进程管理与调度(一)-进程描述及其生命周期Linux学习-进程管理与调度(二)-进程...

  • 谈谈我对管理的理解

    管理是什么,简单的理解就是协调,协调人际关系,协调人内心的各种情绪,另一种关系。 在我看来,管理分为高低端,低端管...

  • 接口和抽象类有什么区别

    学习Java基础知识,打通面试关~十三接口与抽象类面试常客:谈谈你对抽象类和接口的理解 接口用interface修...

  • Android 内存优化

    Android 内存管理机制 内存管理 进程(由Application FrameWork和Linux内核管理) ...

  • Android 中应用程序Activity的冷启动流程

    Activity的启动主要涉及四个进程 SystemServer进程:主要负责管理整个Framework App进...

  • iOS面试题整理

    1.UITableView的重用机制 2.内存管理机制 3.进程与线程的区别 4.谈谈你对Block和delega...

  • 数与式的关键问题

    重视对“数与式”主题的整体理解,既要纵向打通“数与式”主题和小学阶段“数与运算”主题的关系,又要横向打通“数”与“...

  • Android dynamic framework 学习[1]

    Android dynamic framework 学习 @(深入理解OSGI 应用与最佳实践)[ 资源管理, j...

  • iOS 面试注意事项

    对mrc和arc的理解:OC知识--彻底理解内存管理(MRC、ARC) - 简书 谈谈对自动释放池的理解:关于自动...

  • 内存管理

    前段时间看了进程管理,觉得对编程简直大有裨益,至少对于多线程编程方面,对系统的进程管理有了非常深刻的理解,看来还是...

网友评论

    本文标题:打通Framework与Kernel-谈谈我对进程管理的理解

    本文链接:https://www.haomeiwen.com/subject/bdqdsctx.html