Сегодня 28 мая 2026
18+
MWC 2018 2018 Computex IFA 2018
реклама
Новости Software

Программисты «Яндекса» чуть не лишили всех точного времени

Из-за ошибки, допущенной при разработке обновления прошивки для умных колонок «Яндекс Станция», образовалась аномально высокая загрузка на NTP-серверы (Network Time Protocol) в российском сегменте интернета — эти ресурсы используются для синхронизации времени. Компания обнаружила ошибку далеко не сразу, но перечислила меры, которые не допустят её повторения.

 Источник изображения: yandex.ru

Источник изображений: «Яндекс»

В середине октября один из добровольцев, который организовал NTP-сервер на своём домашнем маршрутизаторе, обнаружил, что канал устройства забит запросами. Обновление прошивки и перезагрузка проблемы не решили, но она исчезла после отключения NTP. Далее выяснилось, что с середины октября прекратили работу 120 из 140 российских NTP-серверов. Доброволец призвал сообщество «Хабра» в качестве временной меры запустить у отечественных провайдеров NTP-серверы на виртуальных машинах за минимальную плату — помимо рядовых пользователей, откликнулся крупный облачный оператор, который выделил сразу 30 виртуальных машин.

Виновником оказалась компания «Яндекс», которая в середине октября начала развёртывать новую прошивку для умных колонок серии «Станция». Прошивка этих устройств содержит стандартный клиент синхронизации времени. В штатном режиме она производится каждые пять часов, но в случае неудачной попытки повторная предпринимается через пять секунд. Из-за ошибки в одном из связанных с клиентом модулей все устройства с обновлённой прошивкой начали вне зависимости от результата предыдущей попытки синхронизировать время каждые пять секунд — напомним, только за первые девять месяцев 2024 года было продано, по оценкам, около 3 млн «Яндекс Станций».

На начальном этапе «Яндекс» развернул прошивку на 10 % устройств — это стандартная мера для того, чтобы выявлять ошибки на ранних стадиях. Но в стандартной схеме обнаружения ошибок на тот момент отсутствовала метрика NTP-запросов, и к 24 октября прошивка распространилась на 100 % устройств. Первые жалобы на избыточное число NTP-запросов начали поступать 10 ноября — обычно этот симптом объясняется проблемами на стороне пользователя, и из-за небольшого объёма жалоб приоритет у проблемы был невысоким. Ошибку удалось обнаружить лишь 20 ноября — к этому моменту её исправили и начали готовить новый выход прошивки.

Но тянуть время уже было нельзя, потому что к выходным 23 и 24 ноября в Сети оставалось всего четыре сервера. Поэтому в качестве временной меры «Яндекс» выпустил хотфикс — экстренное обновление, которое увеличивало период обращения с 5 до 600 секунд. Нагрузка на NTP-серверы, таким образом, снижалась в 120 раз, но если какая-то из «Яндекс Станций» после включения не могла синхронизировать время с первой попытки, то в последующие 10 минут её связанные со временем функции оказывались недоступными. Это помогло стабилизировать ситуацию — к тому моменту начали запускать NTP-серверы члены сообщества «Хабра».

Чтобы не допустить повторения инцидента в дальнейшем, в «Яндексе» решили принять несколько мер:

  • выделить несколько ресурсов компании в общий пул NTP-серверов;
  • организовать для своих устройств отдельную зону NTP-серверов;
  • осуществлять мониторинг связанных с NTP метрик при выпуске новых и обновлении старых продуктов;
  • усовершенствовать механизмы обратной связи с пользователями, чтобы эффективнее выявлять подобные проблемы.

Источник:

Если вы заметили ошибку — выделите ее мышью и нажмите CTRL+ENTER.
Материалы по теме

window-new
Soft
Hard
Тренды 🔥
Google и CrowdStrike обезвредили ботнет Glassworm, два года атаковавший разработчиков открытого ПО 21 мин.
No Man’s Sky получила обновление The Swarm с фракциями для игроков, роем дронов и масштабными космическими сражениями 2 ч.
«Удивит и впечатлит людей»: инсайдеры раскрыли название, место анонса и дату выхода ремейка Rayman Legends 2 ч.
Avanpost открыла публичное тестирование облачного сервиса Avanpost Identity Cloud 2 ч.
Telegram в России оштрафовали в третий раз за месяц 4 ч.
Robinhood выпустила кредитку для ИИ-агентов, чтобы те могли оплачивать покупки за пользователей 4 ч.
Кодзима наконец покорил космос, но лишь в ИИ-рекламе для Prada 4 ч.
Спустя пять лет после анонса разработка новой Dragon Quest стартовала с нуля — первый трейлер и подробности Dragon Quest XII: Beyond Dreams 6 ч.
YouTube научился автоматически помечать видео, созданные с помощью ИИ 7 ч.
Большая игра в компактном формате: критики вынесли вердикт олдскульному приключению Mina the Hollower от создателей Shovel Knight 7 ч.
Valve возобновила продажи Steam Deck, но цена взлетела на сотни долларов 8 мин.
Китайский производитель памяти CXMT готовит крупнейшее за последние годы IPO, чтобы бросить вызов Samsung и Micron 2 ч.
Американский стартап в 1000 раз ускорил протипирование печатных плат — жидкий металл меняет разводку печатных плат почти мгновенно 3 ч.
Будущие смартфоны Huawei Mate 90 получат процессор Kirin на аналоге 3-нм техпроцесса 4 ч.
«Это не было запланировано»: Motorola признала скрытую подмену ссылок Amazon на своих смартфонах 4 ч.
Из-за ИИ-бума TSMC повысит цены на 3-нм чипы на 15 % в этом году и ещё на 10 % — в следующем 4 ч.
$800 млрд под угрозой: половине запланированных в США ЦОД угрожают стихийные бедствия 6 ч.
Gigabyte выпустила вторую ревизию GeForce RTX 5060 Gaming OC — она стала быстрее на 7 МГц 6 ч.
MediaTek представила чип Dimensity 8550 для мощных смартфонов среднего уровня — он поддерживает Gemini Nano v3 6 ч.
В очередь за холодом: Modine получила предзаказ на системы охлаждения для ЦОД на $4 млрд 6 ч.