Для отображения персонализированного контента и рекламных сообщений, а также хранения личных настроек на локальном компьютере веб-сайт www.rdn-grp.ru используют технологию cookie и аналогичные. Продолжив использование наших веб-сайтов, Вы даете согласие на обработку персональных данных, выражаете согласие с Политикой конфиденциальности www.rdn-grp.ru и применением этих технологий.
Москва, Большая Черемушкинская 34, лофт «Микроэкономика», 6 этаж

CI/CD в два клика и без простоев


Привет, меня зовут Андрей Коненко, я девопс-инженер RDN Group

Наша команда специализируется на разработке сложных и высоконагруженных решений для промышленных компаний: личных кабинетах, торговых площадках, порталах и интеграционных проектах. RDN Group один из 30 партнеров 1С-Битрикс с расширенной компетенцией крупные корпоративные внедрения Enterprise. 

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

Скорость и качество создания продукта - ключевые элементы успеха в разработке программного обеспечения, что делает их основными факторами конкуренции. В связи с этим, устаревшие модели разработки, такие как императивные, структурные и модульные, заменены более новой моделью CI/CD (непрерывная интеграция / непрерывное развертывание).

CI/CD - это процесс непрерывной интеграции и непрерывной доставки продукта.

Концепция CI/CD относится к гибким методологиям разработки ПО и ориентирована на внимание к бизнес-требованиям и безопасности, а также на обеспечение высокого качества конечного продукта. Этот подход включает в себя:

  • Автоматизацию процессов сборки, упаковки и тестирования программного обеспечения.

  • Автоматическое развертывание приложения в разных окружениях (например, на тестовых, промежуточных и продуктовых серверах).

  • Минимизацию ошибок и уязвимостей в программном продукте путем постоянной проверки и корректировки кода.

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

Основными принципами CI/CD являются: 

  • разделение ответственности за различные этапы процесса, минимизация рисков на каждом этапе жизненного цикла продукта, 

  • сокращение времени обратной связи за счет автоматизации, 

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

Преимущества CI/CD

  • Повышение скорости разработки: разработчики могут быстрее тестировать и вводить изменения в продукт. 

  • Качество тестирования: возможность выявлять ошибки на ранней стадии разработки. 

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

Под непрерывной интеграцией, мы понимаем развертывание кода в тестовых системах. 

Под непрерывной доставкой мы понимаем  доставку приложения до продукта. (максимально упрощая: написал- отправил в репозиторий, все само собралось, автоматически  протестировалось, установилось).

Из чего состоит CI/CD?

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

  • Автоматизированные инструменты развертывания

  • GitLab (инструмент для автоматизации процессов тестирования, развертывания и мониторинга проектов).

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


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

Как проходит процесс CI/CD 

  1. Необходимо забрать из репозитория код и переместить на тестовый сервер. 

  2. Выполнить сборку приложения, если оно того требует.

  3. Запустить автоматизированное тестирование, если приложение собралось без ошибок.

  4. Если все три пункта прошли успешно, тогда первые 2 пункта разворачиваем для продуктовой среды. 

Картинка: процесс CI/CD

Однако не все так просто, дьявол кроется в деталях. 

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

Рассмотрим несколько проблем с которыми можно столкнуться в процессе работы. 

Проблема №1.  

При развертывании произошел сбой сервера - сервис недоступен или работает с ошибкой.

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

В классическом случае, откат из резервной копии, здесь мы получаем неправильно выстроенный процесс CI/CD.

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

Уходим на точку балансировки нагрузки - перебалансируем нагрузку со старого продуктового сервера на новый. 

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

Проблема № 2. 

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

Это связано с тем, что разработчик постоянно обновляет свое приложение и в какой то момент алгоритмы CI/CD могут устареть . Девопс разработчики должны быть постоянно вовлечены в процессы поддержки и обновления  CI/CD- эти процессы должны быть частью приложения.

Решение: 

  1. Необходимо вести документацию по развертыванию приложения и поддерживать ее в актуальном состоянии. 

  2. Девопс инженер занимается обслуживанием серверного ПО и поддерживает его актуальном состоянии. 

Проблема №3

Организация алгоритмов.

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

Тестовая ветвь, в которой производятся изменения проходит CI/CD. Иногда процессы CI/CD организовываются таким образом, что при успешном их прохождении изменения переносятся в продукт автоматически, а из-за неучтенных нюансов возникает ошибка, и сервер перестает работать. 

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

Кто подключен к процессу разработки CI/CD?

Девопс- единоличный организатор всей концепции. 

ТимЛид- управляет всеми процессами, чаще взаимодействует с заказчиком, ставит задачи девопсу, собирает концепцию приложения воедино.

Менеджер проекта- ведет учет затрат .

Что нужно сделать, чтобы настроить CI/CD?

  • спланировать все процессы, которые будут происходить в разрезе развертывания приложения,

  • спланировать развертывание приложения,

  • организовать тестирование приложения,

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

  • выбрать целевую архитектуру,

  • подобрать инструменты,

  • приступить к реализации. 

Инструменты для CI/CD

  1. GitLab - платформа для управления репозиториями, документирования результатов тестирования и разработки, анализа и улучшения функциональности проекта, выявления и исправления ошибок.

  2. Docker - CD-система для контейнеризации проекта.

  3. Travis-CI - сервер, который подключается к виртуальным GitHub-репозиториям с минимальными настройками и не требует отдельной установки.

  4. Jenkins - совместим с различными плагинами для адаптации к различным проектам и задачам.

  5. PHP Censor - CI-сервер для автоматизации сборки PHP-проектов, может работать с репозиториями GitLab, Mercurial и др., с тестовыми библиотеками Atoum, PHP Spec, Behat.

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

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

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

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

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

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

Таким образом, концепция CI/CD помогает разработчикам мгновенного вносить изменения, непрерывно тестировать и совершенствовать продукт, а также взаимодействия не только между собой, но и с заказчиком. 

#CI/CD

Статьи на тему

Как мы можем помочь вашему бизнесу?

Оставить заявку
Рассчитать стоимость проекта

Остались вопросы?

Обратный звонок
Остались вопросы? Мы перезвоним вам и поможем!