Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

如何正确接收 GitHub 的消息邮件 #49

Open
cssmagic opened this issue Mar 20, 2015 · 67 comments
Open

如何正确接收 GitHub 的消息邮件 #49

cssmagic opened this issue Mar 20, 2015 · 67 comments
Labels

Comments

@cssmagic
Copy link
Owner

cssmagic commented Mar 20, 2015

如何正确接收 GitHub 的消息邮件

背景

我厂的开发流程通常都是基于 GitHub 的。在 GitHub 上 review 代码,也是我日常工作的重要组成部分。对我来说,在 code review 过程中最讨厌的莫过于,我在 pull request 或 commit 下面评论或 @ 人,往往石沉大海,没有回音。我事后追问当事人,他们的回复往往是 “不知道你 @ 我了呀~”。

这让我非常恼火。所以,我决定写篇文档给所有人看,避免他们漏看重要的 GitHub 消息。此后在 GitHub 不回复我的人,差不多也可以绝交了罢!

GitHub 的通知机制

通知的类型和方式

在两种情况下,我们会收到 GitHub 的通知。

  • 我关注的(Watching):当我关注了某个项目之后,相当于订阅了这个项目的所有更新,即这个项目的新 release、新 issue、新 PR 及所有讨论都会通知我。

  • 我参与的(Participating):当我参与到某个 issue、PR 或 commit 的讨论,或被别人 @ 后,我都会持续收到这个讨论的后续更新。

后面一种情况似乎对我更加重要一些。如果不需要密切跟进某个项目,我应该避免关注它。

另外,GitHub 会通过以下两种方式来通知我们:

  • 站内信(Web):当我登录 GitHub 网站时,如果有新消息,在导航栏会看到一个小蓝点。点进去就可以看到详细通知。

    站内信收件箱

  • 电子邮件(Email):通知会直接发送到我的邮箱,而且我直接回复邮件的效果相当于登录到相关页面回复,非常方便。

可见,前者是被动方式,提醒能力太弱。而后者是主动推送,时效性好,但我需要注意的就是控制消息密度,避免被轰炸。因此,接下来,我们来了解一下 GitHub 的 “自动关注” 功能。

自动关注

不错过重要的消息,首先意味着不能被无关紧要的消息湮没。如果你经常收到大量的 GitHub 消息,那你可能就全都不看了。因此,我们需要关掉 “自动关注” 功能。

登录 GitHub 通知中心页面,即可关闭这个功能:

自动关注功能

为什么要关它?这个功能很有意思,每当你获得了一个 repo 的 push 权限之后,GitHub 就会帮你自动关注这个 repo。这在开源社区是很有用的,因为当你获得了这个权限时,往往意味着你成为了这个 repo 的核心维护者,你确实需要第一时间掌握这个项目的一举一动。

但这对于公司内部项目就不那么合适了。比如我们的主站项目是一个私有 repo,几乎公司内的每位工程师都会 fork 它;同时出于协作的需要,每个 fork 都需要向所有工程师开放读写权限。因此,你将自动关注这近百个 repo,而这些 repo 的任何风吹草动都会通知你,即使你并未真正在其它同事的 fork 上工作。

总之,为了避免无关消息对你的轰炸,请关掉自动关注功能。你可能已经关注了一堆无关紧要的 fork 了,请记得在你的 关注列表页面 逐一取消。(如果你不是核心管理员,建议你把主站项目的 upstream 也取消关注。)

个人设置

了解完 GitHub 的特性之后,我们就可以针对性地做出配置和选择了。

设定 Email

正常情况下,每个人在工作时间都会开着自己的工作邮箱。那么首先,需要确保 GitHub 的消息是发到这个邮箱的。由于每个人的 GitHub 账号往往并非是用工作邮箱注册的,我们需要把邮箱搞对。

登录 GitHub 的邮箱设置页面,添加自己的工作邮箱。随后工作邮箱会收到一封验证邮件,完成验证之后,你的 GitHub 账号就绑定了两个邮箱。

账号邮箱设置

(并不需要为把这个工作邮箱设置为 “primary”,只要验证通过就可以了。)

到这里我们就做好 Email 的准备工作。

通知中心

接下来,我们进入 GitHub 通知中心,为两种不同类型的通知选择通知方式。请确保至少第一个 “Email” 是被选中的:

通知方式设置

接下来,选择接收邮件通知的邮箱。选择我们刚刚添加的工作邮箱,保存。

通知邮箱设置

(这里的邮箱设置只会影响消息的接收,不会影响账号身份。)

好了,大功告成。从此以后,所有重要的 GitHub 消息都会发送到你的工作邮箱。最后,再告诉你几个小技巧,相信你用得上。

减少干扰

取消关注某个 Repo

前面已经提到过 你的关注列表,在那里,你可以随时清理不再重要的项目。同时,进入任何项目的页面,在右上角都可以选择对它的关注方式。

Repo 的关注选项

“Not watching” 意味着取消关注,你将不会收到与你无关的通知。而与你有关的(你发起的、主动参与的或被 @ 的)讨论有新回复,你还是会收到通知的。

请注意不要选择 “Ignoring”,那意味着你连重要的消息也收不到了。

取消关注某个讨论

当某个讨论已经没你什么事了,但仍然不断有后续消息涌进来,那就果断屏蔽它吧。从消息邮件中的链接点到网页,找到如下所示的 “取消订阅” 的按钮,即可取消关注这个讨论。

取消订阅-1

取消订阅-2

锁定某个讨论

当某个 issue 或 PR 已经没有继续讨论的必要的,你可以锁定它——当然前提是你得是这个 repo 的管理员。

屏蔽某个人

如果你遇到了无聊的人总是骚扰你,可以到它的用户页面,屏蔽并举报。

结语

相信看到这里,你已经对 GitHub 的通知机制十分了解了吧,并且应该可以灵活配置 GitHub 消息的接收方式了。

好吧,就这样吧。如果以后还是不回复我,绝交。


© Creative Commons BY-NC-ND 4.0   |   我要订阅   |   我要打赏

@chunpu
Copy link

chunpu commented Mar 21, 2015

羡慕啊!github 用在工作流程上

@camnpr
Copy link

camnpr commented Mar 31, 2015

玩转GitHub 哈哈

@illuSioN4ng
Copy link

学习了,棒棒哒

@catxxcc
Copy link

catxxcc commented Aug 25, 2015

very good!!!

@rccoder
Copy link

rccoder commented Aug 25, 2015

吐个槽,贵厂对GitHub的使用有这么不熟练么。。。

除此之外,我收不到邮件的更多情况是Gmail的原因,注册的时候Gmail还没有什么问题,现在不翻墙的话是不行的,一直用QQ邮箱代收,然后微信接收,现在接收的不是特别全,就有一定的问题了。不过还好,我一直会看站内信

@cssmagic
Copy link
Owner Author

@rccoder
谢谢吐槽。不过,不是每个人一生下来就是对所有工具熟练的,总会有一个学习和摸索的过程。如果有教程,这个学习的过程会快一些。于是,我写了教程。

另外,文中的一些调侃桥段只是写作手法,就不要当真了吧? 😂

@icepy
Copy link

icepy commented Aug 26, 2015

堪称Github Notification实践指南

@zhiqiang21
Copy link

学习啦,感谢!

@383771059
Copy link

好贴必回!

@clevergump
Copy link

@yimingtang
Copy link

很不错,已转给新来的同事

@AustinXT
Copy link

多谢了,之前被GitHub的抄送狂轰滥炸,邮箱杯盘狼藉。

@zhoujinl
Copy link

好像还不错,先学习了

@hongdou0216
Copy link

发issues怎么添加图片?

@zhiqiang21
Copy link

zhiqiang21 commented Aug 8, 2016

直接拖动图片到文字编辑框里面就可以了

@hongdou0216
Copy link

经常失败

@zhiqiang21
Copy link

zhiqiang21 commented Aug 8, 2016

国内的github服务不稳定,挂代理咳😁

@ysm-github
Copy link

好帖,贵厂是百度吗

@cssmagic
Copy link
Owner Author

@ysm-github
是百姓网哦。

@MarkStray
Copy link

厉害,收藏了

@zhiqiang21
Copy link

为啥没有watch,这边又回到的时候还会收到邮件通知呀

@cssmagic
Copy link
Owner Author

为啥没有watch,这边又回到的时候还会收到邮件通知呀

参与讨论后会自动 watch 这个 issue。退订方法参见本文的 “取消关注某个讨论” 段落。

@johnsun007
Copy link

给力,对小白很有帮助

@staciac
Copy link

staciac commented Oct 29, 2016

很赞,不知道如何处理的时候,先看下有经验的人的处理方法。少走弯路。多谢。

@loveflywei
Copy link

感谢提供说明

@Yodeser
Copy link

Yodeser commented Nov 24, 2016

学习了

@sandianyiyuan
Copy link

已经订阅过的内容现在取消订阅了,在首页里还是会显示,怎么彻底删除呢?

@cssmagic
Copy link
Owner Author

@sandianyiyuan
粗略分析一下,似乎 GitHub 首页信息流包含了三种来源(你自己的项目、你 watch 的项目、你 follow 的人)的动态。所以你需要弄清楚某一条 “在首页里还是会显示” 的动态到底来自哪里,然后再针对性地 unwatch 或 unfollow。

@SawaraNazo
Copy link

您好,您这篇文章写得很好,受益良多。
但是我有个问题,就是我希望得到某项目的new release通知,但是又不想watch它(watch之后所有相关的内容都会提醒我,这一点太麻烦了。
这个可以做到吗?

@cssmagic
Copy link
Owner Author

cssmagic commented Dec 8, 2017

@SawaraNazo
先 watch,然后在邮箱里设置过滤器。

@SawaraNazo
Copy link

@cssmagic
明白了,谢谢您。

@SylviaCheung
Copy link

3Q~
终于找到教程了

@houdq
Copy link

houdq commented Dec 18, 2017

一开始也把fork当做favorite了

@chengkj99
Copy link

666

@jaythc
Copy link

jaythc commented Feb 12, 2018

好文章,受益匪浅.

@gttiankai
Copy link

好文章.谢谢

@GH01
Copy link

GH01 commented Aug 14, 2018

但是奇怪,难道GitHub有时会漏发邮件?
已遇不止一次,虽已勾选 Include your own updates 。
自己的,漏了自己知道,
可要是别人的漏了,遇上楼主这种爱绝交的,岂不冤枉…… 😓
不像是邮箱的问题,[垃圾]里没有。

各位有没这种情况?
@rccoder commented on Aug 25, 2015 : 现在接收的不是特别全
@hongdou0216 commented on Aug 8, 2016 : 经常失败

@windbell3k
Copy link

好文章,学习了,受益匪浅.

@Eric-Zhang1990
Copy link

学习了#99

@wowpH
Copy link

wowpH commented May 18, 2019

必须赞

@MikaQiao
Copy link

学习了

@ylsislove
Copy link

好文章~

@zhc0842
Copy link

zhc0842 commented Apr 1, 2020

学习了

@aiueo-0
Copy link

aiueo-0 commented Jun 1, 2020

学习了, 被轰炸到放弃了一个邮箱...

@even4Java
Copy link

good

@AnClark
Copy link

AnClark commented Aug 20, 2020

关于GitHub的艾特功能,分享一下我的体会:

普通用户想反馈软件问题,可能会选择艾特原作者、dalao等前辈,这在社交媒体上也许是常态。但在GitHub里,艾特他人功能一定得慎用,尤其是commit里。否则会被一些暴躁collaborator直接怒怼,因为你可能会无端打扰到他们,他们不喜欢动不动就来垃圾邮件。对,默认情况下被艾特是会收到邮件的。
比如说项目B fork自项目A,那么项目A的提交者也会出现在项目B的部分commit中,但他们却跟这个项目没关系。这时如果为了反馈问题艾特他们,脾气好的会告诉你他不负责这个项目,让你请勿打扰;而脾气不好的就直接怼你“STOP PINNING ANYONE!”,一点礼貌都不跟你讲。后者往往会很强势。
我个人是不主张开发者无礼回怼的,这会引起非常不愉快的沟通,还会让我八卦对方到底经历了啥坑爹事儿。当然作品归作品,本人归本人,遵循个案原则,理性看待、将心比心才是王道。

@huangjc0715
Copy link

小白对于这里面很多专业词都看不懂,这篇文章很难读

@cjh-1203
Copy link

cjh-1203 commented Nov 5, 2020

感谢分享!终于不用去收无关的issue邮件了……👍

@ibertli
Copy link

ibertli commented Feb 17, 2021

very good, thank you

@KylinLee
Copy link

KylinLee commented Mar 1, 2021

每个issue有comment更新都会收到通知,要怎么取消,我只想在新增issue的时候才被通知。

@wan-yujun
Copy link

作为一个新手小白,很有用,thanks

@ghost
Copy link

ghost commented Jul 2, 2021

我的Subscriptions列表,选了Reson: Mention以后显示Subscriptions 1,但是下面是空的,没法找到那个东西unsubscribe

@xidian2wuzhaoji
Copy link

学习了

@staciac
Copy link

staciac commented Apr 8, 2022 via email

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
Projects
None yet
Development

No branches or pull requests