土法炼钢兴趣小组的算法知识备份

【操作系统百科】Unikernel

文章导航

分类入口
os
标签入口
#unikernel#unikraft#mirageos#includeos#library-os

目录

把应用和 OS 编译成一个二进制 → 直接跑在 hypervisor 上 → 极小攻击面 → 极快启动。为什么没有普及?

一、先看图

flowchart LR
    TRAD[传统<br/>App + OS + 驱动] --> LARGE[大镜像<br/>攻击面大]
    UNI[Unikernel<br/>App + 库OS] --> SMALL[小镜像<br/>攻击面小]
    UNI --> HV[Hypervisor<br/>Xen / KVM]

    classDef trad fill:#f0883e22,stroke:#f0883e,color:#adbac7;
    classDef uni fill:#3fb95022,stroke:#3fb950,color:#adbac7;
    class TRAD,LARGE trad
    class UNI,SMALL,HV uni

二、什么是 Unikernel

库操作系统(Library OS):

三、代表项目

3.1 MirageOS

3.2 IncludeOS

3.3 Unikraft

kraft build --target qemu-x86_64
kraft run

3.4 OSv

四、优势

优势 说明
启动时间 ~10-50ms
镜像大小 ~1-10MB
攻击面 极小(无 shell/无多余驱动)
性能 无 syscall 开销(同一地址空间)
密度 单机可跑数千实例

五、困难

5.1 调试

没有 shell、没有 SSH、没有 GDB server → 调试靠日志和远程 GDB。

5.2 工具链

每个 unikernel 需要专门的工具链 → 不是 gcc + make 就能搞定。

5.3 POSIX 兼容

多数 unikernel 的 POSIX 兼容不完整 → 现有应用需要移植。

Unikraft 的 POSIX 层最完整 → 但仍有差距。

5.4 多进程

单地址空间 → 不支持 fork/exec → 传统多进程架构不可用。

六、与容器/microVM 的关系

容器 → 轻量但共享内核
microVM → 独立内核但有 overhead
unikernel → 最小 OS 但兼容性差

Firecracker 的 microVM 在实践中取代了 unikernel 的很多场景 → 兼容性更好。

七、Nanos

ops run my_app

Nanos = 为运行单个应用设计的 unikernel → 支持 POSIX → 工具链友好。

八、云上的尝试

九、未来方向

十、小结


参考文献

工具


上一篇实时 OS 巡礼 下一篇Rust for Linux

同主题继续阅读

把当前热点继续串成多页阅读,而不是停在单篇消费。

2026-04-17 · os

【操作系统百科】什么是操作系统:从 monitor 到 unikernel 的职责清单

从裸机监控器到微内核再到 unikernel 与 serverless,OS 这个抽象层在六十年里被反复挑战又反复回归。本文不做教科书式定义,而是回到工程视角,提炼 OS 真正在做的五件事:资源抽象、复用、隔离、公平、可观测性。以此为尺,丈量宏内核、微内核、VMM、unikernel、serverless 各自的胜负边界。

2026-05-06 · os

【操作系统百科】内核内存调试

内核内存 bug 是最难追的:UAF、OOB、double free、leak 都可能沉默数月。本文讲 KASAN 三种模式、KFENCE 生产采样、kmemleak、SLUB_DEBUG、UBSAN/KCSAN 联动。

2026-05-08 · os

【操作系统百科】VFS 四层抽象

Linux 的一切皆文件靠 VFS 实现——superblock、inode、dentry、file 四层抽象加 ops 表。本文讲 VFS 核心数据结构、dcache、inode cache、RCU lookup,以及文件系统如何插入 VFS。

2026-04-22 · os

操作系统百科

Linux 6.x 视角下的操作系统系列索引:110 篇覆盖调度、虚拟内存、文件系统与 I/O、并发、隔离、可观测性,按主题、阅读路径与关键问题三种入口组织。


By .