Привет всем! Давайте поговорим о том, чем роли Cloud-инженеров отличаются от DevOps-инженеров в разработке программного обеспечения. Эти две популярные позиции появились сравнительно недавно и из-за схожести их функций часто происходит путаница, а иногда их и вовсе считают взаимозаменяемыми, хотя перед этими профессиями стоят разные цели и задачи.

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

Cloud-инженер

Основной задачей Cloud‑инженера является создание и управление инфраструктурами облачных сред, в которых работают корпоративные приложения.

Изначальной целью облачных платформ — сети серверов, принадлежащих различным компаниям и размещённых в центрах обработки данных — была аренда серверных мощностей. Так компаниям не нужно было самостоятельно настраивать всю инфраструктуру. Сейчас облачные платформы стали предоставлять не только вычислительные мощности, но и различные сервисы, такие как базы данных, системы резервного копирования и другие. Теперь их также можно использовать для развёртывания приложений в кластерах контейнеров, хранения образов приложений и настройки конвейеров поставки ПО с возможностью геораспределения. Теперь доступны как локальные облачные платформы, функционирующие в одном‑двух ЦОДах, так и крупные международные платформы, чьими услугами пользуются тысячи компаний по всему миру. Эти коммерческие облачные сервисы предлагают множество настроенных решений для разработки программного обеспечения, машинного обучения, а также хранения и обработки данных.

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

Инженер по облачным технологиям (Cloud‑инженер) отвечает за проектирование, создание, развёртывание и поддержку облачных инфраструктур и сервисов. Он обеспечивает эффективную и безопасную работу облачных приложений и систем.

Он должен уметь:

  • развёртывать приложения в облаке;

  • настраивать системы мониторинга облачных сервисов;

  • оптимизировать ресурсы для снижения затрат;

  • внедрять и управлять инструментами информационной защиты данных;

  • писать скрипты для автоматизации развёртывания, мониторинга и управления;

  • работать с различными базами и типами данных в облаке;

  • взаимодействовать с разработчиками и другими специалистами для интеграции и поддержки облачных решений;

  • разрабатывать и реализовывать стратегии резервного копирования и восстановления данных для обеспечения отказоустойчивости;

  • настраивать сетевые соединения в облаке.

От Cloud‑инженера требуются навыки управления контейнеризацией, работы с облачными платформами и сетевыми технологиями. Он должен уметь программировать и писать скрипты, быстро выявлять и устранять проблемы в облачной инфраструктуре, а также анализировать данные и метрики для оптимизации работы облачных сервисов. И, конечно, он должен знать и уметь применять принципы информационной безопасности.

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

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

Крупные облачные платформы предлагают множество возможностей, но их сложность и разнообразие опций могут затруднять управление. Ошибки в настройке могут привести к серьёзным проблемам, поэтому всегда востребованы опытные Cloud‑инженеры, которые умеют настраивать всё правильно и эффективно. Такие специалисты должны глубоко понимать все аспекты сервисов выбранной платформы и уметь адаптировать их под корпоративные требования.

DevOps-инженер

Изначально роль DevOps‑инженера не предполагалась в качестве отдельной должности. Концепция DevOps должна была быть реализована несколькими инженерными специалистами, например, разработчиками программного обеспечения, операторами информационных систем, администраторами серверов и др. Но в реальности появилась востребованная профессия DevOps‑инженера, которая стала представлять собой самостоятельную инженерную роль.

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

DevOps‑инженер должен уметь:

  • писать скрипты и инструменты для автоматизации развёртывания, тестирования и мониторинга;

  • поддерживать и управлять серверными и облачными инфраструктурами;

  • интегрировать и автоматизировать тестирование;

  • настраивать системы мониторинга и журналирования для отслеживания работы приложений;

  • работать в тесном сотрудничестве с разработчиками, тестировщиками и операторами;

  • внедрять меры киберзащиты данных и приложений;

  • управлять обновлениями и патчами для поддержания актуальности и безопасности программного обеспечения.

Для выполнения этих задач DevOps‑инженеру необходимо освоить инструменты CI/CD, языки программирования и скриптинга, операционные системы, сетевые технологии и администрирование серверов. Требуется иметь опыт работы с инструментами управления конфигурацией и облачными платформами, контейнерами и оркестраторами. Нужно уметь находить и устранять проблемы в инфраструктуре и коде, а также эффективно взаимодействовать с различными командами и объяснять сложные технические концепции.

В чём разница и что общего 

DevOps‑инженеры сосредоточены на автоматизации процессов выпуска программного обеспечения, стремясь сделать его более быстрым и эффективным. А Cloud‑инженеры работают над автоматизацией облачной инфраструктуры, обеспечивая её надёжность, безопасность, скорость и восстановление. Хотя цели у них разные, есть и что‑то общее.

Когда компания для развёртывания программного обеспечения на серверах использует облако, Cloud‑инженер отвечает за корректную настройку и управление облачной инфраструктурой, чтобы обеспечить быстрое развёртывание, автоматическое тестирование и проверку с использованием различных стратегий. Его задачи включают в себя управление базовой инфраструктурой, мониторинг её работы, обеспечение безопасности, управление ресурсами и настройку географического распределения.

Основная задача DevOps — автоматизация процессов, поэтому инженер использует инструменты для управления инфраструктурой и мониторинга тех частей, которые влияют на выпуск приложений. Здесь и пересекаются обязанности DevOps‑ и Cloud‑инженеров. Иногда это приводит к созданию должности Cloud‑DevOps‑инженер.

Но одной роли недостаточно для охвата всех задач — от управления релизами до резервного копирования и контроля затрат. Поэтому выделяется отдельная роль облачного инженера, который специализируется на управлении облачными сервисами. По идее, DevOps‑ и Cloud‑инженеры должны работать вместе, помогая друг другу. Облачный инженер создаёт безопасную и устойчивую инфраструктуру в облаке, которая способствует достижению целей DevOps‑инженера, чтобы он мог автоматизировать процессы для быстрого развёртывания приложений и их запуска.

Комментарии (4)


  1. tolyanski
    11.12.2024 08:06

    Надо одному и тому же человеку устроиться одновременно на позиции Cloud, DevOps, MLOps, DataOps инженеров, затем все автоматизировать и на чилле получать оклад за четверых :)


  1. dobry-kot
    11.12.2024 08:06

    ИМХО настолько размыли понятие инженера что все осталное стало мейнстримом, хотя разницы между SRE, DEVOPS, CLOUD engineer и тп профессии отличаются только профилем направления. И получается чем больше ты размыт в профессии тем больше денег получаешь, хотя уровень компетенций все равно посредственный!


  1. lexdlx
    11.12.2024 08:06

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

    На текущий момент сбер единственный банк в котором сталкивался с инцидентами:

    • перевод себе же в другой банк по СБП был прерван как подозрительный

    • перевод по СБП вдруг завис на 3 дня

    • получить блокировку карты, т.к. воспользовался ей не в том городе, где обычно. (еще перед ковидом, давненько, но оказаться в другом городе вдруг без денег было запоминающимся)

    • квитанцию о переводе не удалось получить в электронном виде (как в приложении так и через сайт), пришлось долго общаться с ТП и в конечном итоге идти за ними в отделение

    • достать предложением обменяй спасибо на рубли, а при попытке выдать "Сервис временно не доступен"

    Как-то и прайм покупал, вспотел от sso сбера, требующего авторизацию на каждый чих самым отвратительным методом + раз в месяц изменения в лицензионном соглашении. Но там проще, "попытался попользоваться пару месяцев из года" -> "пожалел, что купил" -> "забил".

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

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


    1. tolyanski
      11.12.2024 08:06

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

      Возможно они заняты написанием статей вместо работы))

      по ходу фрилансер писал статью, а не специалист из сбера

      ну или так