Android Native 之 lmkd进程和kernel kswapd的关联

lwkd进程属于native层启动的一个守护进程,他的作用贯穿android世界的始终。他的另外一个大家都属于的名字lowmemorykiller。

根据readme的介绍lmkd是用来对android系统内存检查的守护进程,它通过终止不重要的进程来达到系统稳定运行的状态。在Linux Kernel 4.12之前是这项任务是放在了kernel进行管理,在Linux Kernel 4.12之后移到了native层中,因为在kernel进程管理中直接干掉某个应用进程太过暴力。

后面介绍了我们可以通过一些属性的值来控制lmkd进程的效果,如下:

  • ro.config.low_ram: choose between low-memory vs high-performance device. Default = false.

  • ro.lmk.use_minfree_levels: use free memory and file cache thresholds for making decisions when to kill. This mode works the same way kernel lowmemorykiller driver used to work. Default = false

  • ro.lmk.low: min oom_adj score for processes eligible to be killed at low vmpressure level. Default = 1001 (disabled)

  • ro.lmk.medium: min oom_adj score for processes eligible to be killed at medium vmpressure level. Default = 800 (non-essential processes)

  • ro.lmk.critical: min oom_adj score for processes eligible to be killed at critical vmpressure level. Default = 0 (all processes)

  • ro.lmk.critical_upgrade: enables upgrade to critical level. Default = false

  • ro.lmk.upgrade_pressure: max mem_pressure at which level will be upgraded because system is swapping too much. Default = 100 (disabled)

  • ro.lmk.downgrade_pressure: min mem_pressure at which vmpressure event will be ignored because enough free memory is still available. Default = 100 (disabled)

  • ro.lmk.kill_heaviest_task: kill heaviest eligible task (best decision) vs. any eligible task (fast decision). Default = false

  • ro.lmk.kill_timeout_ms: duration in ms after a kill when no additional kill will be done. Default = 0 (disabled)

  • ro.lmk.debug: enable lmkd debug logs, Default = false

  • ro.lmk.swap_free_low_percentage: level of free swap as a percentage of the total swap space used as a threshold to consider the system as swap space starved. Default for low-RAM devices = 10, for high-end devices = 20

  • ro.lmk.thrashing_limit: number of workingset refaults as a percentage of the file-backed pagecache size used as a threshold to consider system thrashing its pagecache. Default for low-RAM devices = 30, for high-end devices = 100

  • ro.lmk.thrashing_limit_decay: thrashing threshold decay expressed as a percentage of the original threshold used to lower the threshold when system does not recover even after a kill. Default for low-RAM devices = 50, for high-end devices = 10

  • ro.lmk.psi_partial_stall_ms: partial PSI stall threshold in milliseconds for triggering low memory notification. Default for low-RAM devices = 200, for high-end devices = 70

  • ro.lmk.psi_complete_stall_ms: complete PSI stall threshold in milliseconds for triggering critical memory notification. Default = 700

lmkd will set the following Android properties according to current system configurations:

  • sys.lmk.minfree_levels: minfree:oom_adj_score pairs, delimited by comma

  • sys.lmk.reportkills: whether or not it supports reporting process kills to clients. Test app should check this property before testing low memory kill notification. Default will be unset.

一、LMKD源码分析

1、LMKD进程的启动

1.1 三种启动方式

同其他native进程一致,他的启动还是通过init rc机制来启动。如下代码

总结如下:

  • 标记为core类的服务会在init.rcon early-initon init阶段被启动,未显式设置disabled属性时,core类服务会随init进程初始化自动启动。PS:在core进行启动是为了防止核心服务没有启动导致系统异常
  • 监听sys.boot_completed开机属性然后传递--reinit参数进行完整启动。PS:从后文可以了解到reinit会去读取一系列相关属性,即这是完整启动
  • 最后监听属性变更,传递--reinit参数,应该是做成不需要重启系统就能够动态生效这些参数的效果

1.2 主函数三部曲

二、Kernel kswapd线程分析

kernel_platform/msm-kernel/mm/page_alloc.c 是 Linux 内核中负责‌物理页帧分配与管理‌的核心实现文件,主要功能如下:

一、核心功能

  1. 伙伴系统(Buddy System)

    • 实现alloc_pages()/free_pages()等接口,通过2^n阶页块管理物理内存13
    • 处理内存碎片合并与拆分(如__free_one_page()函数)3
  2. 页分配策略

    • 控制GFP标志(GFP_KERNEL/GFP_ATOMIC等)的分配行为14
    • 实现水位线(WMARK_MIN/WMARK_LOW)和内存回收触发逻辑3
  3. NUMA架构支持

    • 多节点内存分配(__alloc_pages_nodemask()

二、关键代码结构

函数/宏功能说明
__alloc_pages_nodemask分配页帧的核心逻辑(含慢速路径/快速路径)3
get_page_from_freelist从空闲列表获取可用页帧3
zone_watermark_ok检查内存水位是否满足分配需求3
__free_pages_ok释放页帧到伙伴系统3

三、与lmkd的关联

lmkd触发内存回收时,最终会通过该文件中的分配器获取/释放物理页帧24。例如:

  • GFP_KERNEL分配可能触发直接内存回收(__perform_reclaim
  • 低内存时通过__alloc_pages_slowpath进入回收流程3

注:该文件是内存管理子系统(MM)的核心组件,代码路径通常为/mm/page_alloc.c,MSM内核版本会包含高通平台的特定优化13。

__setup_per_zone_wmarks这个函数是干什么的?

__setup_per_zone_wmarks是Linux内核中用于初始化内存管理区(zone)水位线(watermark)的关键函数,其核心功能如下:

一、核心作用

  1. 计算并设置三档水位值

    • 根据min_free_kbytes全局参数,为每个zone动态计算WMARK_MIN(最低警戒线)、WMARK_LOW(kswapd唤醒线)、WMARK_HIGH(kswapd休眠线)14
    • 默认比例关系:LOW = MIN * 5/4HIGH = MIN * 3/246
  2. NUMA架构适配

    • 针对不同内存节点(node)的zone独立计算水位,考虑局部内存特性

二、水位线的作用机制

水位等级触发行为
WMARK_HIGH内存充足,kswapd线程进入休眠状态69
WMARK_LOW空闲内存低于此值,唤醒kswapd进行异步回收57
WMARK_MIN触发直接内存回收(direct reclaim),可能阻塞进程分配请求

三、典型调用流程

  1. 系统启动时通过init_per_zone_wmark_min()调用该函数4
  2. 根据公式计算每个zone的min_free_kbytes分摊值:zonemin=min_free_kbytes×zonesizetotal_non_highmem_pageszonemin​=total_non_highmem_pagesmin_free_kbytes×zonesize​​再基于此值推导其他水位

四、相关代码逻辑

// mm/page_alloc.c static void __setup_per_zone_wmarks(void) { // 计算各zone的min水位 for_each_zone(zone) { zone->watermark[WMARK_MIN] = calc_min_watermark(zone); // 推导low/high水位 zone->watermark[WMARK_LOW] = min_wmark_pages(zone) + (tmp >> 2); zone->watermark[WMARK_HIGH] = min_wmark_pages(zone) + (tmp >> 1); } }

该函数是内存分配器(如get_page_from_freelist)判断是否触发回收的核心依据

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.pswp.cn/web/83097.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【生活】程序员防猝si指南

note 一、定期体检二、均衡饮食,多食用对心脏有保护作用的食物三、每周运动四、减压五、保证睡眠六、戒烟限酒7、控制血压8、警惕流感攻击心脏9、关注牙齿健康10、不要抵触吃药 文章目录 note一、定期体检二、均衡饮食,多食用对心脏有保护作用的食物三、…

245. 2019年蓝桥杯国赛 - 数正方形(困难)- 递推

245. 数正方形(困难) 2019年蓝桥杯国赛 - 数正方形(困难) 标签:2019 国赛 递推 题目描述 在一个 N N N N N N 的点阵上,取其中 4 个点恰好组成一个正方形的 4 个顶点,一共有多少种不同的取…

代码随想录刷题day30

1、零钱兑换II 给你一个整数数组 coins 表示不同面额的硬币,另给一个整数 amount 表示总金额。 请你计算并返回可以凑成总金额的硬币组合数。如果任何硬币组合都无法凑出总金额,返回 0 。 假设每一种面额的硬币有无限个。 题目数据保证结果符合 32 位带…

SpringBoot EhCache 缓存

一、EhCache核心原理 层级存储 堆内缓存(Heap):高速访问,受JVM内存限制堆外缓存(Off-Heap):突破JVM堆大小限制(直接内存)磁盘存储(Disk)&#xff…

ServerTrust 并非唯一

NSURLAuthenticationMethodServerTrust 只是 authenticationMethod 的冰山一角 要理解 NSURLAuthenticationMethodServerTrust, 首先要明白它只是 authenticationMethod 的选项之一, 并非唯一 1 先厘清概念 点说明authenticationMethodURLAuthenticationChallenge.protectionS…

盘古信息PCB行业解决方案:以全域场景重构,激活智造新未来

一、破局:PCB行业的时代之问 在数字经济蓬勃发展的浪潮中,PCB(印制电路板)作为 “电子产品之母”,其重要性愈发凸显。随着 5G、人工智能等新兴技术的加速渗透,PCB行业面临着前所未有的挑战与机遇。产品迭代…

数据通信与计算机网络——数据与信号

主要内容 模拟与数字 周期模拟信号 数字信号 传输减损 数据速率限制 性能 注:数据必须被转换成电磁信号才能进行传输。 一、模拟与数字 数据以及表示数据的信号可以使用模拟或者数字的形式。数据可以是模拟的也可以是数字的,模拟数据是连续的采用…

循环语句之while

While语句包括一个循环条件和一段代码块&#xff0c;只要条件为真&#xff0c;就不断 循环执行代码块。 1 2 3 while (条件) { 语句 ; } var i 0; while (i < 100) {console.log(i 当前为&#xff1a; i); i i 1; } 下面的例子是一个无限循环&#xff0c;因…

蓝桥杯第十届国B 质数拆分

题目描述 本题为填空题&#xff0c;只需要算出结果后&#xff0c;在代码中使用输出语句将所填结果输出即可。 将 2019 拆分为若干个两两不同的质数之和&#xff0c;一共有多少种不同的方法&#xff1f; 注意交换顺序视为同一种方法&#xff0c;例如 220172019 与 201722019 …

曼昆《经济学原理》第九版 第十二章税收制度的设计

一、税收基本概念 税收分类&#xff1a; 比例税&#xff1a;税率不随税基变化&#xff08;如部分增值税&#xff09;累进税&#xff1a;税率随税基增加而上升&#xff08;如个人所得税&#xff09;累退税&#xff1a;税率随税基增加而下降&#xff08;如社会保险税上限&#…

在Spring Boot中集成RabbitMQ的完整指南

前言 在现代微服务架构中&#xff0c;消息队列&#xff08;Message Queue&#xff09;是实现异步通信、解耦系统组件的重要工具。RabbitMQ 是一个流行的消息中间件&#xff0c;支持多种消息协议&#xff0c;具有高可靠性和可扩展性。 本博客将详细介绍如何在 Spring Boot 项目…

IDC智能机房整体解决方案

该文档为 IDC 智能机房整体解决方案,目标是实现机房智能化、可视化、远程化管理,提升运维效率与客户服务能力。方案涵盖物理安全智能化(智能电子锁,支持远程控制、权限管理及离线 / 在线授权,兼容 1-3mm 门板厚度等)、监控智能化(人员定位、摄像头、机柜温湿度监控、能耗…

Kafka入门-集群基础环境搭建(JDK/Hadoop 部署 + 虚拟机配置 + SSH 免密+Kafka安装启动)

Kafka 简介 传统定义&#xff1a;Kafka是一个分布式的基于发布/订阅模式的消息队列&#xff0c;应用于大数据实时处理领域。 Kafka最新定义&#xff1a;Apache Kafka是一个开源分布式事件流平台&#xff0c;被数千家公司用于高性能数据管道、流分析、数据集成和关键任务应用…

【仿生机器人】建模—— 图生3D 的几个办法

两件事&#xff01; 第一件&#xff1a; 强如 Gemini&#xff0c;在多模态和三维空间的理解中&#xff0c;如果不微调去做下游应用&#xff0c;直接 Zero-shot 的 效果是很差的 好处是有多视角图生3D&#xff0c;效果还可以&#xff0c;但是也没有很精细&#xff0c;&#xf…

简约商务通用宣传年终总结12套PPT模版分享

IOS风格企业宣传PPT模版&#xff0c;年终工作总结PPT模版&#xff0c;简约精致扁平化商务通用动画PPT模版&#xff0c;素雅商务PPT模版 简约商务通用宣传年终总结12套PPT模版分享:商务通用年终总结类PPT模版https://pan.quark.cn/s/ece1e252d7df

modelscope下载gguf格式模型

modelscope下载gguf格式模型 ollama加载模型 模型地址 https://www.modelscope.cn/models/okwinds/CompassJudger-1-7B-Instruct-GGUF-V3-LOT pip install modelscope modelscope download --modelokwinds/CompassJudger-1-7B-Instruct-GGUF-V3-LOT --include "CompassJ…

关于uniapp展示PDF的解决方案

在 UniApp 的 H5 环境中使用 pdf-vue3 组件可以实现完整的 PDF 预览功能。以下是详细实现步骤和注意事项&#xff1a; 一、安装依赖 安装 pdf-vue3 和 PDF.js 核心库&#xff1a; npm install pdf-vue3 pdfjs-dist二、基本使用示例 <template><view class"con…

解决Excel词典(xllex.dll)文件丢失或损坏问题的终极指南:从基础到高级修复技巧

在日常使用Microsoft Excel的过程中&#xff0c;许多用户可能会遇到一个令人沮丧的问题&#xff1a;Excel词典文件xllex.dll丢失或损坏。这不仅会影响到Excel的正常功能&#xff0c;还可能导致数据处理效率的降低。在这篇文章中&#xff0c;我们将深入探讨这一问题的原因&#…

Linux中《基础IO》详细介绍

目录 理解"文件"狭义理解广义理解文件操作的归类认知系统角度文件类别 回顾C文件接口打开文件写文件读文件稍作修改&#xff0c;实现简单cat命令 输出信息到显示器&#xff0c;你有哪些方法stdin & stdout & stderr打开文件的方式 系统⽂件I/O⼀种传递标志位…

第11篇:数据库中间件系统可配置化设计与动态规则加载机制

11.1 引言&#xff1a;为什么需要可配置化&#xff1f; 数据库中间件在企业级环境中往往需要支持多租户、多业务场景、多数据库后端&#xff0c;因此固定逻辑会迅速过时或僵化。 为了提升 灵活性、可扩展性、部署效率&#xff0c;中间件系统亟需实现&#xff1a; ✅ 高度可配置…