趣谈Bug -500英里邮件问题

继续和大家分享历史上的经典Bug。

这个Bug也比较离奇:

故事发生在2002年,这天,麻省理工(MIT)统计系的主任找到校园邮件系统的负责人Trey Harris,跟他抱怨一个比较离奇的问题:"咱们的邮件发不到500英里以外的地方,其实,是520英里更准确点"。

管理员内心:&(&......... &))(&^%

但不管怎么不相信,但还是亲自用自己的邮箱进行了测试。结果居然是真的!确实如报告一样,邮件只能发送到520英里以内的地方,范围之外的邮件一律发送失败。

经过一番排查,终于搞清了原委。

原来不久之前,邮件服务器的操作系统刚刚进行了版本更新(当年还是SunOS),而当时的操作系统发行版,通常会附带一些附件软件,但这些软件的版本往往比较旧(好比更新Linux,自带的Python版本一般都不是最新的)。因此更新完系统后,他们使用的邮件软件 SendMail 版本被降级了(SendMail 8 -> SendMail 5

而更新系统,还同时保留了SendMail的配置文件sendmail.cfg, 因此就出现了下面的情况:SendMail 5 会解析SendMail 8 的配置文件。

因为 sendmail.cfg中存在一个 SendMail 5不支持的配置项 timeout to connect to the remote SMTP server,即连接远端SMTP Server的超时时间, 对于这个不支持的配置,在 SendMail 5 中被直接忽略,并按默认值0处理。而后来经过试验,0秒的timeout会导致Sendmail在3毫秒后中断连接。

所以为什么是 500 英里呢?

当年,MIT的校园网络中还没有那么多路由,因此网络延时很少,也就是连接一个远端主机的时间,大概接近光速。于是,3毫秒就意味着:

0.003 * 3 * 10 ^ 8 * 0.001 * 0.621 = 558.9

考虑到很少的网络延迟,因此就出现了这个 500 英里的问题。

相关推荐
DB!!!8 分钟前
【bug】系统CA证书毁坏导致找不到有效的 OpenPGP 数据
bug
中冕—霍格沃兹软件开发测试13 小时前
测试用例库建设与管理方案
数据库·人工智能·科技·开源·测试用例·bug
lvchaoq20 小时前
解决组件不能远程搜索的问题
前端·bug
Vanranrr1 天前
一个由非虚函数导致的隐藏Bug:窗口显示异常问题排查与解决
开发语言·bug
AllinGold1 天前
vscode等IDE使用ssh远程连接云服务器ECS,连接不上的通常问题
bug
测试人社区—84162 天前
Postman API测试指南
人工智能·git·测试工具·自动化·bug·postman
万粉变现经纪人2 天前
如何解决 pip install 网络报错 403 Forbidden(访问被阻止)问题
数据库·python·pycharm·beautifulsoup·bug·pandas·pip
测试人社区—84162 天前
Appium移动自动化测试:从入门到精通实战
人工智能·安全·appium·自动化·bug·postman
Wokoo72 天前
软件测试分类与BUG管理
功能测试·单元测试·bug·集成测试·压力测试·ab测试
ChrisitineTX2 天前
RocketMQ 消费端卡死?深扒 Rebalance(重平衡)机制在“网络分区”下的致命 Bug
网络·bug·rocketmq