Сегодня 28 ноября 2024
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.
Вечерний 3DNews
Каждый будний вечер мы рассылаем сводку новостей без белиберды и рекламы. Две минуты на чтение — и вы в курсе главных событий.
Материалы по теме

window-new
Soft
Hard
Тренды 🔥
Будущее обслуживание серверов Bloodborne подарило фанатам новую надежду — оно пройдёт в день 30-летия PlayStation 30 мин.
Riot готова заплатить до 100 тысяч долларов за поиск уязвимостей в античите в Valorant и League of Legends 2 ч.
Titan Quest 2 выйдет в раннем доступе Steam без кооператива и поддержки русского языка, но есть и хорошая новость 4 ч.
Спустя восемь лет после провального запуска обзоры No Man’s Sky в Steam стали «очень положительными» 5 ч.
В московском метро впервые за четыре года замедлился мобильный интернет 6 ч.
ИИ научились взламывать с помощью картинок с подвохом, невидимым для человека 7 ч.
Tencent анонсировала свою Horizon Zero Dawn — экшен Light of Motiram про выживание в мире механических животных 9 ч.
Запуск цифрового рубля забуксовал — магазины не знают, как с ним работать 9 ч.
Amazon разработала ИИ-модель, которая умеет работать с видео 10 ч.
Илон Маск пообещал «сделать игры снова великими», открыв ИИ-студию на базе xAI 10 ч.
Китайцы предложили навечно записывать данные в алмазах — плотность будет в 10 000 раз выше, чем на DVD 4 ч.
Huawei показал конкурента Rolls-Royce — электромобиль Maextro S800 стоимостью от $140 000 4 ч.
Dell отчиталась о росте выручки и прибыли и большом портфеле заказов на серверы, но акции всё равно упали из-за слабого прогноза 6 ч.
Смартфоны Vivo S20 и S20 Pro дебютировали с ценой от $317 — у старшего сразу четыре 50-Мп камеры 6 ч.
DLA Piper: большинство инвесторов ждут роста вложений в ЦОД несмотря на проблемы с доступом к энергии 7 ч.
Redragon RYZE — компактная механическая клавиатура с RGB-подсветкой и тихими переключателями 7 ч.
LG выпустила 27-дюймовый IPS-монитор UltraFine 27US550-W с 4K и апскейлером Super Resolution+ 7 ч.
Создатели «Глонасс» собрались защитить российские автомобили от хакеров 8 ч.
США впервые с 2001 года пересмотрят правила лицензирования подводных интернет-кабелей для защиты национальных интересов 8 ч.
Эволюция устройств для измерения артериального давления: от ртутного тонометра до смарт-часов 9 ч.