当前位置: 首页 > news >正文

趣谈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 英里的问题。

http://www.dtcms.com/a/414115.html

相关文章:

  • 洛阳天艺网络做网站怎么样自适应型网站建设方案
  • 沧州市网站优化排名网站开发的过程中遇到的难题
  • 【JDK 11 安装包免费下载 免登录Oracle 】jdk11与jdk8有什么区别?
  • Oracle 数据库管理员认证难考吗?怎么报考?
  • 计算机网络经典问题透视:物理层调制技术全解析 (ASK, FSK, PSK, QAM, OFDM)
  • Python语法提效指南:推导式与循环的性能对比与最佳实践
  • AWS SageMaker SDK 完整教程:从零开始云端训练你的模型
  • Java Servlet(二)--- HttpServlet,HttpServletRequest,HttpServletResponse
  • Linux-01_2(vi / vim 编辑器)
  • 网站建设的难点在哪里网站设计哪家便宜
  • 网站建设外包项目初做淘宝客选哪个网站
  • 负载均衡式的在线OJ项目编写(三)
  • jQuery为前端开发提供了许多强大而简便的功能
  • Kali 手记:2025年更新版
  • 2025年的 Crate 安全:工具与技术 (RustConf China 2025系列精选)
  • MATLAB学习文档(二十二)
  • 环球资源网网站特色国内做外贸网站的有哪些资料
  • 基于Hadoop的美妆产品网络评价的数据采集与分析-django+spider
  • MySQL InnoDB表压缩:性能优化全解析
  • AWS Toolkit - 注册 AWS Builder ID 账号
  • 零基础学AI大模型之LangChain
  • 深入浅出 XSS — 从原理到实战与防护
  • 长尾关键词挖掘网站python 网站开发入门
  • 【数组按位置对调】2022-11-20
  • UE5(8):认识 UE 的菜单栏,全部保存 CTRL+SHIFT+S,工具栏以及视口工具栏,移动相机在项目编辑器里,选择光照显示等,还有空气墙的隐身角色,加载新手包,沙发的碰撞属性的生成-编辑AM,
  • 成都分类信息网站开发jsp网站开发实例教学
  • SpringBoot 的启动原理
  • 墙绘产品展示交易平台|基于SpringBoot和Vue的墙绘产品展示交易平台(源码+数据库+文档)
  • 开源项目Sherpa-onnx:全平台离线语音识别的轻量级高性能引擎
  • 【大数据技术】ClickHouse配置详细解读