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

在本页
在GitHub上编辑
导出为 PDF
  1. 2020-0910 贡献与入门

撰写良好的提交消息

上一页代码审查下一页如何在不是程序员的情况下做出贡献——成为 FreeBSD 译者

最后更新于1个月前

  • 原文链接:

  • 作者:ED MASTE

为何提交信息很重要?

当你在 Git、Subversion 或其他版本控制系统(VCS)中提交更改时,你会被要求写一些描述提交的文本——提交信息(Commit Messages)。那么,提交信息有多重要呢?你是否应该花费相当多的精力去写它?如果你写的是“修复了一个 bug”,这真的很重要吗?

大多数项目有不止一个开发者,并且持续一段时间。提交信息是与当前和未来的其他开发者沟通的一个非常重要的方法。

FreeBSD 拥有数百名活跃的开发者和数十年的历史,涉及数十万次提交。在这段时间里,开发者社区已经学会了良好的提交信息有多么宝贵;有时这些是通过痛苦的教训学到的。

提交信息至少有三个作用:

  • 与其他开发者沟通

FreeBSD 的提交会生成邮件,发送到各种邮件列表。这些邮件包括提交信息以及补丁本身。提交信息还可以通过像 git log 这样的命令查看。这些信息旨在让其他开发者了解正在进行的更改;其他开发者可能希望测试这些更改,可能对某个主题感兴趣,想要更详细地审查,或者可能有自己的项目在进行,并且从互动中受益。

  • 让更改可发现

在一个有着悠久历史的大型项目中,在调查问题或行为变化时,可能很难找到相关的更改。冗长且详细的提交信息可以方便地进行搜索,找出可能相关的更改。例如,使用 git log --since 1 year --grep USB timeout。

  • 提供历史文档

提交信息用于为未来的开发者记录更改,可能是在几年或几十年后。这些未来的开发者甚至可能是你,原始作者。今天看起来显而易见的更改,过一段时间后可能就不那么显而易见了。

git blame 命令会将每一行源文件标注上进行更改的提交(哈希值和主题行)。

在确立了提交信息的重要性后,以下是一个良好的 FreeBSD 提交信息的元素:

  • 以主题行开始

提交信息应以一行简短的主题开始,简要概括更改内容。主题应该能够让读者快速判断该更改是否值得关注。

  • 保持主题行简短

主题行应尽可能简短,同时保留所需的信息。这有助于提高浏览 git log 的效率,并使 git log --oneline 能够在 80 列的行内显示短哈希和主题行。一个好的经验法则是保持在 63 个字符以内,如果可能,目标应是 50 个字符及更少。

  • 如果适用,主题行前缀加上组件名

如果更改涉及某个特定组件,主题行可以加上该组件名并以冒号(:)结尾。

✓ foo: Add -k option to keep temporary data

在上述建议的 63 个字符限制内包括前缀,以便避免 git log --oneline 换行。

  • 主题首字母大写

主题本身的首字母要大写。如果有前缀,除非必要(如 USB:),否则无需大写。

  • 主题行不要以标点符号结尾

不要以句号或其他标点符号结尾。在这方面,主题行就像新闻头条,或电子邮件中的主题标题。

  • 用空行分隔主题和正文

用空行分隔主题和正文。

一些微不足道的提交不需要正文,只有主题行。

✓ ls: Fix typo in usage text
  • 限制消息为 72 列

git log 和 git format-patch 会将提交信息缩进四个空格。72 列换行使右边缘有一致的对齐边距。将消息限制在 72 个字符以内还可确保提交信息格式化后的补丁在 RFC 2822 建议的电子邮件行长度限制(78 个字符)以下。这个限制与多种可能渲染提交信息的工具兼容;较长的行可能导致换行不一致。

  • 使用现在时、命令语气

这有助于简短的主题行,并提供一致性,包括自动生成的提交信息(例如,git revert 生成的提交信息)。当阅读提交主题列表时,这一点很重要。可以将主题视为完成句子“when applied, this change will …”的部分。

✓ foo: Implement the -k (keep) option
✗ foo: Implemented the -k option
✗ This change implements the -k option in foo
✗ -k option added
  • 关注“做了什么”和“为什么做”,而非“如何做”

解释更改的目标是什么,为什么要做这个更改,而不是怎么做。

不要假设读者已经了解问题。解释该更改的背景和动机。如果有基准数据,可以包含在内。

如果更改存在限制或不完整的方面,请在提交信息中描述这些内容。

  • 考虑是否有部分提交信息应该改为代码注释

有时,在写提交信息时,你可能会写出一两句话,解释更改中一些棘手或令人困惑的部分。这时,可以考虑是否将这些解释作为代码注释放在代码中,这样会更有价值。

  • 为未来的自己写提交信息

在写提交信息时,你掌握了所有背景信息——是什么促使了这个更改,考虑并拒绝的替代方案,更改的局限性等等。想象一下,几年后你回顾这个更改时,写出提交信息的方式应该能够提供这些必要的背景。

  • 提交信息应该独立存在

你可以包括对邮件列表帖子、基准结果网站或代码审查链接的引用。然而,提交信息应该包含所有相关信息,以防这些引用在未来不再可用。

类似地,提交可能会引用先前的提交,例如修复 bug 或还原提交。在引用的提交(或其他合适的简短引用)中,除了提交标识符(修订号或哈希值)外,还应该包括引用提交的主题行。随着每次版本控制系统的迁移(从 CVS 到 Subversion 再到 Git),以前系统中的修订标识符可能变得难以跟踪。‘

  • 在页脚中包含适当的元数据

提交信息的最后一段可能包含一个或多个标准元数据标签。FreeBSD 中使用的标准标签有:

标签
描述

PR

FreeBSD 问题报告(Bugzilla)编号

Submitted by

原作者的 ID(如果不是提交者)

Reported by

报告问题的第三方 ID

Reviewed by

审阅者的 ID

Tested by

测试此更改的人员的 ID

Approved by

批准此更改的导师或代码所有者

Obtained from

来自另一个项目的更改源

MFC after

从 Current 合并到 Stable 前的时间周期

MFC with

与此更改一同合并的关联提交

MFH

用于合并请求的 Ports 季度分支

Relnotes

是否应包含此更改的发布说明(是/否)

Security

与安全问题相关的外部参考,例如 CVE 编号

Sponsored by

资助此更改的组织或事件

Differential Revision

FreeBSD Phabricator 实例中代码审查的完整链接

“ID”表示一个 FreeBSD 用户 ID 或一个名字和电子邮件地址。多个 ID 可以作为逗号分隔的列表呈现,或者通过在后续行中重复元数据标签来表示。


ED MASTE 管理着 FreeBSD 基金会的项目开发工作。他还是选举产生的 FreeBSD 核心团队的成员。除了 FreeBSD,他还为多个其他开源项目做出了贡献,包括 LLVM、ELF 工具链、QEMU 和 Open vSwitch。他与妻子 Anna 以及儿子 Pieter 和 Daniel 一起住在加拿大的基奇纳 - 滑铁卢。

Writing Good Commit Messages