Low memory Killer

Low memory Killer

  • 代码位置

drivers/staging/android/lowmemorykiller.c

  • 控制节点

sys/module/lowmemorykiller/parameters/

adj

adj_max_shift

cost

debug_level

enable_adaptive_lmk

enable_lmk

lmk_fast_run

minfree

oom_reaper

vmpressure_file_min

  • 各个进程的omm_adj

/proc/<PID>/omm_adj

/proc/<PID>/omm_score

/proc/<PID>/omm_score_adj

  • 各个安卓进程的ADJ

    • code path:

      android/platform/frameworks/base/services/core/java/com/android/server/am/ProcessList.java

    • 进程分类

      1. 前台进程

        用户当前操作所必需的进程。如果一个进程满足以下任一条件,即视为前台进程:

        • 托管用户正在交互的 Activity(已调用 ActivityonResume() 方法)
        • 托管某个 Service,后者绑定到用户正在交互的 Activity
        • 托管正在“前台”运行的 Service(服务已调用 startForeground()
        • 托管正执行一个生命周期回调的 ServiceonCreate()onStart()onDestroy()
        • 托管正执行其 onReceive() 方法的 BroadcastReceiver

        通常,在任意给定时间前台进程都为数不多。只有在内存不足以支持它们同时继续运行这一万不得已的情况下,系统才会终止它们。 此时,设备往往已达到内存分页状态,因此需要终止一些前台进程来确保用户界面正常响应。

      2. 可见进程

        没有任何前台组件、但仍会影响用户在屏幕上所见内容的进程。 如果一个进程满足以下任一条件,即视为可见进程如后台播放音乐:

        • 托管不在前台、但仍对用户可见的 Activity(已调用其 onPause() 方法)。例如,如果前台 Activity 启动了一个对话框,允许在其后显示上一 Activity,则有可能会发生这种情况。
        • 托管绑定到可见(或前台)Activity 的 Service

        可见进程被视为是极其重要的进程,除非为了维持所有前台进程同时运行而必须终止,否则系统不会终止这些进程。

      3. 服务进程

        正在运行已使用 startService() 方法启动的服务且不属于上述两个更高类别进程的进程。尽管服务进程与用户所见内容没有直接关联,但是它们通常在执行一些用户关心的操作(例如,在后台播放音乐或从网络下载数据)。因此,除非内存不足以维持所有前台进程和可见进程同时运行,否则系统会让服务进程保持运行状态。

      4. 后台进程

        包含目前对用户不可见的 Activity 的进程(已调用 Activity 的 onStop() 方法)。这些进程对用户体验没有直接影响,系统可能随时终止它们,以回收内存供前台进程、可见进程或服务进程使用。 通常会有很多后台进程在运行,因此它们会保存在 LRU (最近最少使用)列表中,以确保包含用户最近查看的 Activity 的进程最后一个被终止。如果某个 Activity 正确实现了生命周期方法,并保存了其当前状态,则终止其进程不会对用户体验产生明显影响,因为当用户导航回该 Activity 时,Activity 会恢复其所有可见状态。 有关保存和恢复状态的信息,请参阅 Activity文档。

      5. 空进程

        不含任何活动应用组件的进程。保留这种进程的的唯一目的是用作缓存,以缩短下次在其中运行组件所需的启动时间。 为使总体系统资源在进程缓存和底层内核缓存之间保持平衡,系统往往会终止这些进程。

    • android 的ADj分类

      ADJ值越小则优先度越高,例如INVALID和NATIVE的ADJ值在Android 8.0中为-10000和-1000,优先度最高,系统不会去关闭它。紧随其后的是SYSTEM,ADJ值为-900。小于零的ADJ,Low memory Killer是杀不到的。

      android 8.0即以上的分类

      ADJ值类型
      -10000INVALID 未定义
      -1000NATIVE 本机持有的特殊代码
      -900SYSTEM
      -800PERSISTENT_PROC 系统持续进程(电话)
      -700PERSISTENT_SERVICE 系统服务进程
      0FOREGROUND_APP 前台应用
      100VISIBLE_APP 可见应用
      200PERCEPTIBLE_APP 后台应用
      300BACKUP_APP 备份进程
      400HEAVY_WEIGHT_APP 重量级后台进程
      500SERVICE 服务进程
      600HOME_APP 主进程
      700PREVIOUS_APP 上一个进程
      800SERVICE_B 旧的服务进程B列表
      900CACHED_APP_MIN
      906CACHED_APP_MAX
      1001UNKNOWN
      99(PERCEPTIBLE_APP_ADJ - VISIBLE_APP_ADJ - 1)VISIBLE_APP_LAYER_MAX

      android 8.0以下的ADJ

      ADJ级别取值解释
      UNKNOWN_ADJ16一般指将要会缓存进程,无法获取确定值
      CACHED_APP_MAX_ADJ15不可见进程的adj最大值
      CACHED_APP_MIN_ADJ9不可见进程的adj最小值
      SERVICE_B_AD8B List中的Service(较老的、使用可能性更小)
      PREVIOUS_APP_ADJ7上一个App的进程(往往通过按返回键)
      HOME_APP_ADJ6Home进程
      SERVICE_ADJ5服务进程(Service process)
      HEAVY_WEIGHT_APP_ADJ4后台的重量级进程,system/rootdir/init.rc文件中设置
      BACKUP_APP_ADJ3备份进程
      PERCEPTIBLE_APP_ADJ2可感知进程,比如后台音乐播放
      VISIBLE_APP_ADJ1可见进程(Visible process)
      FOREGROUND_APP_ADJ0前台进程(Foreground process)
      PERSISTENT_SERVICE_ADJ-11关联着系统或persistent进程
      PERSISTENT_PROC_ADJ-12系统persistent进程,比如telephony
      SYSTEM_ADJ-16系统进程
      NATIVE_ADJ-17native进程(不被系统管理)

      参考网站:

      ANDROID 8.0 : 进程模型浅析(一)

      Android进程调度之adj算法

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值