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

【操作系统百科】FreeBSD 与 OpenBSD 的不同选择

文章导航

分类入口
os
标签入口
#freebsd#openbsd#kqueue#jail#pledge

目录

Linux 不是唯一选择。FreeBSD 和 OpenBSD 在很多地方做了不同的决定——有些值得借鉴。

一、先看图

flowchart TD
    BSD[BSD 家族] --> FREE[FreeBSD<br/>性能 + ZFS]
    BSD --> OPEN[OpenBSD<br/>安全优先]
    BSD --> NET[NetBSD<br/>可移植性]

    LINUX[Linux] --> PERF[性能导向<br/>eBPF/io_uring]
    LINUX --> ECO[生态最大<br/>驱动最全]

    classDef bsd fill:#f0883e22,stroke:#f0883e,color:#adbac7;
    classDef linux fill:#388bfd22,stroke:#388bfd,color:#adbac7;
    class BSD,FREE,OPEN,NET bsd
    class LINUX,PERF,ECO linux

二、kqueue vs epoll

方面 kqueue epoll
API 设计 统一事件模型(文件/socket/信号/进程) 只处理 fd
事件类型 EVFILT_READ/WRITE/VNODE/PROC/SIGNAL/TIMER EPOLLIN/EPOLLOUT
原子性 kevent 一次性修改+等待 epoll_ctl + epoll_wait 分开
文件系统事件 EVFILT_VNODE 内置 需要 inotify

kqueue 的统一模型更优雅 → Linux 用 epoll+signalfd+timerfd+inotify 拼凑出类似能力。

三、jail vs namespace

# FreeBSD jail
jail -c name=myjail path=/jail host.hostname=jail ip4.addr=10.0.0.1

jail 是一体化容器 → namespace 是细粒度积木。

方面 jail namespace + cgroup
设计 一体化 组合式
复杂度
灵活性 较低
生态 Docker/K8s

四、ZFS

FreeBSD 内核集成 ZFS → 一等公民:

Linux 上 ZFS = 外部模块(许可证问题)→ DKMS 维护。

五、DTrace vs eBPF

方面 DTrace(BSD/Solaris) eBPF(Linux)
语言 D 语言 C/BPF
安全性 严格 verifier
应用范围 追踪 追踪+网络+安全+调度
生态 成熟但小 快速增长

eBPF 功能更广 → DTrace 的 D 语言更友好。

六、pledge / unveil(OpenBSD)

// OpenBSD 进程自限
pledge("stdio rpath", NULL);     // 只允许 stdio 和读文件
unveil("/usr/share", "r");       // 只能访问 /usr/share
unveil(NULL, NULL);              // 锁定

OpenBSD 的安全哲学:默认拒绝 → 显式允许。

七、网络栈

方面 FreeBSD Linux
默认防火墙 pf/ipfw iptables/nftables
TCP 实现 多栈(RACK/BBR) 多拥塞算法
零拷贝 sendfile splice/sendfile
DPDK 等旁路 netmap DPDK/XDP

FreeBSD 的 pf 语法比 iptables 更清晰。

八、代码组织与文档

BSD 的优势:

九、BSD 在生产中

十、小结


参考文献

工具


上一篇KVM 架构 下一篇Windows 内核

同主题继续阅读

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

2026-04-17 · os

【操作系统百科】POSIX 与 Linux/BSD/Windows 的偏离

POSIX 标准定义了 \"一个像 Unix 的 OS 应该长什么样\",但没有哪个真实 OS 完全等于它。本文对照 POSIX 基准,列出 Linux、FreeBSD、macOS、Windows 的扩展与偏离:Linux-only 的接口(epoll、io_uring、eventfd、prctl)、BSD-only(kqueue、pf)、NT 的异步模型、符号链接/路径语义差异、signal 语义的方言、fork 的地位演变。

2026-04-27 · os

【操作系统百科】内存回收

Linux 内存回收是 VM 最复杂的子系统之一。本文讲 active/inactive LRU、kswapd 与 direct reclaim、watermark 三线、swappiness 的真实含义、MGLRU 改造、memcg 回收与 PSI。

2026-04-28 · os

【操作系统百科】交换

swap 还值得开吗?本文讲 swap area 基础、swap cache、zram 压缩内存、zswap 前端压缩池、swappiness 的真实含义、容器里的 swap 策略,以及为什么现代 Android 全靠 zram 不靠磁盘。

2026-05-03 · os

【操作系统百科】Slab/SLUB 分配器

buddy 只管页粒度(4K+),内核大多数对象只有几十到几百字节。slab/SLUB 在 buddy 之上做对象级缓存。本文讲 slab 历史、SLUB 接手、SLOB 退场、kmem_cache、per-CPU cache、KASAN 集成。


By .