Програмистът, който изтри 11 реда и „счупи“ интернет

ное. 10, 2023 | Истории

Програмистът, който изтри 11 реда и „счупи“ интернет

10 ноември 2023 | Истории

Можете да чуете тази Дигитална история в  Storytel

23 март 2016 г. можеше да бъде апокалиптичен ден в историята на дигиталния свят, който надали ще се повтори. Netflix, Facebook и Spotify са само част от безбройните сайтове, които изведнъж се оказва, че… няма как да бъдат поддържани и обновени.

Защо ли? 28-годишният програмист Азер Кочулу просто е изтрил 11 фатални реда компютърен код.

Но как е възможно един непознат програмист да блокира сайтовете на световните гиганти? Защо в странния днешен онлайн свят неочаквано се оказва, че огромни, мултимилиардни проекти се крепят на раменете на доброволния труд на ентусиасти? Какво ли е накарало Азер да се ядоса толкова, че да отприщи в най-страховития му вид ефекта на пеперудата?

Понякога най-малките и уж безобидни редове код обръщат програмата…

 

Азер Кочулу

 

Бекъп дупка не прави

Прелюбопитна е дигиталната история на JavaScript – езикът за програмиране е създаден само за 11 дни и… понякога му личи, въпреки че оттогава извървя дълъг път. Превърна се в жизнената сила, проправила пътеките на днешния интернет, какъвто го познаваме. Докато преди сваляхме програми за какво ли не, инсталирахме ги чрез операционната система, днес почти всичко се случва в браузъра.

Промяната дойде толкова бързо и неусетно, колкото не можехме да предположим… А също толкова бързо всичко може и да се срути, както личи от историята на днешния ни герой.

Възходът на уеб приложенията съвпадна с едно друго важно явление в софтуерния свят – масовото навлизане на софтуера с отворен код. Първопроходник беше създателят на Linux и Git Линус Торвалдс, а през последните десетилетия върху програмите, които са открити и се споделят свободно, се крепи огромна част от днешната софтуерна индустрия.

Особено що се отнася до света на JavaScript. Най-популярната платформа за това се нарича NPM и притежава буквално милиони проекти, които изпадналият в нужда програмист може да използва. Всеки е добре дошъл да остави своите парченца код, които, по един или друг начин, да бъдат използвани от всички останали.

 

Азер Кочулу

 

Бързата работа, срам за програмиста

Тази система работи по повече от впечатляващ начин. Постоянно се появяват нови библиотеки, най-успешните биват сваляни и използвани от разработчиците милиони пъти на ден.

Нещо повече, постепенно този тип проекти се превръщат в огромни вавилонски кули, защото библиотеките със софтуер се крепят една на друга, всяка следваща използва малко парченце код от предишните…

Което в един момент, въпреки цялото удобство, може да се превърне в проблем. Точно както в историята на Азер Кочулу.

Мнозина иронизират факта, че за да създадеш нов проект чрез модулите, които ти се налага да използваш, трупаш гигабайти в папката node_modules, които в един момент тежат повече от Вселената… но това, в крайна сметка, не засяга крайните потребители и определено е по-малкият проблем.

 

Казана дума, хвърлен бъг

По-големият риск със сигурност е сигурността, която става все по-трудна за проследяване с използването на море от код. Именно напомняне в тази посока е случката с мигранта от южната ни съседка.

От малък Азер Кочулу е запален по идеите за софтуера с отворен код. Заедно с основната си работа, има и своеобразно хоби – да създава библиотеки, които да качва на платформата NPM, давайки на останалите програмисти.

Някои от проектите му се радват на сериозен успех, а и той изпитва удовлетворение. До прословутия 23 март 2016 г. е публикувал цели 273, някои от които имат стотици хиляди използвания за седмица. И точно тогава той получава имейл, който го разгневява…

Пише му Боб Стратън, патентен специалист от фирма на име kik. Азер е създал малка софтуерна библиотека със същото название и за да не стават грешки, адвокатите го призовават да смени името на своя проект.

 

Азер Кочулу

 

Шушу-мушу сайта разваля

Знаете, понякога нещата в онлайн комуникацията ескалират бързо, нали? Е, няколко имейла по-късно Азер започва да хвърля огън и жупел с речник, на който би завидял и герой на сръбски филм. Категорично отказва да смени името на библиотеката, дори и когато са му предложени $30 000. Казва, че идеята му е друга и че на полето на отворения код не бива да са водещи търговските интереси.

Прочел интересни неща за близките си роднини, патентният адвокат разбира, че по този начин няма да се получи. Затова решава да се свърже направо с организацията, която може да му помогне.

Макар че NPM е напълно некомерсиална платформа, тя си има компания собственик, която се грижи за правилата и инфраструктурата. Именно на нея пише патентният адвокат на kik, явно успява да впечатли получателите и този път вместо цветист отговор, среща съгласие.

Азер получава нов имейл, този път от NPM, в който го информират, че библиотеката му е отстранена заради проблеми с авторските права. Тъй ли? Възмутен, че платформата се поддава на шантажа и погазва собствените си правила, той с едно движение изтрива всичките си 273 библиотеки.

 

Азер Кочулу

 

Капка по капка – бъг

Така стигаме до следобеда, когато хиляди програмисти от цял свят получават една и съща грешка – някаква библиотека, за която почти никой от тях не е чувал, не може да бъде заредена. Това означава, че те са блокирани в работата си, а някои, които са имали лошия късмет тъкмо тогава да изпращат новия си код към потребителите, се озовават с напълно неработещи сайтове. И всичко това, само заради един от проектите на Азер.

Но как никой не е чувал за липсващата семпла библиотека, след като за последния месец преди това тя е била свалена от цели 2 550 569 програмисти?

Как така всички са използвали кода му, без дори да са чували името му? Как компании като Netflix, Facebook и Spotify са се доверили в крайна сметка на външен софтуер, който би могъл дори да нанася неподозирани вреди?

Отговорът отново се крие в пирамидата на днешния уеб софтуер. Всеки разчита на външни библиотеки, които пък разчитат на предишните.. в огромна кавалкада от взаимни зависимости.

Азер просто е бутнал първото парченце домино… „Това просто счупи интернет“, гласи коментарът, събрал най-много радостни отзиви по темата в платформата за програмисти GitHub.

 

Три пъти мери, един път коди

Е, същото се е случило и с работата на Азер. Оказва се, че огромен брой от най-използваните приложения са използвали точно най-малкия от всичките му 273 проекта – наричан Left-pad и състоящ се от… 11 реда код:

Азер Кочулу

 

Ако дори сте се докоснали до програмирането, бързо ще прецените, че става дума за елементарна функция, която буквално би могла да бъде написана за минути от всеки, познаващ на базово ниво JavaScript. И, все пак, вместо да си я направят сами, са решили да я използват наготово някои от най-популярните библиотеки, на които се крепи мрежата.

Най-много проблеми идват от това, че Left-pad по това време е част и от Babel – много важна и разпространена библиотека, която се използва, за да „превежда“ кода така, че да бъде разчетен и от по-стари браузъри. Babel се използва, на практика, навсякъде. Списъкът включва сайтовете на Facebook, Netflix, PayPal, Yahoo, Spotify, Reddit, Slack, LinkedIn.

И така… „онлайн апокалипсисът“ бързо е избегнат. Първото работещо решение се появява 42 минути, след като проблемът е споменат за първи път. Няма и два часа по-късно в NPM вече е качен нов пакет със същото име, което веднага решава проблема.

 

Азер Кочулу

 

Не е луд който яде бъговете…

После идва време за анализа след мача. И Азер, и kik, и NPM влизат в обяснителен режим, за да разкажат на общността какво се е случило, картината бързо се избистря.

Азер казва, че се е ядосал, защото „тази ситуация ме накара да осъзная, че NPM е нечия частна земя, където корпорацията е по-силна от хората. А аз създавам отворен код, защото „силата трябва да е в хората“. Той моли за прошка всички, които са пострадали, но казва, че това е тъкмо нужната възможност да се говори повече за това как решенията в общността трябва да се вземат именно от нея, а не от централизирани институции.

Остават обаче по-важните въпроси. Ако ставаше дума за много по-комплексно решение, то буквално би могло да блокира работата на милиони програмисти по цял свят и би застрашило почти всички най-големи сайтове.

Още ли ни звучи толкова примамлива идеята за софтуера с отворен код?

 

Азер Кочулу

 

Програмата се кове, докато е гореща

За щастие, оказва се, че тя е още по-магнетична и работеща от всякога. И именно подобни случаи го показват.

Защото общността, която включва огромен брой специалисти, може да реагира бързо и да реши подобен проблем. Днес Азер е с десетилетие по-опитен, натрупал е сериозни успехи като програмист, вече е с по-семпла прическа, може би дори е забравил, че в един момент за малко не „счупи интернет“. Но опитът от този случай даде идеята за по-строги правила кой и как може да изтрие дадена библиотека с код. Днес това би отнело много повече време, всички, които я използват, биха били предупредени навреме, за да вземат мерки.

Ето че когато комерсиалният елемент е елиминиран, понякога могат да се случват чудеса.

Софтуерът с отворен код продължава да властва, както никога. Защото е един от онези не чак толкова много примери, които ни връщат към основната идея на интернет. Възможността да сме обединени, равни, да си помагаме… Пък дано се научим как да го правим и в социалните мрежи.

Дигитални истории

Дигитални истории е и ще си остане изцяло некомерсиално начинание, на което посвещавам доста време и усилия. За създаването на сайта обаче са нужни определени разходи. Ако имате възможност и желание да подпомогнете сайта, вече можете да го направите. Разбира се, все така важна подкрепа си остава всяка добра дума, всяко споделяне на темите.

<a href="https://karamanev.me/author/georgik" target="_self">Георги Караманев</a>

Георги Караманев

Програмист, журналист и писател. Още за мен – тук.
Дигитални истории

Най-нови публикации:

Как да надникнем в „мислите“ на изкуствения интелект?

Как да надникнем в „мислите“ на изкуствения интелект?

Озовахме се във време, в което чатботът не е просто помощник, а и „психотерапевт“. Преди още да го познаваме достатъчно добре, преди да сме заложили етичните рамки. Вече виждаме първите...

повече информация
5 г. Дигитални истории! Ще решите ли куиза с награди?

5 г. Дигитални истории! Ще решите ли куиза с награди?

Точно преди 5 години излезе „Робот с мартеничка“, първият материал на сайта Дигитални истории! Оттогава всяка седмица се появяват по един или два дълги текста, рисуващи историята на самите Дигитални...

повече информация
Как ИИ нарисува 10 класически стиха? 2022 срещу 2026 г.

Как ИИ нарисува 10 класически стиха? 2022 срещу 2026 г.

Вярвахте ли преди няколко години, че изкуственият интелект ще създава толкова изпипани изображения? От свръхреалистични „фотографии“ до персонализирани карикатури в поредната модна тема, която...

повече информация
Денят, в който програмистите спряха да пишат код

Денят, в който програмистите спряха да пишат код

Представяте ли си какво им е било на кочияшите, когато видели първите автомобили? Сигурно в началото са се чувствали в безопасност. „Кой ли ще се качи в тези странни кубчета? Вместо да се наслаждава...

повече информация
Поет + ИИ = Apollo ex Machina. Кои са победителите?

Поет + ИИ = Apollo ex Machina. Кои са победителите?

Дойде време да обявим победителите в първия у нас (и един от първите по света) конкурс за поезия, генерирана с помощта на изкуствен интелект – Apollo ex Machina. На церемония в Столична библиотека...

повече информация

Още публикации по темата:

От рубриката:

От Floor-а до Quizza. Предизвикай знанията си!

От Floor-а до Quizza. Предизвикай знанията си!

Представям ви Quizza! Сайт, който създадохме с доброволен труд. В който можете да се предизвикате, като решите някой от многобройните ни постоянни куизове на какви ли не теми. Можете да се изправите в седмично състезание срещу някои от познатите ви от он- и офлайн състезания герои! И, не на последно място, да срещнете каузи, зад които всеки от нас застава с името си!
Не се съмнявам, че снощи сте гледали първия епизод от The Floor, новото и иновативно състезание по NOVA. Ако не сте, изобщо не е късно, тепърва остават цели 12 епизода. Само по себе си е повод за празник, че игра за знание, а не за скандали, се появява в праймтайма и вярвам, че ще бъде хитът на сезона. Слуховете (и ChatGPT) мълвят, че и аз съм там.
Тук сме обаче за една малко по-различна дигитална история, която е тясно свързана с играта. Тя идва да ни покаже, че когато сме заедно, сме способни на чудеса. Че щом хора, събрани уж да се състезават и побеждават един друг, могат да си протегнат ръка за нещо по-голямо, значи и обществото ни може да го направи.
Обичате ли да провокирате и проверявате знанията си? Търсите ли смислени каузи, на които да помогнете, като сте сигурни, че помощта отива на точното място и помага за нещо важно и устойчиво?
Ако отговорът ви е „да“ дори на един от тези въпроси, то тази Дигитална история е точно за вас!

повече информация
Го. Голямата игра

Го. Голямата игра

Двама души се взират упорито в редички от подредени кръгли, плоски камъчета. Игра като игра, ще си кажете, само че не е толкова просто, никак даже. Защото това не само е една от най-старите игри, които познаваме, но и най-сложната. Дълго време я смятахме за последния бастион на човечеството, където технологиите не могат да ни изпреварят. А когато това се случи… се роди една забележителна нова дигитална история.
Тя идва да ни напомни, че технологиите са тук и за да ни предизвикват, и за да ни заплашват. Но и за да ни показват нови хоризонти да създаваме, да творим, да се развиваме като вид.

повече информация
„Без лудост няма как да ни се получи“

„Без лудост няма как да ни се получи“

В този живот не бива и не може само да получаваш. Ако не даваш – в замяна или пък напълно безвъзмездно, си живял напразно, както се пее в популярния шлагер. Дори да го знаем, струва си да си го припомняме често. Надявам се тази Дигитална история да стигне до повече хора. Вярвам, че ако поуките от нея бъдат разпознати от повече хора, то всички сме способни да си върнем разговора и да помогнем страната ни да процъфтява. Да изпълним големите мечти на главния герой и разказвача тук – децата ни да ИСКАТ да останат в България.
Тенко Николов не само е един от най-успешните технологични предприемачи на България. Той е визионер, който вярва в силата на сработения екип, споделените ценности и малко „здравословна“ лудост.

повече информация

Най-новите:

Как да надникнем в „мислите“ на изкуствения интелект?

Как да надникнем в „мислите“ на изкуствения интелект?

„Работата, професионалния живот, устремът да постигаме корпоративни успехи и позиции, това се е превърнало в масова култура на обществото ни в световен мащаб. Много хора осмислят по този начин живота си и до момента. Оттук нататък ще трябва да го променим. Ще трябва да търсим смисъл.“
Озовахме се във време, в което чатботът не е просто помощник, а и „психотерапевт“. Преди още да го познаваме достатъчно добре, преди да сме заложили етичните рамки. Вече виждаме първите предизвикателства от това, а тепърва се задават истинските проблеми.
Доника Боримечкова е психолог и психотерапевт с над 15 години опит. Този път решихме заедно да поканим на психотерапевтичен сеанс… изкуствения интелект. Защото, както казва Доника, вече много от клиентите ѝ получават съвети от него, преди да я срещнат. Така и не открихме начин и подход, с който да направим подобен експеримент, затова решихме да обсъдим темата, да поставим основите, след което да поканим всеки от вас да ни даде идеи как да продължим. Ето как започва този разговор.

повече информация
5 г. Дигитални истории! Ще решите ли куиза с награди?

5 г. Дигитални истории! Ще решите ли куиза с награди?

Точно преди 5 години излезе първият материал на сайта Дигитални истории! Моят скромен подарък е един забавен и неочакван куиз с награди. Опитайте да се справите с 30 въпроса и ще се включите в жребия за 10 книги, свързани по един или друг начин с историята на начинанието. Куизът отнема не повече от 10 минути, опитайте! А после ви чака изключително любопитната му история…

повече информация
От Floor-а до Quizza. Предизвикай знанията си!

От Floor-а до Quizza. Предизвикай знанията си!

Представям ви Quizza! Сайт, който създадохме с доброволен труд. В който можете да се предизвикате, като решите някой от многобройните ни постоянни куизове на какви ли не теми. Можете да се изправите в седмично състезание срещу някои от познатите ви от он- и офлайн състезания герои! И, не на последно място, да срещнете каузи, зад които всеки от нас застава с името си!
Не се съмнявам, че снощи сте гледали първия епизод от The Floor, новото и иновативно състезание по NOVA. Ако не сте, изобщо не е късно, тепърва остават цели 12 епизода. Само по себе си е повод за празник, че игра за знание, а не за скандали, се появява в праймтайма и вярвам, че ще бъде хитът на сезона. Слуховете (и ChatGPT) мълвят, че и аз съм там.
Тук сме обаче за една малко по-различна дигитална история, която е тясно свързана с играта. Тя идва да ни покаже, че когато сме заедно, сме способни на чудеса. Че щом хора, събрани уж да се състезават и побеждават един друг, могат да си протегнат ръка за нещо по-голямо, значи и обществото ни може да го направи.
Обичате ли да провокирате и проверявате знанията си? Търсите ли смислени каузи, на които да помогнете, като сте сигурни, че помощта отива на точното място и помага за нещо важно и устойчиво?
Ако отговорът ви е „да“ дори на един от тези въпроси, то тази Дигитална история е точно за вас!

повече информация
Как ИИ нарисува 10 класически стиха? 2022 срещу 2026 г.

Как ИИ нарисува 10 класически стиха? 2022 срещу 2026 г.

През 2022 г. призовах първия впечатляващ ИИ модел за изображения MidJourney да изпълни неочаквана задача. Подадох му 10 цитата от любими български поети, за да видим какво ще нарисува той. Резултатите бяха впечатляващи и замислящи, това се превърна в една от най-четените и обсъждани Дигитални истории.
Оттогава мина почти петилетка. Как ли ще изглеждат картинките, които днес ще нарисуват най-модерните модели по същите тези стихове? ИИ несъмнено ще покаже повече умения, но дали ще покаже и творчество, разбиране? Дали илюстрациите му ще са по-близко до изкуство? Преценете сами…
„В живота си нивга не бях се надявал
на толкова мил комплимент:
покани ме AI – най-новият AI –
дома си на чашка абсент.“

повече информация
Денят, в който програмистите спряха да пишат код

Денят, в който програмистите спряха да пишат код

Само за месец някои от безспорните авторитети от различни поколения и области на компютърния свят се обединиха зад една и съща идея. Днес не е нужно човекът да пише компютърен код. Защото изкуственият интелект вече го прави по-добре от нас.
Тази Дигитална история е важна не само за десетките милиони програмисти, но и защото е силен пример. Тя се случва в софтуерния свят, но няма причина да не се повтори във всяка друга област, където ИИ навлиза по-бавно, но също толкова неумолимо.
Май е време да „слизаме“ от клавиатурите. Но… какво да захванем тогава? Какво ще правят програмистите, когато вече не пишат код?

повече информация
Поет + ИИ = Apollo ex Machina. Кои са победителите?

Поет + ИИ = Apollo ex Machina. Кои са победителите?

Дойде време да обявим победителите в първия у нас (и един от първите по света) конкурс за поезия, генерирана с помощта на изкуствен интелект – Apollo ex Machina.
На церемония в Столична библиотека бяха обявени избраниците на журито. Там бе представена и стихосбирката с избрани творби от надпреварата, дело на издателство Scribens. След малко ще можете да прочетете стиховете на най-добрите и да прецените сами колко добри са те.

повече информация
Share This