Чем плохо быть full stack enterprise-администратором
Disclamer: jehy опубликовал интересную статью — Чем плохо быть full stack разработчиком.
Проблема, которую затрагивает автор, на самом деле гораздо шире чем мир разработки. Мы, скромные администраторы, испытываем такие же проблемы. Прочитав ее я не удержался, чтобы не сделать маленькую пародию, спроецировав, порою дословно, ее на мир системного администрирования.
Введение
Прежде всего определимся с терминами. Есть много разных представлений о том, кто же такой full stack администратор, кто-то даже обоснованно считает, что такой администратор — это миф, но в этой статье будет иметься в виду администратор, который обладает знаниями и умениями, позволяющими разобраться в ИТ-инфраструктуре «от» и «до» и при необходимости обслужить любую систему. Идеальный enterprise администратор это тот, кто владеет в какой-то мере как сетевой составляющей, так и системами хранения данных, платформами виртуализации и другими продуктами, может сам диагностировать, на каком уровне возникла неисправность или что потребуется для запуска нового сервера.
Возможно, по заголовку кому-то покажется, что это жалобный пост о том, как плохо живется вчерашнему студенту, а сегодняшнему эникею в одноранговой сети с 1С-кой, который понахватал всего из разных статей в интернете. Нет, пост не жалобный. И мы будем рассматривать не вчерашнего студента, а матерого админа, с бородой и опытом работы в пять лет и более. Просто посмотрим, какие минусы есть в таком развитии.
Минусы
В каждой отдельной области вы хуже, чем узкий специалист
Кажется довольно очевидным, но всё же поясню. Если вы потратили шесть лет на одну технологию, то с очевидностью ваши знания будут больше, чем у человека, который шесть лет занимался несколькими. У вас было больше проектов, вы больше занимались какими-то типичными решениями, больше знаете багов by design.
Вам сложнее продвигаться глубже
У хорошего full stack администратора всегда что-то в мыле. То целый корпус от сети отвалился, то массив развалился, то patch Tuesday от Microsoft. И ваше время на познание нового распределяется между всеми технологиями, с которыми вы работаете. Естественно, что ваше развитие происходит медленнее, чем у коллеги узкой специализации.
У вас больше вероятность перегрузки задачами
Если вы занимаетесь сразу несколькими проектами с нескольких сторон, то даже при хорошем тайм менеджменте часто будет случаться так, что все проекты требуют к себе повышенного внимания и времени. Придётся это решать или передачей части задач другим администраторам, или распределением приоритетов, или тщательным планированием. Конечно, вероятность перегрузки есть у любого — как известно, в реальном мире любую задачу нужно делать «вчера». Но у вас такие задачи могут внезапно появляться пачками.
Вас сложно заменить
Кому-то это может показаться плюсом — вас сложно уволить, вас любят и ценят. Но обратная сторона медали — невозможность передачи задач, звонки в любое время суток, проблемы с уходом в отпуск, сложности при попытке заняться чем-то другим.
У вас нет чёткой зоны ответственности
Если в кране нет воды — значит, виноват главный админ! Какие бы проблемы не возникали, какие бы баги не вылезали — скорее всего, именно вам придётся ими заниматься, даже если проблема на самом деле должна быть в ведении других коллег по цеху. Просто ваша картина мира гораздо полнее, и вы быстрее сможете локализовать и исправить ошибку. К сожалению, этим постоянно злоупотребляют.
«О, дайте ему — он разберётся!»
О лучше бы не давали. В ситуации, когда необходимо разобраться с откровенно кривой, недокументированной или устаревшей системой, скорее всего задействуют именно вас. Особенно печально, когда работодатель хочет сэкономить, наняв одного продвинутого администратора на огромный круг задач. А ты смотришь на удивительную систему и понимаешь, что проще это выкинуть и целиком сделать заново.
Вы не знаете всех нюансов продукта
Это довольно очевидно следует из первого пункта, но хочется упомянуть отдельно — хотя бы потому, что в вакансиях часто требуется опыт работы с конкретными специфическими сценариями, вроде опыта миграции с Exchange 2003 на 2016, интеграции с Lync и построения гибридной инфраструктуры с Office 365.
Вы не успеваете за всеми тенденциями
Опять же это следует из первого пункта. По непонятной мне причине, часто ищут разработчика, который в совершенстве умеет применить что-то, что вышло в релиз полгода назад. Увы, вы не можете одновременно знать и уметь применять Windows Server 2016, рассказать об отличиях последней версии VMware View и о возможных проблемах миграции с EMC на Nutanix в текущий момент. Возможно, вы об этом читали, но попробовать просто не успели.
Вы не всегда оптимально работаете
Скорее всего, ваша работа качественно выполняется, систематизирована и документирована. Но наверняка более квалифицированный специалист — мастер документирования по ГОСТ 34 мог бы сделать ее чуть лучше. Другой вопрос, что это обычно не критично. Действительно плохо, если каша из технологий в голове заставляет вас применять подходы и решения, которые никак не годятся в текущем проекте. Ужасно видеть, как некоторые даже пишут скрипты, которые просто дублируют команды из недр банального графического интерфейса или стандартных утилит.
Вы часто подглядываете в мануалы
Удержать в голове функциональность 20 продуктов просто невозможно. Вчера вы поставили vCenter, а сегодня не можете вспомнить что вы вообще это делали. Если вы часто переключаетесь между разными технологиями и языками, то скорее всего у вас непрерывно будет висеть мануал, в который вы подглядываете, что конечно несколько снижает скорость работы.
Вы можете начать завидовать зарплате узких специалистов
Если начать искать вакансии по самому вашему дорогому навыку, то можно огорчиться — специалисты с большим опытом работы могут получать за него весьма неплохие деньги. Скажем честно — у вас такого опыта работы с конкретной технологией нет. Но даже если вы углубитесь в эту технологию и получите необходимые знания — хотели бы вы дальше всю жизнь заниматься только этим? Например, администрированием СУБД Oracle или исключительно сетевого оборудования Aruba?
Минусы в трудоустройстве
Отдельно хочется упомянуть сложности, которые случаются при смене работы.
Вас буду звать работать по случайным ключевым словам в резюме
HR не всматривается в то, что указанной технологией вы занимались на небольшом проекте три года назад. Он увидел слово, похожее на вакансию, которую надо закрыть, сделал стойку, и пытается вас туда пристроить любой ценой, не интересуясь вашими желаниями и текущими предпочтениями.
Full stack full stack«у рознь
Какой бы вы ни были широкий специалист, вряд ли вы найдёте место работы с точно таким же стеком технологий. У кого-то VMware, у кого-то Hyper-V. Кто-то любит Exchange, а кто-то Communigate. Слева Cisco, справа HUAWEI. Бывает, но крайне редко. Однако пересечения часто довольно большие, и ничто не мешает вам подтянуть недостающее и ещё больше расширить кругозор.
Вам не верят
Да, вот такая смешная и реальная проблема. Если вы указали в резюме слишком много всего, то вам просто не поверят и даже не будут пытаться проверять или спрашивать о том, на каком уровне вы что знаете. Поэтому, как ни смешно, лучший способ — безжалостно удалять из резюме все сведения, которые вы считаете неактуальными для своего будущего. А ещё лучше — подгонять резюме под каждую вакансию.
Вам сложнее искать подходящую вакансию
Высоквалифицированных fullstack администраторов, да на нормальную зарплату ищут довольно редко, и не всегда работодатель с такой вакансией может конкурировать по зарплате с вакансией узкой специализации по условиям. Вы видите вакансию CCIE, или узкого специалиста в области UC, а для fullstack только пару вакансий на уровне квалификации и зарплаты эникея.
Плюсы
Теперь, наконец, о вкусном.
Вы можете выбирать, кем работать дальше
Вам гораздо проще сменить ориентацию (простите за двусмысленность), чем обычному администратору. Вы видите многое в применении, можете разобраться и понять, что вас интересует. Да, вам придётся потратить время на углубление —, но это будет потраченное с пользой время. Да, вам скорее всего придётся завести несколько пет проджектов, чтобы попробовать всё, что хочется. Но это опять же окупается сторицей. Некоторые держат дома целые кластеры с Xeon и сотней гигабайт RAM, чтобы в свободное время постигать новое.
Вы меньше выгораете
Если есть возможность периодически менять технологии, то вы гораздо меньше устаёте от решения одних и тех же проблем. Конечно, если вы не хардкорный фанат и не получаете удовольствие просто от того, что восстанавливаете по двадцать ящиков Exchange для разных клиентов.
Вам проще расти в тимлида или архитектора
Довольно очевидный плюс — чем больше вы разбираетесь в общей структуре, тем больше у вас шансов на рост в руководителя. Конечно, при наличии желания и коммуникативных навыков.
Вы можете отдебажить всё, что угодно
Очевидный плюс. Ваше системное мышление достигло уровня, на котором вы можете исправить что угодно и где угодно.
Работать веселее, интереснее и познавательнее
За один день вы можете получить много новых навыков и знаний в абсолютно разных вещах.
В одиночку вы можете создавать чудесные вещи на стыке разных технологий
Вы один можете сделать то, на что при стандартном подходе требуется 3–4 человека.
Опубликовать тонкое приложение на терминальной ферме через ipsec VPN с поддержкой ГОСТ, начиная с подготовки файрволла, продолжая нарезкой СХД, добавлением физических хостов, развертыванием гипервизоров, установкой клиентских ОС и конфигурированием балансировки по загрузке? Легко! Вы один можете представить всю систему и реализовать её без согласований, недопониманий и проволочек.
Ваши решения работают быстрее и надёжнее
За счёт понимания взаимодействия различных систем, вы можете выбрать лучше пути для их комбинирования. Вы лучше понимаете каждый компонент и не боитесь его использовать. Как пример — возьмём «кляудные технологии» (мопед не мой, в публикациях проскакивало). В общем и целом, облако это чудесный способ решения огромного количества задач, в том числе задач масштабирования. К сожалению, всё чаще вижу, что облачные решения используются просто потому, что админ не умеет и боится конфигурировать on-premises, а представляет это в виде дополнительного плюса. А многое можно сделать гораздо дешевле и лучше, если иметь хотя бы поверхностное понимание вопроса.
Вы постигаете дзен
Теперь вы знаете, что нет технологии, которая лучше остальных. Вы знаете, что нет самой лучшей базы данных. Вы можете предположить, что какой-то инструмент подходит для ваших целей лучше…, но вы вполне готовы использовать альтернативы, если на то есть какие-то основания, например, квалификация остальных админов. Вы больше не пишете статей про синтетические тесты, созданные с тем, чтобы показать преимущества одной технологии над другой. Вы знаете, что прирост производительности в пять процентов скорее всего не стоит двух ваших человеко-месяцев. А освободившееся от холиваров время вы наконец можете потратить на что-то полезное. Например, чтобы наладить взаимоотношения с девушкой (для примера назовём её Машей). Вы теперь понимаете, что технологии бывают разные, что люди бывают разные, и нужно просто найти правильный способ связать всё воедино. Ты любишь мир, и мир любит тебя. Даже когда ты его используешь, чтобы выстрелить себе в ногу.