FreeBSD 中文社区 2025 第二季度问卷调查
FreeBSD 中文社区(CFC)
VitePress 镜像站QQ 群 787969044视频教程Ⅰ视频教程Ⅱ
  • FreeBSD 从入门到追忆
  • 中文期刊
  • 状态报告
  • 发行说明
  • 手册
  • 网络文章集锦
  • 笔记本支持报告
  • Port 开发者手册
  • 架构手册
  • 开发者手册
  • 中文 man 手册
  • 文章
  • 书籍
  • FreeBSD 中文期刊
  • 编辑日志
  • 2025-123 下游项目
    • FreeBSD 发布工程:新主管上任
    • GhostBSD:从易用到挣扎与重生
    • BSD Now 与将来
    • 字符设备驱动教程(第三部分)
    • 学会走路——连接 GPIO 系统
    • FreeBSD 中对 SYN 段的处理
    • FreeBSD 2024 年秋季峰会
  • 2024-1112 虚拟化
    • 字符设备驱动程序教程(第二部分)
    • 面向 Linux 和 Windows 用户的 bhyve
    • Xen 与 FreeBSD
    • Wifibox:一种嵌入式虚拟化无线路由器
    • 嵌入式 FreeBSD:Fabric——起步阶段
    • DGP:一种新的数据包控制方法
    • 会议报告:我在都柏林的 EuroBSDCon 体验
  • 2024-0910 内核开发
    • 字符设备驱动程序教程
    • VPP 移植到了 FreeBSD:基础用法
    • 利用 Kyua 的 Jail 功能提升 FreeBSD 测试套件的并行效率
    • FreeBSD 上的 Valgrind
    • 嵌入式 FreeBSD:探索 bhyve
    • TCP/IP 历险记:FreeBSD TCP 协议栈中的 Pacing
    • 实用软件:实现无纸化(Paperless)
  • 2024-0708 存储与文件系统
    • FreeBSD 中的 NVMe-oF
    • FreeBSD iSCSI 入门
    • 使用 ZFS 原生加密保护数据
    • 嵌入式 FreeBSD:打造自己的镜像
    • TCP LRO 简介
    • 基于 Samba 的时间机器备份
  • 2024-0506 配置管理对决
    • 基本系统中的 mfsBSD
    • rdist
    • Hashicorp Vault
    • 在 GitHub 上向 FreeBSD 提交 PR
    • 悼念 Mike Karels
    • 2024 年 5-6 月来信
    • 嵌入式 FreeBSD 面包板
    • TCP/IP 历险记:TCP BBLog
    • 实用软件:开发定制 Ansible 模块
  • 2024-0304 开发工作流与集成
    • FreeBSD 内核开发工作流程
    • FreeBSD 与 KDE 持续集成(CI)
    • 更现代的内核调试工具
    • 从零开始的 ZFS 镜像及 makefs -t zfs
    • 提升 Git 使用体验
  • 2024-0102 网络(十周年)
    • FreeBSD 中的 RACK 栈和替代 TCP 栈
    • FreeBSD 14 中有关 TCP 的更新
    • if_ovpn 还是 OpenVPN
    • SR-IOV 已成为 FreeBSD 的重要功能
    • FreeBSD 接口 API(IfAPI)
    • BATMAN:更优的可移动热点网络方式
    • 配置自己的 VPN——基于 FreeBSD、Wireguard、IPv6 和广告拦截
    • 实用软件:使用 Zabbix 监控主机
  • 2023-1112 FreeBSD 14.0
    • LinuxBoot:从 Linux 启动 FreeBSD
    • FreeBSD 容器镜像
    • 现在用 Webhook 触发我
    • 新的 Ports 提交者:oel Bodenmann (jbo@freebsd.org)
  • 2023-0910 Port 与软件包
    • 回忆录:与 Warner Losh(@imp)的访谈
    • 在你自己的仓库中定制 Poudriere 源
    • Wazuh 和 MITRE Caldera 在 FreeBSD Jail 中的使用
    • PEP 517
    • CCCamp 2023 旅行报告
  • 2023-0708 容器与云
    • 在 Firecracker 上的 FreeBSD
    • 使用 pot 和 nomad 管理 Jail
    • 会议报告:C 与 BSD 正如拉丁语与我们——一位神学家的旅程
    • 抒怀之旅:与 Doug Rabson 的访谈
    • 基于 Jail 的广告拦截教程
    • 我们收到的来信
  • 2023-0506 FreeBSD 三十周年纪念特刊
    • CheriBSD 近十多年的历程
    • AArch64:成为 FreeBSD 新的一级架构
    • 岁月如梭:我个人的时间线
    • 安装 FreeBSD 1.0:回顾 30 年前
    • ZFS 是如何进入 FreeBSD 的呢?
    • 我不是来自约克郡的,我保证!
    • 回忆录:采访 David Greenman Lawrence
    • FreeBSD 和早期的 Unix 社区
    • 早期的 FreeBSD 移植
    • FreeBSD 30 周年:成功的秘诀
    • FreeBSD 在日本:回忆之旅与今日之实
  • 2023-0304 嵌入式
    • CheriBSD port 和软件包
    • 让我们来试试 ChatGPT
    • GPU 直通
  • 2023-0102 构建 FreEBSD Web 服务器
    • ZFS 的原子 I/O 与 PostgreSQL
    • 虚拟实验室——BSD 编程研讨会
    • ZFS 简介
    • 会议报告:落基山庆祝女性计算机科学家
    • 进行中的工作/征求反馈:数据包批处理
    • 基金会与 FreeBSD 桌面
  • 2022-1112 可观测性和衡量标准
    • 在 FreeBSD 的 DDB 内核调试器中编写自定义命令
    • DTrace:老式跟踪系统的新扩展
    • 基于证书的 Icinga 监控
    • 活动监控脚本(activitymonitor.sh)
    • 实用 IPv6(第四部分)
    • EuroBSDCon 会议报道
    • 实用 Port:Prometheus 的安装与配置
    • 书评:《用火解决问题:管理老化的计算机系统(并为现代系统保驾护航)》Kill It with Fire: Manage Aging Computer Systems (and Future Proof Modern Ones)
  • 2022-0910 安全性
    • CARP 简介
    • 重构内核加密服务框架
    • PAM 小窍门
    • SSH 小窍门
    • 实用 IPv6(第三部分)
    • 书评:Understanding Software Dynamics(深入理解软件性能——一种动态视角)—— Richard L. Sites 著
    • 访谈:保障 FreeBSD 安全性
    • MCH 2022 会议报告
  • 2022-0708 科研、系统与 FreeBSD
    • 在 FreeBSD 上构建 Loom 框架
    • 教授本科生 Unix 课程
    • FreeBSD 入门研讨会
    • 实用 IPv6(第二部分)
    • 在 2022 年及以后推广 FreeBSD
    • 进行中的工作/征求反馈:Socket 缓冲区
    • FreeBSD 开发者峰会报告
    • 支持 Electromagnetic Field 2022
  • 2022-0506 灾难恢复
    • 使用 FreeBSD 构建高弹性的私有云
    • LLDB 14 —— FreeBSD 新调试器
    • 实用 IPv6(第一部分)
    • 利用 netdump(4) 进行事后内核调试
    • 进行中的工作/征求反馈:FreeBSD 启动性能
    • 实用 Port:在 OpenZFS 上设置 NFSv4 文件服务器
  • 2022-0304 ARM64 是一级架构
    • FreeBSD/ARM64 上的数据科学
    • Pinebook Pro 上的 FreeBSD
    • 嵌入式控制器的 ACPI 支持
    • 进行中的工作/征求反馈:Lumina 桌面征集开发人员
    • 实用 Port:如何设置 Apple 时间机器
  • 2022-0102 软件与系统管理
    • 为 FreeBSD Ports 做贡献
    • 使用 Git 贡献到 FreeBSD Ports
    • CBSD:第一部分——生产环境
    • 将 OpenBSD 的 pf syncookie 代码移植到 FreeBSD 的 pf
    • 进行中的工作/征求反馈:mkjail
    • 《编程智慧:编程鬼才的经验和思考》(The Kollected Kode Vicious)书评
    • 会议报告:EuroBSDCon 2021 我的第一次 EuroBSDCon:一位新组织者的视角
  • 2021-1112 存储
    • 开放通道 SSD
    • 构建 FreeBSD 社区
    • 与完美操作系统同行 27 年
    • 进行中的工作/征求反馈:OccamBSD
    • 通过 iSCSI 导入 ZFS ZIL——不要在工作中这样做——就像我做的那样
  • 2021-0910 FreeBSD 开发
    • FreeBSD 代码审查与 git-arc
    • 如何为 FreeBSD 实现简单的 USB 驱动程序
    • 内核开发技巧
    • 程序员编程杂谈
  • 2021-0708 桌面/无线网
    • 通往 FreeBSD 桌面的直线路径
    • FreeBSD 13 中的人机接口设备 (HID) 支持
    • Panfrost 驱动程序
    • 用 Git 更新 FreeBSD
    • FreeBSD 的新面孔
    • 想给你的桌面加点佐料?
  • 2021-0506 安全
    • 七种提升新安装 FreeBSD 安全性的方法
    • copyinout 框架
    • 使用 TLS 改善 NFS 安全性
    • Capsicum 案例研究:Got
    • 对 Jail 进行安全扫描
  • 2021-0304 FreeBSD 13.0
    • 展望未来
    • FreeBSD 13.0 工具链
    • FreeBSD 13.0 中有新加载器吗?
    • TCP Cubic 准备起飞
    • OpenZFS 中的 Zstandard 压缩
    • 会议报告:FreeBSD 供应商峰会
    • Git 不够吗?
  • 2021-0102 案例研究
    • Tarsnap 的 FreeBSD 集群
    • BALLY WULFF
    • Netflix Open Connect
    • FreeBSD 的新面孔
    • 写作学者的 FreeBSD
    • 在世界之巅
  • 2020-1112 工作流/持续集成(CI)
    • FreeBSD Git 快速入门
    • 使用 syzkaller 进行内核 Fuzzing
    • Mastering Vim Quickly 书评
    • 线上会议实用技巧
    • 在控制台上进行网络监控
  • 2020-0910 贡献与入门
    • 采访:Warner Losh,第 2 部分
    • 代码审查
    • 撰写良好的提交消息
    • 如何在不是程序员的情况下做出贡献——成为 FreeBSD 译者
    • 如何成为文档提交者
    • 谷歌编程之夏
    • 为 FreeBSD 期刊撰写文章
    • 你为什么使用 FreeBSD
    • FreeBSD 的新面孔
  • 2020-0708 基准测试/调优
    • FreeBSD Friday
    • 采访:Warner Losh,第 1 部分
    • 构建和运行开源社区
    • 在 FreeBSD 上轻松搭建我的世界(Minecraft)服务器
    • FreeBSD 的新面孔
  • 2020-0506 网络性能
    • 内核中的 TLS 卸载
    • 访谈:Michael W Lucas
    • FreeBSD 桌面发行版
    • 使用 Poudriere 进行 Port 批量管理
    • FreeBSD 的新面孔
由 GitBook 提供支持
LogoLogo

FreeBSD 中文社区(CFC) 2025

在本页
  • 大学时期
  • 被 Jail 限制了
  • syslog-ng 的岁月
  • 接下来呢?
在GitHub上编辑
导出为 PDF
  1. 2021-1112 存储

与完美操作系统同行 27 年

上一页构建 FreeBSD 社区下一页进行中的工作/征求反馈:OccamBSD

最后更新于1个月前

  • 原文链接:

  • 作者:PETER CZANIK

如果你是 FreeBSD 的长期用户,你可能已经知道我所说的一切。而且,事实上,你可能还能补充一些观点。但希望也有一些读者是 Linux 甚至 Windows 用户,能够学到一些新东西!

FreeBSD 不仅仅是个内核,它是一个完整的操作系统。它包含了启动和使用系统所需的一切:网络工具、文本编辑器、开发工具等等。为什么这很重要呢?因为所有这些组件是一起开发的,它们完美地协同工作!而且,一个精心打磨的系统也更容易被记录和文档化。我最喜欢的文档之一就是 FreeBSD 手册,它覆盖了大部分操作系统内容,并且(大多数时候)是最新的。

当然,并不是所有的东西都能集成到基本操作系统中,这时 FreeBSD 的 ports 和 packages 就能派上用场。Ports 系统实现了基本系统和第三方软件的清晰分离,这使得你可以在 FreeBSD 基本系统上安装第三方软件。

有成千上万的现成软件包可选。例如,所有的图形桌面应用程序都可以通过 ports 安装,像各种 Web 服务器或更现代的开发工具亦如此。

FreeBSD 很灵活。它可以运行在树莓派到桌面计算机,再到高端服务器的任何设备上。你可以使用 FreeBSD 项目提供的二进制文件来安装基本系统和软件包。但你也可以重新编译一切,并根据自己的环境进行精细定制。难怪这么多设备是基于 FreeBSD 的。

FreeBSD 的工程设计非常出色。操作系统的每个小细节在实施前都经过精心设计,这通常能带来完美的解决方案,但也意味着进展稍微慢一些。如果你喜欢使用最新、最强大的硬件作为桌面,那么它可能还没有得到充分支持——甚至可能完全不支持。这也是为什么很多人(包括我自己)认为 FreeBSD 是一款服务器操作系统,尽管 FreeBSD 在桌面上运行得也非常完美——只是在老旧硬件上。

大学时期

27 年前,当我开始上大学时,学校已经有了一台 FreeBSD 服务器——一台 486 电脑,配有 16 MB(不是 GB)的内存和 SCSI 硬盘。我记不清具体是哪个版本的 FreeBSD,但它应该是 1.X 版本,因为 2.0 版本仅几个月后才发布。花了很多天的时间下载新版本:当时我们整个大学只有 64K 的网络带宽。

学校没有 Linux 系统,而我的任务就是安装第一台 Linux 服务器,这让我有机会同时体验这两种操作系统的早期发展。在安装系统的数量上,Linux 很快凭借其“够用”的态度赢了,因为完美的 FreeBSD 往往在新硬件和新技术的采用上比较慢。然而,在工作上,FreeBSD 那种精心设计、不出差错的实现方式,至今依然是更愉快的体验——至少对我而言是这样。

在最初的两年里,我是一个常规的 FreeBSD 用户,但在接下来的十六年里,我还维护着这台服务器,即使我已经离开了大学。FreeBSD 因其稳定性而闻名,直到 Gmail 广泛普及后很久,仍然有很多学生和教职工要求在那台服务器上注册用户名。

被 Jail 限制了

幸运的是,这次没有是我被限制,而是那些 Web 服务器!我做了一份兼职系统管理员的工作,管理着 Web 服务器。提供静态页面并不可怕,但提供 PHP 页面就需要一些勇气。幸运的是,就在我需要为客户解决 PHP 服务问题时,FreeBSD 引入了 jail。

最初,我只有一台服务器,所有的 jail 都是手动创建和配置的。当客户数量不多时,这并不是什么大问题,但当你有多台服务器和数十个客户时,这就成了一个相当麻烦的问题。所以,我引入了一些 Shell 脚本,后来我们又引入了集中管理、LDAP 和基于 Windows 的管理应用程序,几乎所有的工作都能自动化完成。

虽然我们周围许多托管公司不断报告影响多个客户的安全漏洞,但我们使用经过精心加固的 FreeBSD 基本系统以及自建和加固的 jail 完美解决了这个问题。当然,即便是最加固的 jail 环境,在配置不当的 WordPress 实例面前也是无能为力的。确实有些 Web 服务器被篡改,但这些事件通常仅影响单个 jail。当你在一台服务器上运行数百个 jail 时,这也不算什么,顶峰时期,我们的集群中有数十台物理和虚拟机器。所有的编译工作都是我在这些服务器上完成的,并且我移除了所有运行这些 jail 所不必要的基本系统选项。jail 内的软件在编译时和配置时都进行了加固。

待我离开公司,同样的系统在没有任何更新的情况下继续使用了五年。他们仔细监控系统日志,并在关闭整个系统之前,我再次获得访问权限进行审计。在花了几个小时检查最后剩余的主机后,我没有发现任何安全事件的证据。FreeBSD jail 真的很棒!

syslog-ng 的岁月

当我加入现在的工作岗位时,第一项任务之一就是确保 Linux 发行版和 FreeBSD 拥有最新的 syslog-ng 包。更新一个包的速度会更快,如果在请求更新的同时,我还向包维护者提供了一个更新后的包。所以,我从维护者的角度学习了 FreeBSD ports 基础知识。

我不是 FreeBSD ports 的提交者,因为我只维护一个包,但我与一个提交者紧密合作,这样对我们双方都更为轻松:我对 syslog-ng 更为熟悉,所以我可以修改 Port 以启用新功能。他对 FreeBSD ports 比我了解得多,可以确保 Port syslog-ng 符合最新的 Ports 建议。

十年前,在 FOSDEM 上,我把部分时间花在了 BSD 开发室。那时有一场关于如何通过额外的包扩展基于 FreeBSD 的设备的演讲。演讲结束后,我问如何将 syslog-ng 集成进去。我甚至把我的名片递给了演讲者。虽然从未收到联系,但在那次讨论后不久,我发现基于 FreeBSD 的设备开始使用 syslog-ng 进行日志记录。

syslog-ng 以其可移植性而闻名。多年来,所有支持的商业 UNIX 变体逐渐消失,开发团队将重点转向 Linux。我的常规测试帮助确保 syslog-ng 没有变成仅支持 Linux 的软件。

几年前,我了解到了 BastilleBSD,这是一款 FreeBSD 的 jail 管理系统。记得两十年前我自己实现脚本时的痛苦,我真的很欣赏 BastilleBSD 提供的功能和易用性。现在它有了模板系统——类似于 Linux 世界中的 Dockerfile——使创建 jail 更加简单。它还提供了一个 syslog-ng 的模板。你可以在这里阅读更多信息:https://www.syslog-ng.com/community/b/blog/posts/running-syslog-ng-in-bastille-revisited

接下来呢?

偶尔,我会尝试将 FreeBSD 用作桌面系统,但很快就放弃了。我喜欢最先进的硬件,但不幸的是,FreeBSD 并不支持。例如,Windows 和 Linux 在我的 AMD Ryzen 5800 + nVidia 3070 系统上运行得没有问题,而 FreeBSD 只能以文本模式运行——而且我无法让图形功能正常工作。所以,对我来说,FreeBSD 仍然是一款服务器操作系统,我非常喜欢它。而待我再次拥有一些真正的服务器——不仅仅是用于开发和测试的虚拟机——我期待在它们上运行 FreeBSD!


PETER CZANIK 从 1994 年使用 FreeBSD 1.X 版本开始。他是一名工程师,目前在 Balabit(One Identity 业务的一部分)担任开源布道者,Balabit 开发了 syslog-ng。他协助 FreeBSD 和 Linux 发行版维护 syslog-ng 包,跟踪 bug,帮助用户,并定期在各种会议上演讲(如 SCALE、All Things Open、FOSDEM、LOADays 等)。在有限的空闲时间里,他对非 x86 架构感兴趣,并在他的 PPC 和 ARM 机器上工作。

27 Years with Perfect OS