{"id":14277,"url":"\/distributions\/14277\/click?bit=1&hash=17ce698c744183890278e5e72fb5473eaa8dd0a28fac1d357bd91d8537b18c22","title":"\u041e\u0446\u0438\u0444\u0440\u043e\u0432\u0430\u0442\u044c \u043b\u0438\u0442\u0440\u044b \u0431\u0435\u043d\u0437\u0438\u043d\u0430 \u0438\u043b\u0438 \u0437\u043e\u043b\u043e\u0442\u044b\u0435 \u0443\u043a\u0440\u0430\u0448\u0435\u043d\u0438\u044f","buttonText":"\u041a\u0430\u043a?","imageUuid":"771ad34a-9f50-5b0b-bc84-204d36a20025"}

6 советов бизнесу, что проверить в инфраструктуре сайта

Чтобы в Черную пятницу не пострадать из-за того, что сайт “лежит”, а поток покупателей идет.

Очень досадно, когда отдел маркетинга\отдел продаж\коммерческий департамент или лично собственник бизнеса просчитали всё перед акцией (типа Чёрной пятницы) — и всё пошло прахом, потому что про возможные ошибки внутри сайта никто не подумал…

Впрочем, тут ни один из сотрудников вышеперечисленных отделов не виноват. Дело в том, что в программной части встречается такой сорт ошибок, которые проявляются исключительно во время наплыва клиентов. Что же делать? Опустить руки и играть в ромашку “упадёт — не упадёт”? Если знать, куда смотреть, то гадать не придётся. В этой статье мы собрали практические рекомендации, как избежать простоев, связанных с такими ошибками. Советы основаны на нашем четырнадцатилетнем опыте поддержки высоконагруженных веб-проектов.

Важно: нет единого универсального рецепта для всех проектов, ведь каждый из них — особенный. Поэтому невозможно задать конкретные параметры по тому или иному показателю из перечня ниже. Но благодаря этой статье вы сможете поставить перед штатными (или нештатными) айтишниками конкретные задачи: что проверить и где проверить.

Оптимизировать скорость отклика страницы, на которую будет приземляться трафик

Отклик, скорость отклика сайта — это то время, которое проходит между запросом сайту и ответом на этот запрос. К примеру, если пользователь захотел посмотреть конкретный товар в каталоге, скоростью отклика будет то время, за которое загрузилась страница товара.

Скорость отклика зависит от множества факторов: сервера, ОС, софта, отвечающего за фронтенд*, ПО, отвечающее за бэкенд** и базу данных.

*фронтенд — часть сайта, видимая пользователю: картинки, страницы, кнопки — весь пользовательский интерфейс, которые мы видим в браузере, когда заходим на любой сайт.

**бэкенд — скрытая часть сайта, “механизм”, благодаря которому он работает: выполняются запросы на сервере и другие процессы на сайте.

Цель донастроек — это улучшение текущих показателей: ускорить запросы и быстрее возвращать ответы на них за счет кэширования или индексирования в базе данных.

Если этого не сделать, то даже после отправки е-мейл рассылки с акцией могут возникнуть большие проблемы.

Большинство почтовых клиентов, например, тот же Gmail, при получении ссылки отправляют по ней бота, чтобы сформировать превью. Если мы шлём рассылку с акцией на сотни тысяч или миллионы адресов, то на сайт приходит сотни тысяч или миллионы ботов от её адресатов. Потом уже реальные пользователи приходят по url из той же рассылки и окончательно добивают ситуацию. Все покупатели, которые хотели попасть на сайт, не смогли этого сделать, потому что он упал ещё до их визита.

Это может произойти как раз из-за недостатка скорости отклика. Сайт слишком медленно отвечает на запросы от ботов и пользователей. В результате образуется очередь, которая попросту перегружает систему количеством запросов, ждущих обработки.

Проверить настройки приложений

Иногда бывает так, что нужный софт установлен, — например, тот же балансировщик нагрузки, — но туда никто не заглядывал и поэтому не изменил настройки лимитов по умолчанию. Настройки “из коробки” не предназначены для работы при высоких нагрузках; в лучшем случае они годятся для среднестатистического трафика в спокойный будний день. Так что их обязательно стоит проверить.

Вместе с ними проверьте также заданные лимиты подключений, лимит памяти для процессов, лимиты дискового пространства, количество воркеров*** и кэширование с HDD в оперативную память.

*** Воркер или Веб-воркер — обработчик, вроде кассира на кассе, у него есть посетители — процессы, которые он должен обработать. Бывает так, что он не справляется. При этом кассир вроде и не устал, и не перегружен, занята своим делом, а посетители к ней попасть не могут из-за большой очереди. Из-за этого система тормозит и некоторые пользователи бросают товары и уходят.

Вот кейс о том, что проверять настройки — это очень важно.

Дано: медицинская лаборатория по обработке анализов и соответствующий софт. В некоторых филиалах всё время от времени тормозит, в самом крупном — большие проблемы с производительностью. Штатные специалисты заказчика месяцами не могут понять, в чем дело.

Решение: проверяем настройки ПО и видим, что система уперлась не в лимиты подключений, а в количество воркеров приложения. Фактически есть много свободных ресурсов, большой нагрузки нет, ошибок нет, но приложение просто не успевает обрабатывать все запросы. Это происходило потому, что системе недоставало потоков для обработки запросов параллельно, но мощностей для этого хватало. Мы добавили еще несколько воркеров, и многомесячная проблема решилась за 4 часа с перерывом на кофе.

Протестировать серверные мощности

Сделать это нужно в соотношении с текущей нагрузкой — проверить, насколько больший трафик выдержит ваша система. Самый правильный для этого путь — провести нагрузочное тестирование, чтобы при необходимости легко и быстро масштабироваться.

Пример: в интернет-магазин обуви приходит 5 посетителей в секунду. От этого процессор и память сервера уже заняты на 90%. Это значит, что роста нагрузки хотя бы в 2 раза инфраструктура при её текущих настройках не выдержит.

Именно нагрузочное тестирование — сознательная и контролируемая перегрузка системы — позволяет выявить те ошибки, которые проявляются во время наплыва клиентов.

Проверить систему хранения данных

Проверьте, настроена ли репликация и запись в мастер/чтение со слэйва, аппаратные и программные лимиты на хранение данных и скорости чтения/записи на дисках, лимиты на передачу файлов в облачных сервисах.

Эти действия спасут вас от чрезмерной нагрузки на сервер во время чтения данных из базы или статического контента с диска. Добавив CDN**** и чтение со слейва, вы подготовитесь заранее и снимете возможную нагрузку с сервера, передавая ее на вспомогательные диски или CDN.

**** CDN (Content Delivery Network) — географически распределенная инфраструктура, которая помогает сайтам быстрее загружаться и отвечать на запросы пользователей.

Проверить связность компонентов и коммуникации с внешними сервисами

  • Связность компонентов: использование подсистем, порядок обработки пользовательского запроса.
  • Коммуникации с внешними сервисами: API платежного шлюза, сервис для email-рассылок, геосервисы, сторонние модули GPS, лимиты передачи данных в сети, лимиты передачи данных в канале связи.

Замечание: наличие системы мониторинга на сервере не даёт информации о проблемах с каналом. Вовремя их обнаружить помогут:

  • мониторинг сетевого интерфейса и его текущей скорости;
  • мониторинг доступности сервера с нескольких точек — банальный пинг сервера из разных мест, чтобы не получилось так, что из офиса в Санкт-Петербурге сервер отвечает, а во Владивостоке — нет.

Проверьте вспомогательные компоненты

Проверьте работу мониторинга проекта, а также сторонние сервисы сбора логов и трейсов, системы поиска багов и уязвимостей, которые могут стать узким местом. Если с ними возникнут проблемы, то техподдержка оперативно не получит алерты о проблеме, а значит, не сможет предотвратить инцидент.

  • Сторонние сервисы нужно проверять регулярно и делается обычно это руками специалиста техподдержки.
  • На дашбордах системы мониторинга сайта обязательно должны быть все необходимые графики, отображающие состояние системы.
  • Также нужно проверить триггеры по которым срабатывают алерты — предупреждения системы мониторинга, о том, что происходит нештатная ситуация.

Зачем вообще использовать то, что может стать проблемой? Подобные сторонние сервисы не только снимают нагрузку с инфраструктуры. Они помогают в те моменты, когда система мониторинга “легла” вместе с сайтом, и служат резервным источником необходимой информации.

Памятка, как сделать черную пятницу светлой

  • Даже если все проверить перед релизом, могут вылезти ошибки, которые случаются только при росте трафика;
  • Чтобы их избежать, нужно проверить отклик страницы, настройки софта, систему хранения данных, утилизацию мощностей и вспомогательные компоненты системы.
  • Сделать это лучше всего с помощью нагрузочного тестирования. Подробнее о том, как оно проходит — в этой статье.

Мы упаковали все главные мысли из этой статьи в небольшой чек-лист, которые поможет вам подготовиться к любой масштабной распродаже. Скачать его, чтобы он всегда был под рукой, можно по ссылке.

0
6 комментариев
Написать комментарий...
Рамиль Хантимиров

А как же главное - подключить и протестировать защиту от DDoS?

Ответить
Развернуть ветку
ITSumma
Автор

Мы старались рассказать о тех вещах, про которые часто забывают перед акциями. Но вы, безусловно, правы — про защиту от DDoS тоже забывать не стоит. Спасибо за ценное дополнение!

Ответить
Развернуть ветку
Ника Авдонина

все равно найдется какой-то хакер-азиат, который сможет пробить защиту)

Ответить
Развернуть ветку
ITSumma
Автор

Это со всем так) Что бы ты не делал, всегда найдется азиат, который делает это лучше😉

Ответить
Развернуть ветку
Eugene Trifonov

Спасибо за полезную статью

Ответить
Развернуть ветку
ITSumma
Автор

Пожалуйста!😊

Ответить
Развернуть ветку
3 комментария
Раскрывать всегда