Досадные ошибки в программном обеспечении могут стоить компаниям очень дорого и даже ставят под угрозу существование их бизнеса. Однако ошибки, которые допускает сам «бизнес», влияют на судьбу ИТ-индустрии и судьбы целых поколений.
В истории программирования не всегда все было легко и безоблачно. Ведь любому программисту, вне зависимости от опыта и технического бэкграунда, трудно уберечься от ошибок и порой даже небольшого количества плохого кода хватало, чтобы вызвать серьезную проблему.
Чаще всего зависший сайт или игра не несут угрозы здоровью и не приводят к серьезным финансовым потерям. Но есть программы, ошибки в которых могут стать причиной колоссальных убытков.
Cтадион «Хартфорд Колизей»
Ущерб: 90 млн долларов
18 января 1978 года болельщики чудом избежали смерти на стадионе «Хартфорд Колизей». Через несколько часов после того, как они покинули стадион, его стальная крыша рухнула на трибуны.
Причина случившегося – ошибка в расчетах при проектировании конструкции. Уже в то время для строительного проектирования создавался специальный софт. Программист не учел такие факторы, как мокрый снег и ветер при расчете прочности балок, поддерживающих крышу. Он исходил только из веса самой крыши. В результате одна из опор неожиданно прогнулась под воздействием снега, это вызвало цепную реакцию, которая сложила всю конструкцию вместе с другими участками крыши как костяшки домино.
15 января 1990 года ошибка в новой версии прошивки междугородних коммутаторов привела к сбою 114 коммутаторов
Из-за этого более 60 тысяч человек остались без междугородней связи на 9 часов. Согласно программе, коммутатор должен перезагрузиться, если получит соответствующий сигнал, однако этот сигнал по ошибке пересылался каждый раз при восстановлении после сбоя какого-либо коммутатора.
Все началось с падения и перезагрузки коммутатора в Нью-Йорке, который вызвал масштабную цепную реакцию, в результате которой 114 коммутаторов перезагружались непрерывно каждые 6 секунд. Сначала компания обвиняла хакеров, однако позже выяснилось, что причиной стала одна неверная строка кода, в которой реализовывалась отправка сигнала.
Бизнес-ошибки в ИТ
Часто возникают вопросы — отчего в мире информационных технологий некоторые крупнейшие сделки так и остаются нереализованными, а самые перспективные продукты не развиваются? Обычно причина в том, что их лидеры не могут предугадать будущее развитие событий.
А ведь события могли сложиться так, что не появились бы ни Microsoft, ни Apple. В альтернативном мире главным поисковым сервером был бы не Google, а Yahoo. Самым распространенным компьютером был бы Xerox, самой популярной социальной сетью – CompuServe. А музыку мы слушали бы через RealPod.
Спасение Apple
В конце 1990-х годов продажи компьютеров Apple Mac существенно снизились. Этому способствовали более дешевые конкуренты – Power Computing и Radius. Цена акций Apple упала до $5. Но неожиданно помощь пришла от Microsoft: помощь в размере $150 миллионов. Кроме того, Microsoft пообещала продолжить разработку своего пакета офисных программ для MacOS.
Из-за такого решения Microsoft лишила себя определенных перспектив. Вполне возможно, сегодня на рынке царили бы WinPhone, музыку на них мы бы качали через WinTunes. А все пользователи до сих пор с нетерпением ожидали бы выхода достойной альтернативы Windows.
Маринер-1 — самый дорогой дефис в истории
Ущерб: $18 млн ($156 млн на 2021 год)
В 1962 году NASA произвело запуск ракеты-носителя «Атлас», целью которой было доставка аппарата «Маринер-1» на Венеру для последующего изучения планеты. Однако после старта ракеты не прошло и 5 минут — на 293 секунде ее было решено ликвидировать в целях безопасности.
Причиной такого решения стала потеря связи между антенной аппарата и системой наведения, расположенной на Земле. Как только связь разорвалась, управлять ракетой-носителем принялся компьютер, но исполняемый им код содержал совсем крохотную ошибку — пропущенный дефис.
После инцидента стало известно, что на самом деле было две причины неправильной работоспособности ракеты. Первая — некачественная принимающая антенна на самой ракете «Атлас». Но такой поворот событий был предусмотрен, а потому управлять наклоном ракеты-носителя в случае потери сигнала с Земли должен был бортовой компьютер.
Так и произошло, правда исполняемый код содержал ошибку в виде пропущенного дефиса, а точнее — символа надчеркивания (макрона) в одном из уравнений. Как итог — ракета сильно накренилась и развалилась в воздухе.
Спутник Mars Climate Orbiter
Ущерб: $125 млн ($198 млн на 2021 год)
Зимой 1998 года NASA отправило на Марс спутник для изучения его климата: наблюдения за атмосферой и съемки поверхности планеты. В планы космического агентства входил сбор данных о Марсе, о том, как на планете циркулирует пыль, водяной пар и озон в слоях атмосферы, как изменяются погодные условия, как ведут себя пылевые бури.
Спустя 9 месяцев после запуска, в сентябре 1999 года Mars Climate Orbiter достиг цели и должен был остановиться на высоте около 110 км над поверхностью Марса. Однако спутник затормозил лишь на высоте 57 км, из-за чего распался в атмосфере.
Такое отклонение от курса было вызвано банальной ошибкой в ПО: программа для измерения силы использовала не ньютоны (Н), а британскую единицу фунт-сила. Это было одной из причин полного перехода NASA на метрическую систему исчисления в 2007 году.
Хакер-аспирант, или «Червь Морриса»
Ущерб: $97 млн ($215 млн на 2021 год)
На самом деле Роберт Моррис, будучи аспирантом Корнелльского университета в 1988 году, вовсе не планировал создавать зловред для вывода из строя тысяч компьютеров. Моррис хотел лишь узнать масштабность правительственной сети APRANET, для чего написал небольшую программу, которая бы искала соединение между имеющимися ПК в сети и помогла бы составить общую карту. В 1988 году аспирант воплотил задуманное, запустив собственное ПО на одном из компьютеров Массачусетского технологического института.
Ничто не предвещало беды, ведь Роберт Моррис даже и не догадывался, что его ПО далеко от идеала. Всего за сутки «червь Морриса» сумел проникнуть в 6000 компьютеров и вывел их из строя. Хотя программа была простой и безобидной, ее несовершенство стало губительно для «машин». У червя был баг: он не перезаписывался на ПК, которые до этого уже инфицировал, а наоборот — делал бесконечное количество копий самого себя, «съедая» все доступные ресурсы «железа».
Интересно, что Роберт Моррис мог с легкостью избежать наказания, так как доказать его причастность к ненамеренной кибератаке было невозможно. Однако его отец, работавший в АНБ, лично сдал сына-хакера агентам ФБР. В качестве наказания Морриса обязали выплатить солидный на то время штраф в 10 000 долларов, а также дали 3 года условного заключения.
Knight Capital — угнать $500 млн за 45 минут
Ущерб: $500 млн ($567 млн на 2021 год)
После «Черного понедельника» 1987 года, когда ПО трейдеров потеснило людей и взяло управление биржей в свои руки, финансовые игроки стали намного осторожнее обращаться с электронными помощниками. Однако это не помешало ошибке повториться в 2012 году благодаря роботу финансовой компании Knight Capital.
В начале 2010-х начала набирать обороты высокочастотная торговля — сотни и даже тысячи сделок проводились при помощи специальных программ практически без участия человека в считанные минуты. Knight Capital в те годы находилась в топе финансовых компаний, а потому решила вывести на рынок своего электронного трейдера.
Правда, не сложилось — программа содержала ошибку в коде, из-за чего за 45 минут робот провел свыше 2 млн сделок. Обычно такой объем выполнялся Knight Capital за неделю.
И ничего поделать в компании не могли — у программы не было «выключателя», а потому до срабатывания защитных механизмов Knight Capital успела потерять 500 млн долларов.
Первый Pentium комом
Ущерб: $475 млн ($839 млн на 2021 год)
Не всегда под определением «баг» значится ошибка на стороне ПО — иногда подводит и «железо». Так случилось в 1994 году с компанией Intel, которая выпустила процессор Pentium со вшитыми в него неправильными таблицами. Бракованный процессор с ошибкой в модуле операций с плавающей запятой выдавал некорректные результаты, когда производилось деление над подобными числами. Первым это заметил математик Томас Найсли, преподававший в Линчбургском Колледже во время исследования пар, триплетов и квадриплетов простых чисел.
Сначала Найсли не поверил своим глазам и попросил коллег перепроверить его расчеты, на что ему ответили — компьютер врет. Далее подтянулись СМИ, и Intel не удалось увильнуть от проблемы. Доводы компании о том, что ошибка находится аж в 9-м знаке после запятой и никак не влияет на точность измерений для подавляющего числа пользователей, общественность не успокоили.
В итоге IT-корпорации пришлось организовать отзывную компанию, которая обошлась гиганту почти в полмиллиарда долларов.
Ariane 5 — копипаста ценой в 8,5 млрд долларов
Ущерб: $8,5 млрд ($14 млрд на 2021 год)
Всего 39 секунд полета ракеты Ariane 5 обошлись Европейскому космическому агентству в 8,5 млрд долларов. Виной тому стало банальное копирование фрагмента кода для программного обеспечения Ariane 5 с предыдущей модели Ariane 4. ПО новой ракеты не сочеталось с более новым и мощным двигателем, что вызвало ошибку в работе компьютера, из-за чего ракета отклонилась от курса и начала разрушаться в воздухе, впоследствии самоуничтожившись.
Mt.Gox — страшный сон криптомайнера
Ущерб: $473 млн (36 млрд на сентябрь 2021 года)
В интернете немало историй о том, как обычные люди, некогда купившие огромное количество биткоинов за копейки, впоследствии стали непризнанными долларовыми миллионерами и даже миллиардерами. Все из-за своей халатности: то забыв пароль от криптовалютного кошелька, то выбросив на помойку HDD с ценными монетами, то купив пиццу за десятки тысяч биткоинов еще в самом начале.
В 2014 году, когда о биткоинах простой люд особо еще не знал, криптовалютные биржи уже во всю торговали электронной монетой. Одной из таких бирж была Mt.Gox, которая прославилась в 2014 году заявлением о пропаже около 7% от общего количества биткоинов — 850 000 монет.
Можно было бы списать столь солидную потерю на атаки хакеров, но на самом деле проблема заключалась в баге программного обеспечения. Скрипт обработки транзакций попросту производил списывание монет в двойном количестве. На момент инцидента долг биржи перед пользователями составлял всего 473 млн долларов, а на сегодня это внушительные 36 млрд «вечнозеленых». По этой причине процедура банкротства Mt.Gox длится по сей день.
Кошмар 21 века, или «Проблема 2000»
Ущерб: до $500 млрд (до $771 млрд на 2021 год)
До 2000-го года многие программы писались с 6-значным форматом даты: вместо комбинации ЧЧ. ММ. ГГГГ использовалась ЧЧ. ММ. ГГ. Это было логично и безопасно до наступления 2000-го года. Но с наступлением нового тысячелетия это грозило техногенным апокалипсисом: кто знает, как повели бы себя компьютеры и компьютеризированные механизмы, «увидевшие» на табло «00», что справедливо и для 1900-го года.
Баг Y2K затронул все страны с цифровой экономикой и страны СНГ в том числе, где его назвали «Проблемой 2000». Несмотря на то, что в 2000-м году цифровизация мира была крайне невысокой в сравнении с 2021 годом, на исправление ПО во всем мире потребовалось от 300 до 500 млрд долларов. До сих пор ведущие эксперты спорят, целесообразно ли было тратить столь большие средства на исправление ошибки. Так или иначе, а похожий инцидент ждет все 32-битные системы в январе 2038 года.
Открытие терминала 5 в Хитроу, 2008 год
Ущерб: более чем 16 миллионов фунтов стерлингов
Представьте себе, что вы готовитесь к долгожданному отпуску или важной деловой поездке, но обнаруживаете, что ваш рейс задержан, а багажа нигде нет.
Именно это произошло с тысячами путешественников после открытия Терминала 5 в Хитроу в марте 2008 года, и виной всему стало неработающее программное обеспечение. Проблема заключалась в новой системе обработки багажа, которая хорошо показала себя на испытаниях, но в реальной жизни потерпела неудачу. Это привело к массовым сбоям, таким как неисправность багажных лент и тысячи потерянных или отправленных не по назначению вещей.
British Airways также сообщила, что проблемы с беспроводной сетью вызвали дополнительные проблемы в аэропорту. В течение следующих 10 дней было потеряно около 42 000 чемоданов и отменено более 500 рейсов, что обошлось более чем в 16 миллионов фунтов стерлингов.
Понравилась статья? Поделитесь с друзьями!
Без активной гиперссылки на материал Sauap.org копирование запрещено!
Ссылки: https://hi-tech.mail.ru/review/60093-samye-dorogie-oshibki-programmistov-v-istorii/#anchor410984, https://habr.com/ru/articles/307394/, https://dzen.ru/a/YmGlfKfvZlIrekY6