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 期刊撰写文章

最后更新于2个月前

  • 原文链接:

  • 作者:MARIUSZ ZABORSKI

谷歌编程之夏 2020 结束于九月。这个了不起的计划让年轻学生在为开源组织贡献的同时,获得了大量的经验。FreeBSD 项目自计划开始以来每年都参与其中。在这篇文章中,我们将从学生和导师的角度介绍这个项目。

谷歌编程之夏是一项由谷歌于 2005 年启动的年度国际项目。目标是让学生接触开源项目,计划的形式是为学生提供暑期奖学金。学生们可以在暑假期间为开源组织编写代码,而不是寻找实习机会或度假。

学生们需要近乎全职地投入他们选择的项目,谷歌为他们提供津贴。津贴金额每年有所不同,目前,津贴金额取决于学生的所在地,范围从 3000 美元到 7000 美元不等。

幸运的是,学生们并不孤单,因为谷歌编程之夏要求学生与导师合作。导师是开源组织的成员和贡献者,且对学生工作的主题感兴趣。

谷歌编程之夏在夏季之前就已经开始。每年一月,谷歌会开放申请,开源项目可以申请加入该计划。一个好的做法是提前准备,并不断收集谷歌编程之夏项目的想法。可以创建简单的 Wiki 页面和谷歌文档,收集潜在的项目供学生参与。项目可以从简单到复杂不等,但必须考虑到学生在暑假期间应该能够提供一定的代码。提供有趣的项目非常重要;否则,学生可能会选择其他开源组织。此外,记得组织中的某个人(导师)应该对该项目负责。这个人必须能够在学生的旅程中提供帮助。

几个月后,开源组织将被批准或拒绝加入该计划——通常在二月底会收到通知。之后,学生们将有一些时间来寻找自己感兴趣的开源组织和项目。他们可以通过邮件列表、IRC、Slack 或其他任何方式讨论这些想法。如果他们对列出的项目不感兴趣,学生也可以提出自己的项目建议,之后开源组织可以为该项目寻找导师。

在三月,开源社区将审查学生的申请并分配导师。谷歌编程之夏组织者会通知每个开源项目其名额数量。不幸的是,并不是所有学生都能获得名额。申请将根据学生的研究质量、对主题的知识以及过去几个月的参与度进行评审。对学生的一个好建议是尽早展示兴趣,思考项目的挑战,进行一些研究,与社区讨论挑战,甚至看看代码。没人期望你能像背诵自己名字一样熟悉代码——导师很可能会帮你解读源代码——但自己主动去了解并付出额外努力,能展现你的参与度。

导师不仅需要在项目的主题领域具有专业知识,还应该融入开源社区。如果出现他们无法帮助的问题,或者学生需要额外的访问权限,导师应该知道该去哪里。他们应该了解项目的代码指南,并能提交代码或找到能提交代码的人。对于某些学生来说,获得第一次提交开源的机会可能比奖学金更重要(你应该专注于那些学生)。一些项目可能会有多个导师。

学生被接纳后,社区联络和编程工作开始。这是学生们辛勤工作的时刻。在 FreeBSD,我们为学生在这一阶段应该做的事情提供了指南。其中之一是维护他们项目的 Wiki 页面。学生应尽可能频繁地更新页面,这有助于项目在组织中的可见性。记录我们在夏季遇到的问题和挑战是很好的做法,因为许多项目在计划结束时可能还没有完成。通过记录已完成的工作,我们可以在谷歌编程之夏结束后将其交接给其他人。

学生还应该每周向邮件列表发送状态更新。这项活动激励学生分享并记录他们所取得的成就,同时也有助于项目的可见性。它还提高了社区的凝聚力。邮件列表中可能有一些开发者能帮助解决问题或提供不同的项目视角。分享状态更新确实非常值得。

最后但同样重要的是,学生应尽可能频繁地提交代码。代码质量其实并不重要——你可以随时改进它——但看到代码后讨论问题会容易得多。有些学生每个月只提交一到两次代码,这样做是行不通的。经过一个月的编程,我们可能会发现应该朝完全不同的方向走,而当导师看不到代码时,很难帮助学生。导师应鼓励学生频繁提交代码,不要害怕展示未完成的工作。

大多数时候,项目是在网上进行的。只有少数学生有机会每天与导师在现场工作。有时,沟通可能会变得困难,特别是当导师和学生位于不同的时区时。学生和导师之间的电子邮件可能显得太正式,学生可能不愿意写邮件。许多学生也可能将这种关系视为教授与学生的关系。如果你从未见过导师本人,就很难想象他们会如何反应。学生和导师应尽量减少沟通负担。通过 IRC、Slack 或 Discord 进行沟通,比电子邮件更适合此目的。

导师还应记住,项目是他们的,他们对其负责。如果你几周没有回应问题,学生可能会因此失去继续参与的动力。你必须帮助学生,但要记住,真正的工作应该由学生完成。你在这里的角色是帮助管理过程,并协助与你熟悉的社区进行沟通。

导师会在夏季期间评估他们的学生几次。(在之前的几年里,有两次评估,现在有三次。)导师将学生的进展报告给谷歌。记住,如果导师和学生没有按时提交评估,谷歌将取消项目。谷歌会在每次成功评估后支付学生报酬。

如果项目进展顺利,那么很好,这并不复杂。导师只需要将学生推进到下一个阶段。如果学生没有写过一行代码,那么接下来的部分非常不愉快,但仍然很简单。

不幸的是,也存在一种中间状态。有些学生在项目开始时非常活跃,但随后突然消失。也有一些学生匆忙地在评估前做完所有工作。有时,很难知道学生做了多少工作,因为远程工作的情况(这就是为什么提交代码如此重要)。最重要的是,导师需要问自己是否还想继续与学生合作。如果不想,必须做出艰难的决定。

如果还有希望,导师必须告诉学生应该改进的地方——如果他们没有表现得更好,那么下次评估时就要给他们不及格。如果你做的工作比你的学生还多,那么你必须给学生不及格。如果你不断挣扎于让学生参与进来,那么你必须给他们不及格。学生的参与度比他们写的代码质量更为重要。

没有比这更好的方式让开源组织获得新鲜血液。大多数学生并未接触到冷门的开源项目。谷歌编程之夏让学生从内部了解一个项目。如果他们能为项目做出贡献(如果他们做了,那就完美了),但这并不是最重要的。最重要的是向他们展示一个优秀的开源环境,让他们从中学习。如果我们做到这一点,越来越多的学生将留在这个环境中,大家都会从中受益。学生将获得本来难以获得的知识,并获得不错的简历条目,这可能为他们打开新的大门。

历史证明,许多开始参与谷歌编程之夏项目的学生在多年后仍然继续为该项目做贡献。在作者看来,这应该是任何参与谷歌编程之夏的开源组织的目标。我们必须记住,学生的代码可能不完美,但如果他们能在项目中坚持超过这三个月,他们对组织的贡献将远远超过单个项目的成果。许多学生第二年就成为了谷歌编程之夏导师!

我们希望在下一场谷歌编程之夏活动中看到你作为学生或导师!


MARIUSZ ZABORSKI 是 Fudo Security 的 QA 和开发经理。他在 2013 年完成了一个成功的谷歌编程之夏项目,并为 FreeBSD 项目指导了几位谷歌编程之夏学生。Mariusz 自 2015 年起自豪地拥有 FreeBSD commit 权限。他的主要兴趣领域是操作系统安全和低级编程。在 Fudo Security,Mariusz 领导一个团队开发用于监控、记录和控制 IT 基础设施中流量的最先进解决方案。2018 年,Mariusz 组织了波兰 BSD 用户组。在空闲时间,他喜欢在 https://oshogbo.vexillium.org 上写博客。

Google Summer of Code