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

【操作系统百科】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-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 .