怀念夏天 发表于 2024-7-13 04:13:48

探究华为HarmonyOS微内核架构设计(整理篇)

        开篇阐明:本文仅用于大学本科《操作体系》课程作业。笔者此前对华为鸿蒙操作体系的认知停顿在较为浅层的程度,接触甚少,因此也是使用这次机会,对其进行一次较为体系的资料搜集整理,其中多数内容都会参考鉴戒到一些学术期刊、开源项目文档、技术博客、行业白皮书等,在此表现感谢。如有任何侵权问题,请及时与我接洽。
    前言

        鸿蒙操作体系自2019年发布以来,以其创新的微内核架构为焦点设计理念,引起了业界广泛关注。本文将探究HarmonyOS的微内核架构设计,剖析其内涵机制、关键技术以及现实应用。

一、什么是“微内核架构”

            微内核架构(Microkernel Architecture)是一种操作体系内核设计范式,它是相对于宏内核(Monolithic Kernel)而言的一种更为精简和模块化的内核结构。微内核架构作为一种先进的操作体系设计模式,通过仅将最基本的服务置于焦点层,大大提拔了体系的可靠性和安全性,同时也赋予了体系更高的可扩展性和机动性。相较于传统的宏内核设计,微内核可以大概在包管焦点功能最小化的根本上,使得外部服务和应用组件可以大概以模块化的情势进行机动摆设和高效运行,这在高度碎片化的物联网设备环境中显得尤为重要。
https://img-blog.csdnimg.cn/direct/251fe57aa51a49a0a15982d164e02505.png
图1  宏内核架构图
https://img-blog.csdnimg.cn/direct/2d4c3b1de5b04568a67ade10e9b2e40a.png
图2  微内核架构图
        引用网上的形貌,宏内核就犹如大管家,几乎包办一切,用户应用步伐的需求直接向内核提出;微内核更像一个署理人,几乎所有的驱动、文件体系全部运行在与用户应用步伐平级的用户模式下。因此微内核在服从方面处于劣势,也导致当前主流操作体系如Linux和Windows本质上使用的都是宏内核。
        宏内核服从高,但众所周知,宏内核的操作体系尤其是Windows,经常会存在安全漏洞,用户在没有泄露暗码且没使用问题硬件的环境下,还是会遭到被黑客入侵,因此安全性上微内核显然更胜一筹。此外,宏内核在及时性方面的表现也比不上微内核。
https://img-blog.csdnimg.cn/direct/705b473992a04a50b178ef9a7a6dcaf7.png
图3  宏内核与微内核的对比表现图
二、微内核的发展汗青

        微内核从开始提出至今就在不停发展完善,大致可分为三个汗青时期,也称为三代。
        第一代:从无到有

https://img-blog.csdnimg.cn/direct/994a9f1165d7432787b899946c3270ef.png
图4  Mach概述图
           第一代微内核的主要代表是 Mach,由美国卡耐基梅隆大学的 Avie Tevanian 和 Richard Rashid 主导开发的。其时正是UNIX 发展正方兴未艾时期,因此Mach不可避免的受到UNIX的影响,最起码兼容unix是最起码的考量,但是与unix不同的是,Mach 使用微内核架构。Mach 以 IPC 是作为所有体系服务与内核交换数据的根本机制,充实运用 IPC、虚拟内存、多进程等特性将冗余的体系服务移出内核作为进程运行。
        1986年,Mach 发布了第2版,但此时 Mach 内核并不提供完全的体系服务,该本的内核包罗了大量 4.3 版本的 BSD 体系(UNIX的一个分支)代码提供体系服务,而且 BSD 体系服务运行在内核状态,这导致 Mach 内核的代码体积甚至大于常规 UNIX 内核。
        Mach 3.0 于 1990 年发布,由于在体系服务之间完全使用 IPC 通讯,而不是向宏内核那样直接进行函数调用,即便是多处理器呆板上运行也性能丧失惨重,Mach 3.0 最多比 UNIX 丧失 67% 运行服从,这导致 Mach 3.0 以及其所代表的第一代微内核设计被看衰。此后断断续续有在 Mach 的根本上对性能进行提拔的尝试,但是均不太理想,至此 Mach 成为了微内核第一代先驱者。
        第二代:解决性能问题

           第二代微内核的主要代表是 L3 和 L4,以及 QNX 体系使用的 Neutrino 内核。前面第一代的微内核 Mach 由于服从问题原因失败了,但是微内核的理念并没有被放弃,Jochen Liedtke 认为 Mach 的 IPC 服从低下的原因就是由于 IPC 部门不够精简,于是有了L3 和 L4 微内核,对 IPC 部门进行了很彻底的精简优化。除了 L4 内核,也还有其他微内核比如 Exokernel、Rambler 等,但做的比较成功的是:黑莓公司旗下的 QNX 体系所使用的 Neutrino 内核(QNX,1980年诞生,最初以 QUICK UNIX 为名,后改为 QNX;2004 年 QNX 被 Harman 国际收购;2010 年 Harman 国际下被黑莓收购,QNX 成为黑莓旗下的资产),QNX 主要为高可靠领域提供解决方案,比如交通、能源、医疗、航天航空等。
https://img-blog.csdnimg.cn/direct/3e051eb3db6545ff8c26f58927febdf6.png
图5  QNX Neutrino微内核
        第三代:安全问题

           在前面两代的微内核的根本上,第三代微内核发达发展,许许多多微内核都被开发出来,主要代表有:seL4、Fiasco.OC、NOVA 等。
        本来第一代微内核的设计隔离了使内核安全性降低的体系服务,让体系服务漏洞不会影响内核,进而提高了内核安全性,可以说是关上了破坏体系的门, 但是第二代体系却又给攻击者开了个窗户。由于第二代微内核在内核中省去了关于安全性检查等步骤,把所有关于安全检查功能的实现都交给体系服务自己去实现,这导致体系服务的通讯接口直接袒露给用户态,任何进程都可能无限定地哀求体系服务,体系服务不得不花费额外的代价来区分哀求是否正当,容易造成拒绝服务攻击。比如正常的文件服务应该是从虚拟文件体系服务->文件体系服务->磁盘驱动服务这个流程来完成的,但是如果攻击者如果绕过虚拟文件体系服务,直接无限定地哀求攻击者自己没有权限访问的文件体系服务,使文件体系服务恒久处于满载状态,让其他进程无法通过正常的虚拟文件体系得到文件体系服务。为了加强安全性,且不太过影响性能,人们开始研发第三代微内核。
         seL4 是在第二代内核 L4 的根本上发展而来的。seL4 不仅仅继承了 L4 内核家族的高性能特性,还具备基于端点(enndpoint)的 IPC 机制。 这种 IPC 机制最大的特点是使用了能力空间的概念,进程在使用 IPC 哀求体系服务时必须具备相对应的能力,进程持有不可伪造的令牌来表现拥有哀求某种服务的能力。令牌可以被复制,可以被转移,还可以通过 IPC 进行传输。令牌其实是一个指向存在于内核空间内核对象的指针,所以普通进程并不能修改自身以及其他进程的权限分配,但是内核可以对令牌指定的权限进行控制,从而包管了用户态不能绕过能力空间这个机制对体系服务造成滥用。
https://img-blog.csdnimg.cn/direct/9b784c8b50e7444e8e3743c602fb65f5.png
图6  sel4微内核
三、微内核结构构成

        3.1 内核焦点层

        内核焦点层是HarmonyOS微内核架构的根本,负责提供最焦点的体系服务,确保操作体系的稳定运行。
        3.1.1 进程管理与线程调治

           在HarmonyOS微内核中,进程管理负责创建、烧毁进程,以及维护进程状态和上下文信息。线程调治则负责决定哪个线程在何时得到CPU使用权,依据优先级、调治计谋等因素进行公平、高效的调治决策。微内核设计夸大最小化内核,因此,其进程管理与线程调治机制通常设计得简单且高效,避免不须要的复杂性导致的性能丧失和安全隐患。
        3.1.2 内存管理

           内存管理模块负责整个体系的物理内存分配、接纳,以及虚拟内存映射。在微内核架构中,内存管理单位(MMU)通常被用于实现地点空间隔离,确保不同进程只能访问其被分配的内存区域。HarmonyOS微内核的内存管理可能采用了分页或分段机制,以及高效的内存分配算法,犹如伴体系、 slab 分配器等,以确保内存的高效使用和安全性。
        3.1.3 中断处理

           中断处理是操作体系响应硬件变乱的关键机制。HarmonyOS微内核的中断处理模块负责接收来自硬件的中断哀求,快速生存当前执行环境,调用相应的中断服务例程(ISR),并在ISR执行完毕后规复先前的执行环境。微内核设计中,中断处理应尽可能快,以降低中断耽误,包管体系的及时响应能力。
        3.1.4 基本的IPC机制

            进程间通讯(IPC)是微内核架构中不同进程(或服务)之间交换信息和同步的重要手段。HarmonyOS微内核可能提供了诸如消息传递、共享内存、信号量、互斥锁等基本的IPC机制,以支持服务间的协作。由于服务大多在用户态运行,微内核的IPC机制通常设计得高效且安全,确保在严格的权限控制下进行数据交换。
        3.2 体系服务层

           体系服务层包罗了原本在宏内核中位于内核态的各种服务,如设备驱动、文件体系、网络协议栈等。在HarmonyOS微内核架构中,这些服务被重构为独立的用户态进程或服务,通过微内核提供的接口与内核焦点层交互。
        3.2.1 设备驱动

           设备驱动在微内核中作为用户态服务运行,通过体系调用大概消息传递机制与内核焦点层进行通讯,哀求访问硬件资源或上报硬件变乱。这种设计允许驱动步伐在用户态瓦解时不会影响内核的稳定性,同时简化了驱动的开发、摆设和更新流程。
        3.2.2 文件体系

           文件体系服务同样在用户态实现,通过微内核提供的API与内核交互,执行文件的创建、删除、读写、目录操作等。这种分离设计提高了文件体系的可移植性和安全性,同时允许文件体系服务独立升级,不影响内核或其他服务。
        3.2.3 网络协议栈

            网络协议栈(如TCP/IP)在HarmonyOS微内核中也被迁移到用户态,通过微内核提供的网络接口与硬件网络设备交互,处理数据包的收发、路由、拥塞控制等。这种设计有助于提高网络服务的可扩展性和故障隔离能力,同时简化了对新网络协议的支持。        
        3.3安全子体系

        安全子体系是HarmonyOS微内核架构中确保体系整体安全的关键构成部门。
        3.3.1 权限分离与访问控制

           微内核通过严格的权限模型实现权限分离,每个服务、进程或用户都有明确的权限集,只能访问被授权的资源。访问控制机制则在体系调用、IPC等操作中实行,确保只有拥有适当权限的实体才能进行特定操作。这包罗但不限于基于角色的访问控制(RBAC)、强制访问控制(MAC)等计谋。
        3.3.2 安全通讯

           微内核可能实现了一系列安全通讯机制,如加密的IPC通道、安全的远程过程调用(RPC)等,确保在服务间传递的数据得到保护,防止未经授权的窃听或篡改。此外,可能还支持安全认证和身份验证机制,确保参与通讯的服务身份的正当性。
        3.3.3 可信执行环境(TEE)

           HarmonyOS微内核可能集成或支持可信执行环境(TEE),如ARM TrustZone技术,提供一个隔离且受保护的执行环境,用于执行对敏感数据(如密钥、生物识别数据)的处理或存储操作。TEE提供了硬件级别的隔离和加密保护,加强了体系的整体安全性。
        3.4 跨平台支持层

 跨平台支持层确保HarmonyOS微内核可以大概在不同的硬件平台上稳定、高效运行。
        3.4.1 硬件平台适应性

           微内核通过精巧的设计,使其焦点代码具有良好的跨平台性,可以大概在不同架构(如ARM、RISC-V等)的处理器上编译和运行。这通常涉及到对不同指令集特性的抽象,以及对处理器特定功能(如多核同步、中断处理等)的通用化封装。
        3.4.2 硬件抽象层(HAL)

            HAL作为微内核与硬件之间的中间层,为上层体系服务提供同一的接口,隐蔽底层硬件的详细细节。在HarmonyOS中,HAL可能包罗各种设备驱动的接口界说、平台相干的体系调用封装等,使得体系服务和应用步伐无需关心底层硬件差异,只需按照同一接口编程即可。
        3.4.3 跨平台设备驱动支持

            通过HAL,HarmonyOS微内核可以大概支持多种硬件平台上的设备驱动。驱动开发者只需要按照HAL界说的接口编写驱动代码,即可实现跨平台的设备驱动。同时,微内核可能提供了驱动热插拔、动态加载等机制,进一步加强了驱动的机动性和可移植性。
四、关键技术特点

4.1 模块化设计

           HarmonyOS微内核采取了高度模块化的架构设计,将内核功能分别为相互独立的模块,每个模块承载特定的功能组件,如进程管理模块、线程调治模块、内存管理模块、中断处理模块等。这些模块在开发、测试和升级过程中均可独立进行,大大提高了开发服从和体系的可维护性。
        模块间的关系遵循松耦合原则,这意味着模块间的依赖性最小化,单个模块的改动不会引发连锁反应,影响到其他模块的正常运行。模块化设计使得HarmonyOS微内核具备极高的机动性,可根据不同应用场景和硬件条件,机动增减和组合模块,以实现定制化的需求。
4.2 服务化整合

           HarmonyOS提倡“一切皆服务”的理念,微内核通过服务化的方式组织和管理各类体系服务。服务注册、发现、调用机制是其焦点特色之一,体系服务不再内嵌于内核中,而是作为独立进程运行在用户态,通过微内核提供的尺度化接口与内核进行交互。
        当体系启动或运行过程中,服务可以根据需求动态注册到服务注册中心,其他服务或应用步伐可以通过查询服务注册表,按需调用所需服务。这种服务化整合设计促进了服务的可扩展性和机动性,也为构建分布式体系提供了便利。
4.3 安全机制

           HarmonyOS微内核在安全设计层面力图全面、深入,通过多重安全防护手段确保体系的安全性。首先,依托于细粒度的权限模型,实现了严格的访问控制,确保进程和服务只能访问授权范围内的体系资源。
        此外,采用加密的安全通讯协议,确保服务间通讯内容的私密性和完备性。HarmonyOS可能还引入了可信执行环境(TEE)技术,为敏感数据处理和关键服务提供硬件级别的隔离和保护。体系启动阶段采用安全启动机制,确保体系固件和内核的完备性,防止恶意篡改。
4.4 跨平台能力

           HarmonyOS微内核采用尺度化接口和硬件抽象层(HAL)技术,实现了对多种处理器架构(如ARM、RISC-V等)和设备类型的广泛支持。HAL屏蔽了底层硬件差异,使得上层服务和应用可以跨平台运行,且保持一致的性能和行为。
        微内核在设计时特别关注跨平台性能的一致性,通过高效的内存管理和调治算法,以及对不同平台特性的针对性优化,确保在不同硬件平台上的体系性能不打折扣。
五、创新点分析

相比于其他微内核操作体系,如L4、QNX等,HarmonyOS微内核的创新性主要表如今:
5.1 分布式技术革新

           HarmonyOS提出了分布式软总线的概念,实现了跨设备的无缝协同和资源虚拟化,打破了传统设备边界,构建了真正的万物互联生态环境。
5.2 资源管理计谋

           通过独特的资源调治算法和确定性时延引擎,HarmonyOS微内核在面对复杂的分布式盘算场景时,仍能保持优异的性能表现和低时延响应,尤其适合工业自动化、车联网等对及时性要求高的领域。
5.3 安全强化

           除了常见的权限管理、安全通讯等安全机制外,HarmonyOS还在体系安全设计上采取了更深层次的防御步伐,如引入分布式设备信任链机制,确保设备间通讯的安全可信。
六、应用场景与效果评估

6.1 分布式盘算场景下的上风展现

   

[*] 设备间协同:在智能家居场景下,HarmonyOS微内核通太过布式软总线技术,让各类智能设备仿佛成为一个整体,实现跨设备的任务调治、数据交换和资源虚拟化。例如,用户可以通过智能手机发出指令,控制家中不同品牌的智能家电设备。
[*] 低时延响应:在工业自动化和车联网应用中,HarmonyOS微内核依附其确定性时延引擎和高效的资源调治计谋,确保了在分布式盘算环境下的及时响应,满足了高度细密控制和快速响应的要求。
6.2 现实应用案例分析及性能测试效果

        以某一现实摆设的智能家居项目为例:
           案例配景:该项目运用HarmonyOS微内核技术,整合了多品牌、多品类的智能家居设备,形成了一个完备的家庭自动化解决方案,体系规模覆盖上百种不同类型的设备。
        体系摆设与实行:HarmonyOS微内核在每一台智能设备上实现摆设,通过同一的HAL和尺度化接口毗连不同设备。体系集成涵盖了各类服务组件,如语音识别服务、设备控礼服务、数据同步服务等,全部以服务化的方式运行并进行同一管理。
        性能测试与评估:经过严格的性能测试,HarmonyOS微内核在设备间通讯、服务调用、任务调治等方面表现出色。数据显示,在跨设备联动场景下,体系均匀响应时间低于5毫秒,消息传输速率高出100Mbps,体系资源使用率始终保持在60%以内,展现出优秀的性能程度。
        用户反馈与改进建议:现实用户普遍反馈HarmonyOS微内核在智能家居环境中的体验良好,设备间协同流畅,响应速度快。同时,通过持续收集用户反馈和建议,HarmonyOS团队正积极对微内核进行优化迭代,解决个别设备适配问题和功能短板,不停提拔用户体验和体系性能。

七、参考文献

                     
原文链接:
http://t.csdnimg.cn/vjFIQ
http://t.csdnimg.cn/Xq8Ek

总结

        本文对华为鸿蒙操作体系(HarmonyOS)的微内核架构进行了深入探究,从微内核架构的基本概念出发,对比宏内核架构,阐述了微内核在安全性、及时性等方面的上风,尽管在服从上可能存在一定劣势,但通过历代微内核的发展,已经逐步解决了性能问题,并在安全方面取得了明显进步。
        鸿蒙微内核的焦点结构包罗内核焦点层、体系服务层、安全子体系和跨平台支持层。内核焦点层承担着进程管理与线程调治、内存管理、中断处理和IPC机制等基本功能;体系服务层通过将设备驱动、文件体系和网络协议栈等服务以用户态进程的情势运行,实现服务的模块化和动态管理;安全子体系通过权限分离、访问控制、安全通讯机制以及可信执行环境确保体系整体安全;跨平台支持层则通过硬件平台适应性、硬件抽象层和跨平台设备驱动支持,包管了HarmonyOS微内核在多种硬件平台上的高效稳定运行。
        HarmonyOS微内核在关键技术特点上展示了模块化设计、服务化整合、强大的安全机制以及出色的跨平台能力。其中,分布式软总线技术的提出,打破了传统设备边界,实现了跨设备的无缝协同和资源虚拟化,是其在分布式盘算场景下的重要创新。独特的资源调治算法和确定性时延引擎确保了在复杂分布式盘算场景下仍旧具有优秀的性能表现和低时延响应,尤其实用于工业自动化、车联网等及时性要求高的领域。此外,HarmonyOS还强化了安全设计,引入分布式设备信任链等深层次防御步伐,确保设备间通讯的安全可信。
        通过现实应用案例分析,HarmonyOS微内核在智能家居场景中得到了成功应用,其在设备间通讯、服务调用和任务调治等方面表现出卓越性能,经测试,在跨设备联动场景下,体系响应时间小于5毫秒,消息传输速率高出100Mbps,体系资源使用率保持在60%以内,用户反馈显示HarmonyOS在智能家居环境中的表现优秀,设备协同流畅且响应迅速。HarmonyOS团队持续优化微内核架构,以满足不停发展的市场需求和用户期待。

免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。
页: [1]
查看完整版本: 探究华为HarmonyOS微内核架构设计(整理篇)