Size: a a a

2020 March 18

SU

Serg Udo in Random Ruby Chat
Так убили уже стартапера
источник

SU

Serg Udo in Random Ruby Chat
Сенкью
источник

AD

Anton Davydov in Random Ruby Chat
источник

M

Max in Random Ruby Chat
источник

DB

Dmitryi Berg in Random Ruby Chat
источник

R

Rafkat in Random Ruby Chat
​​Мы в iGooods лежали почти полдня. Стыдно! Зря я угорал вчера над утконосом, что они упали. Поделюсь честно, от чего мы лежали. Это подробный постмортем аварии с техническими подробностями, мама, извини.



Из-за коронавируса к нам начали приходить в 2-3 раза больше клиентов, чем обычно. Плюс у нас на днях запускается два новых партнерства — с Joom и с магазинами Лента. Серверы работали на 40-60 процентах емкости и мы решили «добавить железа». В 6 вечера мы налили пару новых машин в кластер приложений, в час ночи по Москве — перетащили базу на новую, ультра мощную тачку. Обе операции — необычные для iGooods, множество вещей делалось руками. Ошибка №0 — мы сделали 2 крупных изменения близко друг с другом

В 7 утра по Москве, сервер базы данных начал плавиться от нагрузки в процессор. Это компьютер с 70 ядрами, но базе нужно было минимум 300. Запросов было вроде бы не сильно больше, чем обычно, но занимали они всё больше времени. Люди просыпались у себя дома и начинали делать заказы — сервера умирали, сайт не открывался, приложения выдавали ошибки. Самое опасное — курьеры и сборщики заказов выходили на работу и не могли работать.

Мы, конечно, думали, что сможем быстро починить проблему. Через час стало понятно, что нужно хотя бы временное решение. Мы выключили все пользовательские интерфейсы iGooods, оставив рабочей только админку и внутренние приложения курьеров и пикеров (сборщиков заказов). Ошибка №1 — в случае аварии не нужно пытаться «сделать хорошо», нужно определить критичные сервисы и восстановить их первым делом.

Мы решили, что проблема в новой базе данных. Мало ли, конфигурация, железо, да хоть драйверы. Попытались вернуться на старый сервер. Мы не сохранили WAL логи между переездами, так что вместо 3 минут эта операция заняла 40 минут — пришлось перегнать всю базу данных между серверами. Мы планировали откат для приложений, но не для переноса базы — он нам казался довольно безопасной операцией. Ошибка №2 — мы решили, что «уж тут-то не взорвется», на самом деле вместе с любым изменением нужно продумывать пути отката.

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

В конце концов, Женя случайно заметили ошибку, что наше rails приложение не может записать в redis-кеш. BINGO! Вот тут всё наконец-то встало на свои места. В нашем приложении есть много страниц, которые собираются очень долго. Все они кешируются rails'ами в redis. И вот этот редис кеш у нас отвалился на запись на части серверов приложений из-за кривых настроек окружения (душераздирающие подробности приложены картинкой). Кеш протухал постепенно и с каждой потерянной записью все больше тяжелых запросов грузили Postgres. Ошибки №3, 4 и 5: настройка тачек производится руками, не кодом; логи переполнены, так что сложно заметить новую ошибку; не все важные сервисы (redis, rails cache) включены в мониторинг.

Как вы можете видеть, всё довольно банально. Будь у нас настроена нормальная рабочая среда — не было бы такой аварии.

Итак, чего нам не хватило и что мы приведем в порядок:
- инфраструктура в коде (полный ansible вместо хождения руками на серверы);
- хороший, чистый мониторинг всех ключевых метрик приложения,  APM — за день до аварии мы включили Datadog, но ещё не было нормальных дэшбордов и исторических данных;
- сообщения об ошибках (у нас bugsnag) засраны нерелевантными сообщеними — их нужно почистить.

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

Если у вас похожая ситуация — рекомендую навести порядок заранее, не ждать форс-мажора.

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

Fin.
источник

VE

Vitaliy Emeliyantsev in Random Ruby Chat
Сохранил, спасибо
источник
2020 March 19

AB

A B in Random Ruby Chat
Привет, чат будет закрываться на карантин?
источник

EB

Eugene Burmakin in Random Ruby Chat
Пока шутите на расстоянии не ближе 1 метра, можно оставить открытым
источник

R

Rafkat in Random Ruby Chat
A B
Привет, чат будет закрываться на карантин?
Нет, токсичная атмосфера не позволит
источник

AB

A B in Random Ruby Chat
Токсик убивает коронавирусы.
источник

AB

A B in Random Ruby Chat
Всех прибывающих из Италии добавляйте в руби-чат
источник

LS

Loki Starcaller in Random Ruby Chat
источник

EB

Eugene Burmakin in Random Ruby Chat
Друзия, порадуйтесь за меня, я наконец-то обновил перевод книжки "Основы веб-хакинга" :) Долго к этому шёл, ещё дольше — стоял на месте, но сейчас перевод обновлён, сообразил к нему несложный одностраничник с описанием книги, доволен.

https://webhacking.ru/
источник

D

Dimon in Random Ruby Chat
Жек, красавчик
источник

AD

Anton Davydov in Random Ruby Chat
источник

EB

Eugene Burmakin in Random Ruby Chat
Спасибо (:
источник

NM

Nikita M in Random Ruby Chat
Dimon
пацики, вопросик один надо обкашлять.

Вот есть таблица в постгре, могу ли я сделать jsonb поле праймери кеем?

инб4. зачем
Нет
источник

NM

Nikita M in Random Ruby Chat
Только составным или заодно уникальным если постгра это позволяет
источник

D

Dimon in Random Ruby Chat
Да
источник