您当前的位置:首页 > 电脑百科 > 程序开发 > 编程百科

一行代码,为何造成 6000 万美元的损失?

时间:2023-11-15 12:05:52  来源:CSDN  作者:

整理 | 郑丽媛

出品 | CSDN(ID:CSDNnews)

你能想象吗:仅因一行代码,导致一家公司损失了至少 6000 万美元?听起来可能颇为匪夷所思,但这件事真实发生在了美国电信公司 AT&T 的身上。

自 1877 年成立以来,AT&T 从未发生过重大网络事故,为此公司也大力宣传自家系统的可靠性和安全性。在这种背景下,到了上世纪 90 年代,当时 AT&T 已经占据了美国 70% 的长途通讯量、电话呼叫转发超过 11.5 亿次,是当之无愧的美国最大电信通讯公司。

然而 1990 年 1 月 15 日 AT&T 发生的这场重大事故,颠覆了它在人们心中“安全可靠”的固有印象:1990 年 1 月 15 日,AT&T 出现大面积系统故障,网络持续瘫痪了 9 个小时,期间 6 万多人的电话完全无法接通、7500 万个电话被错过、呼叫连接故障率高达 50%、500 个航班延误……AT&T 因此损失了超过 6000 万美元。

那么这个价值 6000 万美元的“罪魁祸首”,到底是哪行代码呢?

应管理层要求,代码没有经过测试

在发生这场重大事故之前,AT&T 维持了一百多年的稳定可靠,主要利用当时先进的电子交换机和信号系统处理了大部分电话,其系统通常能在几秒钟内完成呼叫路由选择。

按理说,既然如此 AT&T 的整个网络应该被设计得非常完善,即便单个交换机出现故障也不该引起系统崩溃,还能自主隔离有缺陷的交换机——一直以来,AT&T 也确实如此。但在事故发生前,AT&T 为了改善长途通话质量,将软件进行了更新,而这个更新中存在一个致命 Bug。

事故当天,这个 Bug 从纽约的一台交换机开始,导致整个网络都出现了故障,共影响了 114 台交换机。最初,这台纽约交换机的自检程序发现它已接近负载极限,要执行复位并发出信号时,这个 Bug 引起了多米诺骨牌效应,导致大范围的网络中断。

你或许会问:那软件更新前 AT&T 没有测试吗?这就是有趣的地方了:由于代码改动较小,因此按照管理层的要求,那次更新并没有经过测试。

美国近一半主要通信线路瘫痪

追根溯源,这个损失 6000 万美元的事故原因,是在网络交换机上实施的软件更新中出现了编码错误。具体来说,这个 Bug 是由一个非常简单的语法错误引起的:该 Bug 发生在 C 语言程序中,其中嵌套条件语句中的关键字 break 用法错误,由此导致了数据覆盖和系统重置。

伪代码如下:

一行代码,为何造成 6000 万美元的损失?

以上代码存在的问题:

  • 如果环形缓冲区不为空,则跳过第 7 行的“if”语句,转而执行第 10 行的 break 语句。
  • 然而,为了使程序正常运行,本应执行第 11 行。
  • 当 break 语句被执行,而不是处理传入消息并为可选参数设置指针时,数据(本应保留的指针)就会被覆盖。
  • 纠错软件识别出数据被覆盖,便启动关闭开关进行重置。由于整个网络中的所有交换机都使用了这个有缺陷的软件,导致了连锁复位反应,最终使整个网络系统瘫痪,让问题变得更加复杂。

也就是说,尽管此前 AT&T 进行了严格测试,网络设计也非常灵活,但这次一行代码的疏忽还是导致了美国几乎一半的主要通信线路瘫痪。

网友:我敢打赌,没有管理层因此被解雇

在经历了 9 个小时的持续瘫痪后,AT&T 当时解决问题的方法是:让工程师把交换机重装回以前的软件版本。而实际上,事后 AT&T 超过 100 人的技术团队参与了此次事故分析,共花了两周时间进行严格的代码阅读、测试和复制,才最终弄清了 Bug 所在。

AT&T 的这次事故发生在 33 年前,可就算后来的公司拥有了更好工作流程,也难免会有漏网的 Bug,例如 2016 年 YouTube 也发生了首次全球故障。

作为这些发生重大故障的公司而言,其损失无疑是巨大的,因此每次也都会给他们带去相应的教训。但对大多数公司来说,很多故障归根结底都是人为错误和流程漏洞造成的。

对于一行代码导致损失 6000 万美元这件事,诸多网友也发表了自己的看法:

  • “这是人们在软件开发中最具挑战性的问题之一:事件原因和我们称之为‘触发器’之间存在巨大差异。导致问题的不是 1 行代码,而是这种环境使得 1 行代码就能够‘触发’问题。”
  • “问题在于一行代码 + 糟糕的管理,因为还有高层迫使工程师跳过测试。而且我敢打赌,没有管理层因此被解雇。”
  • “最可悲的地方是:管理层要求绕过测试,因为代码变化太小了。”

那么你对于这个导致了 6000 万美元损失的事故,又有什么看法吗?

参考链接:

https://shimo.im/docs/9030J9eOGnc0n7kw

https://www.reddit.com/r/programming/comments/17uemqw/one_line_of_code_caused_att_to_lose_60_million/



Tags:代码   点击:()  评论:()
声明:本站部分内容及图片来自互联网,转载是出于传递更多信息之目的,内容观点仅代表作者本人,不构成投资建议。投资者据此操作,风险自担。如有任何标注错误或版权侵犯请与我们联系,我们将及时更正、删除。
▌相关推荐
跳转链接代码怎么写?
在网页开发中,跳转链接是一项常见的功能。然而,对于非技术人员来说,编写跳转链接代码可能会显得有些困难。不用担心!我们可以借助外链平台来简化操作,即使没有编程经验,也能轻松实...【详细内容】
2024-03-27  Search: 代码  点击:(12)  评论:(0)  加入收藏
为何大语言模型不会取代码农?
译者 | 布加迪审校 | 重楼生成式人工智能(GenAI)会取代人类程序员吗?恐怕不会。不过,使用GenAI的人类可能会取代程序员。但是如今有这么多的大语言模型(LLM),实际效果不一而足。如...【详细内容】
2024-03-21  Search: 代码  点击:(19)  评论:(0)  加入收藏
如何从头开始编写LoRA代码,这有一份教程
选自 lightning.ai作者:Sebastian Raschka机器之心编译编辑:陈萍作者表示:在各种有效的 LLM 微调方法中,LoRA 仍然是他的首选。LoRA(Low-Rank Adaptation)作为一种用于微调 LLM(大...【详细内容】
2024-03-21  Search: 代码  点击:(12)  评论:(0)  加入收藏
如何编写高性能的Java代码
作者 | 波哥审校 | 重楼在当今软件开发领域,编写高性能的Java代码是至关重要的。Java作为一种流行的编程语言,拥有强大的生态系统和丰富的工具链,但是要写出性能优异的Java代码...【详细内容】
2024-03-20  Search: 代码  点击:(19)  评论:(0)  加入收藏
微软AI程序员登场,10倍AI工程师真来了?996自主生成代码,性能超GPT-4 30%
新智元报道编辑:桃子 润【新智元导读】全球首个AI程序员Devin诞生之后,让码农纷纷恐慌。没想到,微软同时也整出了一个AI程序员——AutoDev,能够自主生成、执行代码等...【详细内容】
2024-03-18  Search: 代码  点击:(15)  评论:(0)  加入收藏
对JavaScript代码压缩有什么好处?
对JavaScript代码进行压缩主要带来以下好处: 减小文件大小:通过移除代码中的空白符、换行符、注释,以及缩短变量名等方式,可以显著减小JavaScript文件的大小。这有助于减少网页...【详细内容】
2024-03-13  Search: 代码  点击:(2)  评论:(0)  加入收藏
如何进行Python代码的代码重构和优化?
Python是一种高级编程语言,它具有简洁、易于理解和易于维护的特点。然而,代码重构和优化对于保持代码质量和性能至关重要。什么是代码重构?代码重构是指在不改变代码外部行为的...【详细内容】
2024-02-22  Search: 代码  点击:(32)  评论:(0)  加入收藏
18个JavaScript技巧:编写简洁高效的代码
本文翻译自 18 JavaScript Tips : You Should Know for Clean and Efficient Code,作者:Shefali, 略有删改。在这篇文章中,我将分享18个JavaScript技巧,以及一些你应该知道的示例...【详细内容】
2024-01-30  Search: 代码  点击:(65)  评论:(0)  加入收藏
C++代码优化攻略
今天我们将深入探讨C++性能优化的世界。在当今软件开发的浪潮中,高性能的代码是必不可少的。无论是开发桌面应用、移动应用,还是嵌入式系统,性能都是关键。1. 选择合适的数据结...【详细内容】
2024-01-26  Search: 代码  点击:(113)  评论:(0)  加入收藏
手把手教你为开源项目贡献代码
背景前段时间无意间看到一篇公众号 招贤令:一起来搞一个新开源项目,作者介绍他想要做一个开源项目:cprobe 用于整合目前市面上散落在各地的 Exporter,统一进行管理。比如我们常...【详细内容】
2024-01-26  Search: 代码  点击:(70)  评论:(0)  加入收藏
▌简易百科推荐
即将过时的 5 种软件开发技能!
作者 | Eran Yahav编译 | 言征出品 | 51CTO技术栈(微信号:blog51cto) 时至今日,AI编码工具已经进化到足够强大了吗?这未必好回答,但从2023 年 Stack Overflow 上的调查数据来看,44%...【详细内容】
2024-04-03    51CTO  Tags:软件开发   点击:(5)  评论:(0)  加入收藏
跳转链接代码怎么写?
在网页开发中,跳转链接是一项常见的功能。然而,对于非技术人员来说,编写跳转链接代码可能会显得有些困难。不用担心!我们可以借助外链平台来简化操作,即使没有编程经验,也能轻松实...【详细内容】
2024-03-27  蓝色天纪    Tags:跳转链接   点击:(12)  评论:(0)  加入收藏
中台亡了,问题到底出在哪里?
曾几何时,中台一度被当做“变革灵药”,嫁接在“前台作战单元”和“后台资源部门”之间,实现企业各业务线的“打通”和全域业务能力集成,提高开发和服务效率。但在中台如火如荼之...【详细内容】
2024-03-27  dbaplus社群    Tags:中台   点击:(8)  评论:(0)  加入收藏
员工写了个比删库更可怕的Bug!
想必大家都听说过删库跑路吧,我之前一直把它当一个段子来看。可万万没想到,就在昨天,我们公司的某位员工,竟然写了一个比删库更可怕的 Bug!给大家分享一下(不是公开处刑),希望朋友们...【详细内容】
2024-03-26  dbaplus社群    Tags:Bug   点击:(5)  评论:(0)  加入收藏
我们一起聊聊什么是正向代理和反向代理
从字面意思上看,代理就是代替处理的意思,一个对象有能力代替另一个对象处理某一件事。代理,这个词在我们的日常生活中也不陌生,比如在购物、旅游等场景中,我们经常会委托别人代替...【详细内容】
2024-03-26  萤火架构  微信公众号  Tags:正向代理   点击:(10)  评论:(0)  加入收藏
看一遍就理解:IO模型详解
前言大家好,我是程序员田螺。今天我们一起来学习IO模型。在本文开始前呢,先问问大家几个问题哈~什么是IO呢?什么是阻塞非阻塞IO?什么是同步异步IO?什么是IO多路复用?select/epoll...【详细内容】
2024-03-26  捡田螺的小男孩  微信公众号  Tags:IO模型   点击:(8)  评论:(0)  加入收藏
为什么都说 HashMap 是线程不安全的?
做Java开发的人,应该都用过 HashMap 这种集合。今天就和大家来聊聊,为什么 HashMap 是线程不安全的。1.HashMap 数据结构简单来说,HashMap 基于哈希表实现。它使用键的哈希码来...【详细内容】
2024-03-22  Java技术指北  微信公众号  Tags:HashMap   点击:(11)  评论:(0)  加入收藏
如何从头开始编写LoRA代码,这有一份教程
选自 lightning.ai作者:Sebastian Raschka机器之心编译编辑:陈萍作者表示:在各种有效的 LLM 微调方法中,LoRA 仍然是他的首选。LoRA(Low-Rank Adaptation)作为一种用于微调 LLM(大...【详细内容】
2024-03-21  机器之心Pro    Tags:LoRA   点击:(12)  评论:(0)  加入收藏
这样搭建日志中心,传统的ELK就扔了吧!
最近客户有个新需求,就是想查看网站的访问情况。由于网站没有做google的统计和百度的统计,所以访问情况,只能通过日志查看,通过脚本的形式给客户导出也不太实际,给客户写个简单的...【详细内容】
2024-03-20  dbaplus社群    Tags:日志   点击:(4)  评论:(0)  加入收藏
Kubernetes 究竟有没有 LTS?
从一个有趣的问题引出很多人都在关注的 Kubernetes LTS 的问题。有趣的问题2019 年,一个名为 apiserver LoopbackClient Server cert expired after 1 year[1] 的 issue 中提...【详细内容】
2024-03-15  云原生散修  微信公众号  Tags:Kubernetes   点击:(5)  评论:(0)  加入收藏
站内最新
站内热门
站内头条