CI/CD для 1С::Журнал СА 6.2017
www.samag.ru
Журнал «БИТ. Бизнес&Информационные технологии»      
Поиск   
              
 www.samag.ru    Web  0 товаров , сумма 0 руб.
E-mail
Пароль  
 Запомнить меня
Регистрация | Забыли пароль?
Журнал "Системный администратор"
Журнал «БИТ»
Подписка
Архив номеров
Где купить
Наука и технологии
Авторам
Рекламодателям
Контакты
   

  Опросы
1001 и 1 книга  
19.03.2018г.
Просмотров: 6831
Комментарии: 0
Машинное обучение с использованием библиотеки Н2О

 Читать далее...

12.03.2018г.
Просмотров: 7361
Комментарии: 0
Особенности киберпреступлений в России: инструменты нападения и защита информации

 Читать далее...

12.03.2018г.
Просмотров: 4612
Комментарии: 0
Глубокое обучение с точки зрения практика

 Читать далее...

12.03.2018г.
Просмотров: 3160
Комментарии: 0
Изучаем pandas

 Читать далее...

12.03.2018г.
Просмотров: 3965
Комментарии: 0
Программирование на языке Rust (Цветное издание)

 Читать далее...

19.12.2017г.
Просмотров: 3967
Комментарии: 0
Глубокое обучение

 Читать далее...

19.12.2017г.
Просмотров: 6470
Комментарии: 0
Анализ социальных медиа на Python

 Читать далее...

19.12.2017г.
Просмотров: 3312
Комментарии: 0
Основы блокчейна

 Читать далее...

19.12.2017г.
Просмотров: 3591
Комментарии: 0
Java 9. Полный обзор нововведений

 Читать далее...

16.02.2017г.
Просмотров: 7450
Комментарии: 0
Опоздавших не бывает, или книга о стеке

 Читать далее...

17.05.2016г.
Просмотров: 10814
Комментарии: 0
Теория вычислений для программистов

 Читать далее...

30.03.2015г.
Просмотров: 12527
Комментарии: 0
От математики к обобщенному программированию

 Читать далее...

18.02.2014г.
Просмотров: 14233
Комментарии: 0
Рецензия на книгу «Читаем Тьюринга»

 Читать далее...

13.02.2014г.
Просмотров: 9263
Комментарии: 0
Читайте, размышляйте, действуйте

 Читать далее...

12.02.2014г.
Просмотров: 7210
Комментарии: 0
Рисуем наши мысли

 Читать далее...

10.02.2014г.
Просмотров: 5518
Комментарии: 3
Страна в цифрах

 Читать далее...

18.12.2013г.
Просмотров: 4749
Комментарии: 0
Большие данные меняют нашу жизнь

 Читать далее...

18.12.2013г.
Просмотров: 3567
Комментарии: 0
Компьютерные технологии – корень зла для точки роста

 Читать далее...

04.12.2013г.
Просмотров: 3276
Комментарии: 0
Паутина в облаках

 Читать далее...

03.12.2013г.
Просмотров: 3508
Комментарии: 1
Рецензия на книгу «MongoDB в действии»

 Читать далее...

02.12.2013г.
Просмотров: 3163
Комментарии: 0
Не думай о минутах свысока

 Читать далее...

Друзья сайта  

 CI/CD для 1С

Архив номеров / 2017 / Выпуск №6 (175) / CI/CD для 1С

Рубрика: Разработка /  Изучаем «1С»

Олег Филиппов ОЛЕГ ФИЛИППОВ, АНТ-Информ, заместитель начальника отдела разработки, comol@mail.ru

CI/CD для 1С

Если вы хотите использовать лучшие практики, применяемые крупными командами при разработке на 1С, эта статья может оказаться весьма полезной

Заголовок этой статьи может оставить двоякое мнение: или совсем непонятно, о чем речь, или понятно, но не ясно при чем тут 1С. К сожалению, с терминологией CI/CD знакомы далеко не все, даже в среде разработчиков. Поэтому в первой части статьи будет немного теории по вопросам, что это такое и для чего оно нужно. Но сначала немного разберемся, почему на первый взгляд применительно к 1С процессы CI/CD кажутся неуместными:

  • Процесс сборки как таковой отсутствует.
  • Отсутствует возможность ветвления в «хранилище конфигураций», а также нет возможности использовать сторонние системы контроля версий.
  • 1С – это Windows-решение, тут нет никаких Docker или других удобных контейнеров.
  • 1С штатным образом не интегрируется с Jenkins, GitLabCI и им подобными.
  • 1С не является модульным решением, прикладное решение разрабатывается как целостное.

В этом, конечно, есть зерно истины – для 1С выгода от применения процессов CI/CD будет намного меньше, чем для команд разработки на традиционных языках программирования, особенно если эти команды разрабатывают приложения на C++/Python/Ruby, т.е. на языках программирования, приложения на которых трудно представить не модульными.

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

CI – Continuous Integration (непрерывная интеграция) – суть этого процесса заключается в том, что должна существовать единая среда, где постоянно объединяются все изменения команды разработчиков, которые они вносят в систему контроля версий. Да, кстати, система контроля версий при этом должна существовать. Если ее нет, то вообще непонятно, какведется разработка и как она управляется. Разработчик 1С, конечно, не может работать совместно с другим разработчиком над одним и тем же модулем. VCS, встроенная вплатформу, это запрещает. Но никто не запрещает иметь, к примеру, два хранилища (ну или три или более – по желанию), в которых будут отдельные ветки кода. В этом случае сервер сборок будет еще нужнее. В базе разработчика платформой 1С не гарантируется наличие всего кода, который в данный момент коммитят другие члены команды.

CD – Continuous Delivery (непрерывная доставка) – суть данного подхода заключается в том, что любые изменения, сделанные разработчиками в процессе работы над проектом, должны попадать к конечному пользователю максимально быстро и беспроблемно. Очень редко процессы Continuous Delivery рассматривают отдельно от процессов Continuous Integration. Часто даже сами разработчики путаются и представляют себе это как одно и то же: «я закоммитил изменение – оно должно протестироваться и успешно собраться – этоназывают CI/CD». На самом деле в рамках CD речь идет уже несколько дальше. Процессы CD должны обеспечить именно «доставку» ПО до конечного пользователя. Выражаясь русским языком, любая сборка, которая появилась на сервере сборок, должна иметь возможность тут же отправиться в Production, и в течение незначительного времени эту сборку получат все пользователи разрабатываемого ПО. При этом идеальный вариант, если пользователь даже не заметит, что у него уже новая версия данного программного продукта, и сбагами, обнаруженными в старой версии, он просто столкнуться не успел. Не вижу никаких причин не применять этот подход к 1С, особенно если речь идет о поддержке филиальной сети, распределенной информационной базы или чего-то в этом роде.

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

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

Классическая картинка, демонстрирующая, какие процессы входят в CI/CD, представлена на рис. 1.

Рисунок 1. Последовательность процессов CI/CD

Рисунок 1. Последовательность процессов CI/CD

Теперь давайте рассмотрим, какие из этих процессов применимы к 1С и как мы можем их автоматизировать на сервере сборок. Как правило, на практике CI/CD приобретают следующий вид:

  • Автоматическое получение всего кода системы после каждого коммита, а вернее даже сказать, перед коммитом.
  • Автоматическая проверка качества кода.
  • Автоматический Make исполняемых файлов. Сборка модулей проекта в единое решение.
  • Автоматический прогон тестов модулей (unit-тестов).
  • Развертывание окружения.
  • Автоматический прогон тестов в нужном окружении.
  • Автоматическое обновление ПО на рабочих станциях конечных пользователей.

Данные процессы планировались прежде всего для команд разработки на универсальных языках программирования, но это не значит, что они совсем не применимы к 1С. Нужно просто учитывать некоторую специфику. Фразы вроде «это не для 1С» или «у нас нет крупной разработки» в современном мире звучат больше как отговорки. Определенные трудности и потребность в адаптации даже не столько процессов, а средств их автоматизации – совсем не повод отказываться от Best Practice современных подходов к разработке иподдержке жизненного цикла ПО. Далее по каждому пункту разберемся отдельно.

Статью целиком читайте в журнале «Системный администратор», №6 за 2017 г. на страницах 52-55.

PDF-версию данного номера можно приобрести в нашем магазине.


  1. V8Reader. Средство разбора конфигурации 1С – http://infostart.ru/public/106310.
  2. https://github.com/oscript-library/tool1cd.
  3. Автоматизированная проверка конфигураций 1С – http://v8.1c.ru/acc.
  4. КопиПастаМер – https://infostart.ru/public/294285.
  5. SonarQube для 1С – https://github.com/silverbulleters/sonar-1c-bsl-public.
  6. ПО для юнит-тестирования для 1С – https://github.com/xDrivenDevelopment/xUnitFor1C.
  7. 1С сценарное тестирование – http://1c.ru/news/info.jsp?id=17985.
  8. Пример решения для развертывания 1С – https://www.youtube.com/watch?v=B8WAXWOv4IM&t=70s.

Комментарии
 
  24.01.2019 - 05:25 |  Dima84

Хорошая статья, спасибо. Мне еще понравились статьи "Почему настройка CI&CD является одним из главных приоритетов для IT компании" и "Список IT профессии и их роли в создании программного продукта (в разрезе CI & CD)" на портале LinuxTrainingCenter. В них очень доступно описан процесс Непрерывной интеграции и доставки CI & CD и роли IT профессии в CI&CD при разработке программы.

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

Добавить комментарий

Комментарии могут оставлять только зарегистрированные пользователи

               Copyright © Системный администратор

Яндекс.Метрика
Tel.: (499) 277-12-45
E-mail: sa@samag.ru