Кремниевая резня бензопилой

Дежурство — это важная составляющая большинства современных организаций. Ведь часто бывает, что проблема прилетает и в 3 часа ночи. Но кто должен дежурить? И как организовать этот процесс так, чтобы он имел смысл?
Заглядывайте под кат, там Барух Садогурский (@jbaruch) и Леонид Игольник (@ligolnik) расскажут хоррор-историю про одного неудачливого дежурного. Помните Васю, которому всегда приходилось фиксить баги бухому в три часа ночи? Это только начало.

468d143d649e453a36181827f843479f.png

Материал подготовлен на основе выступления Баруха и Леонида на осенней конференции DevOops 2017.

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

Пока он ни о чем не подозревает, его коллега из техподдержки принимает звонок от клиента. Тот рассказывает, что в понедельник он должен будет показать генеральному директору очень важную demo, но что-то не работает. Нужно срочно устранить проблему. Support сделал все, что мог (предложил выключить и включить), и эскалирует эту проблему дежурному.

Вася дежурит один на весь проект, заниматься этим придется ему. Инженер техподдержки его будит и пытается объяснить проблему очень простыми словами: «Вот там что-то не работает, что-то не так».

Вася выслушивает коллегу, обдумывает произошедшее и принимает единственно правильное решение…

6edf253de7d7babf85c1ed15b1a2b31f.png

Инженер поддержки обижается, но все равно просит клиента подождать до понедельника. Клиент с таким положением дел не согласен и эскалирует проблему саппорт-менеджеру. Теперь уже тот звонит Васе и говорит, что это несерьезно: «Все-таки дело важное, клиент переживает, надо». Вася — человек ответственный. Надо значит надо: кофе и потанцуем (поищем что-то в логах).

В логах все оказалось совсем не просто. Сначала Вася 15 минут искал человека с доступом к правильному логу. Его он нашел и получил лог. Но как? На почту в формате .doc, конечно же. Вася ответственный, молодой и читает лог в ворде: совсем ничего не понятно. Но есть ключевые слова, по которым можно поискать в Knowledge Base. Вася зависает на интересных вещах минут на 20, узнает много всего интересного, но ничего нужного в данный момент.

Что Вася делает дальше? Нужно кого-то искать, но Вася — инженер молодой и будить Senior-а страшно. Поэтому он решает, что нужно позвонить коллеге, такому же джуниору.

2cd9cbed7f8a7bed344dde6af272bd36.png

Коллега — хороший товарищ, с горем пополам они понимают, в чем проблема, и начинают ее решать. Спустя два-три часа работы они нашли hot-fix. Его надо сразу отдавать в продакшн. Но как? Есть change control board, который собирается по понедельникам раз в две недели. Но такой вариант не подходит, нужно же срочно.

Естественно, деплоить в продакшн нельзя, нет root. Значит единственный вариант — послать jar-файл с двумя классами и абзацем объяснений по e-mail. Те ребята зайдут по ssh на продакшн и там этот jar-файл в WebSphere подложат в правильную директорию. И вот, в 6–7 часов утра, наконец-то можно идти спать с чувством выполненного долга.

c478265cc5c839c05c8d4b62de5f3af1.png

В понедельник Вася приходит на работу и видит необычную картину. На VP of Engineering наорал гендиректор, потому что на гендиректора наорал клиент, потому что на него наорал его гендиректор. Оказывается, что решить проблему не получилось.

У начальства есть четыре вопроса: «Что случилось в пятницу?»; «Почему я об этом узнал от босса в понедельник?»; «Почему фикс занял шесть часов?» и «Кто виноват?». В комнату вызываются опсы, которые говорят, что это не их проблема. В комнату вызывается Вася и прочий дев, который тоже говорит «Ничего не работало». Вся эта игра в картошку продолжается до обеда.

Поскольку время обедать, принимается решение «Окей, оно само сломалось, никто не виноват». Конец истории.

cb90f12db5881b38dd9a1b8a24496eee.png

Устроим небольшой разбор полетов: давайте пройдемся по этому кошмару и попробуем дать ответы на все вопросы.

Кто должен дежурить


Дежурить могут сисадмины (или более модное слово — SRE). Они этим занимаются не первый год, у них все хорошо поставлено. Может дежурить DBA, могут те, кто занимается месседжингом. Если повезло, дежурит NOC (network operation center) — это когда всех этих ребят сажают в одну комнату. У них есть runbooks, в которых написано, что делать в сложной ситуации.  

e09be70905e239d8c20a74576641aa5c.png

С этими ребятами все понятно, они профи в дежурстве. Но, к сожалению, в DevOps есть вторая часть уравнения, которая не очень желает дежурить. Как заставить вторую часть? Да и надо ли заставлять, ведь профи должны осознавать важность дежурства.

Есть две причины, почему люди не хотят дежурить. Одна — это когда так:

4f9e817a351d0f5f2ddd7e1156b03203.png

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

0b9eeb86e1bafbac931df8d1b6653459.png

Нужно писать хороший код, все просто. Но этому тоже нужно научиться. Возникает новый вопрос: «Как научиться?». Нужно засунуть пальцы в розетку — #painisinstructional. Боль помогает.

2606b77da3af11845e734d1b60b56bf1.png

Дежурства сами по себе улучшают качество кода. Тот же Вася в понедельник, скорее всего, исправит свои ошибки, чтобы не сидеть еще одну ночь в поиске ошибок.

Барьеры при дежурстве


При дежурстве встречаются некоторые барьеры, которых там быть не должно. Пройдемся по Васиному пятничному фиаско. Помните, как он читал логи в ворд-документе?

34ca9b253f0cd952954826bb26310a36.png

Все мы любим продукты Microsoft, но в современном мире так работать нельзя. Есть очевидные вещи про логи, которые должен понимать каждый. Главный пункт — это количество тулов, которые решают эти проблемы: Logstash, Loggly, Sumo logic, Kibana. Их нужно использовать.

Возвращаясь к вопросу доступа: почему не дают доступ к логу? Ответ — sensitive data. Клиентам пообещали защищать данные от утечек. Значит, логи никому нельзя показывать или нужно пользоваться системами с функционалом data masking. Он сам скрывает персональные данные и не показывает их человеку без нужного уровня доступа. Все сегодняшние инструменты для парсинга логов имеют эту функциональность.

Еще одно преимущество этих инструментов — на них можно построить «мониторинг для бедных». Например, в логах, увидев определенное кол-во ошибок (переполнена очередь и т.п.), можно триггернуть аллерт.

a0ff3a9d4a0e58da7f7f9d3044f1e10b.png

Кто определяет важность проблемы


Как понять, ложиться дежурному спать или срочно бежать исправлять проблему? Кто назначает severity? Кто решает, насколько критична проблема? Решает support. А почему? Потому что саппорт имеет видение проблемы. Он знает, насколько все плохо.

Более того, сегодня почти все компании работают по принципу «Continuous Delivery», поэтому все клиенты получают все фичи одновременно (и заодно баги). Допустим, есть баг, который для клиента выглядит как «Что-то там не работает, ничего страшного». В этот же момент саппорт видит сотни оповещений о проблеме, и это, очевидно, серьезно.

Еще в определении важности проблемы участвует клиент. Но есть проблема — клиент не всегда верит, что его небольшую проблему починят и ставит наивысшую важность. Severity начинает использоваться как инструмент манипуляции. Но если severity definition построен правильно и клиент понимает, что такое SLA, такого обычно не происходит. Это взаимный процесс обучения, когда клиенты начинают понимать, что действительно очень важно, а что просто важно.

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

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

6bad6b8118363d6ec214e3e9e9609dbf.png

Организационные проблемы


Вася не понял проблему до конца. Конечно, он же только что проснулся, а коллега из техподдержки еще и плохо объяснил. Лечится это только одним способом: билет. Билет (ticket) — это референс-номер, который рассказывает, о чем вообще речь. Это нужно для Васи, потому что вместо телефона саппорт мог сказать Васе «Открой нашу систему ведения тикетов и посмотри тикет номер 42». Это нужно по нескольким причинам. Во-первых, Вася, вместо того чтобы в сонном состоянии слушать коллегу, проснется, пойдет почитает тикет и поймет, насколько это важно. Во-вторых, проблема может быть и не одна.

Есть еще одно затруднение, которое влияет на общую картину: Васю нужно найти. Откуда саппорт знает, что именно Вася сегодня дежурит? А вдруг он и Васю то не знает. Важно, чтобы было просто найти нужного человека. Решение — Virtual Extension с разными префиксами для инженера, продакшена и тд. Ну или другие, более навороченные системы. С таким решением не надо гадать, куда звонить среди ночи, все переключается автоматически.

Еще удобнее — Escalation Chat в Slack, Telegram, Skype, где угодно. Title чата — номер того самого тикета. Все общение по этому тикету между нужными людьми идет в этом чатике. Одна из самых полезных фич такого чатика заключается в том, что не нужно ничего рассказывать тем, кто присоединяется к работе через какое-то время. О том, какие решения уже приняты, можно просто прочитать.

Ну и virtual phone bridge, который можно сравнить с местом сбора при пожаре: все знают, куда идти в случае возникновения проблем. Кстати, в современных системах типа Zoom или Bluejeans весь нужный функционал уже встроен.

a256f04a085845d9d6e145f6dac418ff.png

Путь эскалации


Вася побоялся звонить сеньору, ведь они страшные. Что делать с этим? Поговорим про escalation path. Надо всегда знать, кого и когда будить или отрывать от работы. Это должно быть совершенно четко понятно всем: и тому, кто будит, и тому, кого будят. Еще нужно знать, куда звонить, если первый путь не сработал. Хороший escalation path идет вплоть до генерального директора компании.

aa07f8129f9fc0ca054c7e6af456bebf.png

Есть коммуникации, которые должны исходить от CEO. Он должен быть в курсе критических проблем.

Менеджер на побегушках


Следующая интересная позиция — manager on call. Он не обязательно должен быть технарем и принимать участие в решении проблемы. Во-первых, Вася среди ночи не может рассказать клиенту ничего полезного. Дежурный менеджер может помочь в такой ситуации. Кроме того, он может заняться координацией, управлением проектом в сложной ситуации, управлением ресурсами. Ведь работа должна идти бесперебойно.

90178892b8b970928206232047cf7e4d.png

Доступ к продакшену


Стоит ли давать Васе доступ к продакшену? Ведь не все — блестящие инженеры, и есть определенные вещи, на которых учиться не хотелось бы, клиенты обидятся. Это решается с помощью процесса деплоймента. Если процесс настроен правильно, то Вася может нажать кнопочку, которая в итоге его код на продакшн задеплоит. Если у вас есть нормальный continuous delivery pipeline, скорее всего, это можно делать автоматически (пройдут все тесты). Если нет, во многих компаниях решение принимает senior-инженер или менеджер. Он делает ревью, оценивает риск кода и принимает решение.

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

4d08ecb982b940a0e10e06f6f6c053b7.png

Смена дежурных


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

4cd77691c3ef18c0c8e1e3a937ee548a.png

Другие проблемы


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

451befeeccc16cf1a31cf91c225e0df3.png

Как это воплотить?


Но как же это все привести в компанию? Нужно понимать, что это займет какое-то время.

b8b5f21957318f2c41d0a5e93cf720a9.png

Нужно начинать с сеньор-ребят на дежурстве. Они имеют опыт и знают, что и как чинить. У сеньора меньше проблем: есть доступ к логам и т.п.

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

7af9f68998708b451a129db0086d5123.png

Выводы


Переходим к главному. Несмотря на то, что мы, технари, влюблены в tech, самое главное — это не продукты и технологии, которые используются в компании, а чувство дежурного «Я вовлечен в процесс улучшения продукта» (ну или самого дежурства). Многие понимают, что надо дежурить, но хочется видеть улучшения. Люди должны осознавать, что благодаря им и их улучшениям все становится лучше.

e3c26d207d37fb88592f800859a07fa4.png

P.S


Хотим порекомендовать книжку под названием Drive. Это — книга о мотивации людей, которые работают в профессиях типа нашей. Эта мотивация состоит из трех основных составляющих и (спойлер) ни одна из них — не деньги.

6b961558862a44f511344e29ef38a662.png

Уже в это воскресенье Барух и Леонид выступят с докладом »#DataDrivenDevOps» на DevOops 2018 в Петербурге. Приходите, будет много интересного: вот доклады, вот Джон Уиллис, а вот вечеринка с BoF-ами и караоке. Ждем вас!

© Habrahabr.ru