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

  Опросы
  Статьи

Дата-центры  

Дата-центры: есть ли опасность утечки данных?

Российские компании уже несколько лет испытывают дефицит вычислительных мощностей. Рост числа проектов,

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

Книжная полка  

Защиты много не бывает

Среди книжных новинок издательства «БХВ» есть несколько изданий, посвященных методам социальной инженерии

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

Событие  

В банке рассола ждет сисадмина с полей фрактал-кукумбер

Читайте впечатления о слете ДСА 2024, рассказанные волонтером и участником слета

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

Организация бесперебойной работы  

Бесперебойная работа ИТ-инфраструктуры в режиме 24/7 Как обеспечить ее в нынешних условиях?

Год назад ИТ-компания «Крок» провела исследование «Ключевые тренды сервисного рынка 2023». Результаты

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

Книжная полка  

Читайте и познавайте мир технологий!

Издательство «БХВ» продолжает радовать выпуском интересных и полезных, к тому же прекрасно

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

СУБД PostgreSQL  

СУБД Postgres Pro

Сертификация по новым требованиям ФСТЭК и роль администратора без доступа к данным

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

Критическая инфраструктура  

КИИ для оператора связи. Готовы ли компании к повышению уровня кибербезопасности?

Похоже, что провайдеры и операторы связи начали забывать о требованиях законодательства

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

Архитектура ПО  

Архитектурные метрики. Качество архитектуры и способность системы к эволюционированию

Обычно соответствие программного продукта требованиям мы проверяем через скоуп вполне себе понятных

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

Как хорошо вы это знаете  

Что вам известно о разработках компании ARinteg?

Компания ARinteg (ООО «АРинтег») – системный интегратор на российском рынке ИБ –

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

Графические редакторы  

Рисование абстрактных гор в стиле Paper Cut

Векторный графический редактор Inkscape – яркий представитель той прослойки open source, с

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

День сисадмина  

Учите матчасть! Или как стать системным администратором

Лето – время не только отпусков, но и хорошая возможность определиться с профессией

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

День сисадмина  

Живой айтишник – это всегда движение. Остановка смерти подобна

Наши авторы рассказывают о своем опыте и дают советы начинающим системным администраторам.

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

Виртуализация  

Рынок решений для виртуализации

По данным «Обзора российского рынка инфраструктурного ПО и перспектив его развития», сделанного

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

Книжная полка  

Как стать креативным и востребованным

Издательский дом «Питер» предлагает новинки компьютерной литературы, а также книги по бизнесу

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

02.12.2013г.
Просмотров: 3090
Комментарии: 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