Endevor - Endevor

Endevor это управление исходным кодом и управление выпуском инструмент для мэйнфреймы Бег z / OS.[1]Это часть семейства инструментов администрирования, созданных CA Technologies (ранее Computer Associates), который используется для поддержки программных приложений и отслеживания их версий.[2]

Слово ENDEVOR - это аббревиатура, которая первоначально означала Environment for Developers and Operations, но теперь является официальным названием продукта для флагманского мэйнфрейма CA Управление жизненным циклом приложений продукт контроля версий. Он также конкурирует с другим инструментом управления исходным кодом CA, Panvalet.

Управления источником

Endevor обеспечивает управление исходными и связанными объектами кода как отдельными элементами. Ссылочный «элемент» используется для определения наименьшего объекта, которым управляет Endevor. Стандартные функции управления версиями поддерживаются для управления элементами, включая ADD, UPDATE, DELETE, MOVE, TRANSFER, SIGNIN и SIGNOUT.

Функции элементов Endevor

Доступ к функциям Endevor можно получить в интерактивном режиме с помощью 3270 ISPF панелей или в пакетном режиме с помощью JCL и API Endevor. Многие функции, выполняемые в интерактивном режиме, выполняются в пакетном режиме. Все функции элементов Endevor описываются с использованием проприетарного Язык управления программным обеспечением.

Добавлять

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

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

Двигаться

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

Элемент может перемещаться только в течение заранее определенного жизненного цикла.

Удалить

Удаляет регистрацию целевого элемента и удаляет связанный источник элемента и загрузочные модули.

Передача

Перемещает элемент из любого исходного этапа в любой целевой этап. Функция ПЕРЕДАЧА используется для обхода заранее определенных жизненных циклов.

Генерировать

Сгенерируйте выходы. В случае программ это включает программный модуль / модули ЗАГРУЗКИ, DBRM и исходный код. GENERATE обычно выполняется сразу после ADD или UPDATE.

Контроль источника против контроля библиотеки вывода

Endevor отделяет управление источником от объектов, используемых в качестве входных, и объектов, создаваемых в качестве выходных, при выполнении действия. В большинстве случаев элемент хранится внутри Endevor как база кода, а последующие изменения сохраняются как дельты. Таким образом, управление исходным кодом происходит внутри Endevor, а действия в системе управления версиями отделены от изменений объектов в выходных библиотеках, которые включают модули загрузки и копии обработанного кода.

Библиотеки, контролируемые Endevor, защищены продуктом безопасности мэйнфреймов, таким как RACF или же АКФ. Приложение Endevor выполняет системные действия, используя две выделенные системные учетные записи, для которых есть доступ для записи в библиотеки, контролируемые Endevor. Как правило, обычным пользователям мэйнфреймов запрещено изменять библиотеки, управляемые Endevor. Это гарантирует, что единственный способ генерировать и продвигать код - через Endevor, и обеспечивает контрольный журнал всех изменений.

Библиотеки вывода, контролируемые Endevor, используются для хранения следующих типов объектов:

  • Источник элемента (обычно копия самой последней версии источника ввода, сохраненная для обеспечения прямого и легкого доступа с помощью стандартных инструментов мэйнфрейма)
  • Элементная база (обычно в виде зашифрованного имени файла)
  • Дельты элементов (обычно в виде зашифрованного имени файла)
  • Загрузить модули (скомпилированные исполняемые файлы)
  • DBRM модули (скомпилированные модули, содержащие операторы SQL и переменные, используемые программами)
  • Списки (подробный обзор действий, произошедших во время выполнения функций элемента)

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

Управление релизами

Endevor поддерживает управление выпусками, как определено ITIL в виде пакетного контроля. Для обеспечения безопасности пакетов доступны два варианта - собственная безопасность Endevor или Интерфейс внешней безопасности Endevor (ESI ).

Пакетный контроль

Endevor поддерживает управление выпусками в форме управления пакетами. Пакет - это контейнер для Endevor SCL и связанной с ним управляющей информации для выпуска кода. Как минимум, у пакета есть имя, окно выполнения, определяющее временной диапазон, когда пакет может быть выполнен, примечания о пакете, различные флаги и, по крайней мере, одно значение SCL.

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

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

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

Безопасность

Endevor Native Security

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

Каждая группа утверждающих может иметь до 16 идентификаторов пользователей. Первым ИД пользователя в группе утверждающих обычно всегда устанавливается ИД пользователя внутренней системы Endevor "NDVR", который предоставляет системе Endevor (пакетной) полномочия на выполнение действий пакета. Это связано с моделью безопасности в Endevor, для которой требуется явный безопасный доступ. Это означает, что если внутренний идентификатор пользователя системы Endevor не связан с одной из групп утверждающих при преобразовании пакета, то система Endevor (пакетная) не может выполнять команды для этого пакета.

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

Каждая группа утверждающих имеет установленный кворум, для которого можно установить значение от 0 до 16. Как правило, группа утверждающих имеет кворум 1, что означает, что по крайней мере один из пользователей, перечисленных в группе утверждающих, должен утвердить пакет, чтобы пакет для перехода в статус РАЗРЕШЕН. Кворум группы утверждающих, равный нулю, используется для групп утверждающих, где пользователи должны быть проинформированы о действиях пакета или пользователям требуется возможность ОТКАЗАТЬ пакет, но не требуется явно утверждать. Если к пакету присоединяется группа утверждающих с нулевым кворумом, состояние утверждения автоматически устанавливается на УТВЕРЖДЕНО для этой группы.

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

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

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

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

Таблицы безопасности Endevor

Таблицы безопасности представляют собой стандартные двоичные справочные таблицы, скомпилированные на ассемблере для мейнфреймов. Источником таблицы является стандартная таблица объявленных пар мэйнфреймов, скомпилированная (ASMA90) и связанная (IEWL) поисковая система ассемблера (CONSDEF, TYPE =, TABLE =, GROUP =, USERID =), которая хранится в библиотеке загрузки и упоминается как двоичный объект система безопасности Endevor, определенная в конфигурационном модуле C1DEFLTS. Обычно для каждой среды Endevor существует одна таблица безопасности, однако на одну таблицу безопасности могут ссылаться несколько сред. В этих таблицах определяется доступ к функциям Endevor при использовании собственной безопасности.

Таблица доступа к системе Endevor

Доступ к средам Endevor определяется одной таблицей безопасности для каждой среды Endevor. Эта таблица безопасности определяет списки контроля доступа определяется группами, к которым относятся пользователи, и перечисляет этапы, на которых пользователи могут взаимодействовать. Затем доступ может быть предоставлен одному или нескольким пользователям на основе идентификатора пользователя мэйнфрейма в качестве статического значения или использования $ в качестве подстановочного знака для «любого символа».

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

Каждая среда Endevor имеет детальную разбивку функций, специфичных для этой среды. Это контролирует возможность пользователей выполнять определенные функции SCM, такие как ДОБАВЛЕНИЕ, ОБНОВЛЕНИЕ, УДАЛЕНИЕ, ПЕРЕМЕЩЕНИЕ.

Компиляция и ссылка на таблицу безопасности Endevor

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

Выходы

Администраторы Endevor могут изменять функции Endevor и собирать информацию с помощью программ выхода. Существует несколько типов выхода, каждый из которых привязан к определенной функции Endevor. Выходы обычно пишутся как программы COBOL или Assembler, но теоретически могут быть любым языком, который можно скомпилировать и связать на z / OS. Выход будет указывать, где в дереве выхода будет выполняться код и что будет затронуто.

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

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

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

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

Процессоров

Основные функции элементов Endevor, включая GENERATE DELETE и MOVE, выполняют программы, написанные на специальном языке Endevor, подобном JCL, для выполнения функций SCL, таких как перемещение исходного кода и загрузка модулей.

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

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

Если процессор не определен для типа / группы процессоров / функции, генерирующий удаление или перемещение, вызывается процессор по умолчанию. Процесс по умолчанию перемещает объекты BASE, DELTA и SOURCE OUTPUT LIBRARY из исходных библиотек в целевые библиотеки, как определено элементом TYPE.

Типы элементов

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

Пример определения Endevor TYPE для объектов COBOL. В этом примере тип COBOL в среде TEST.

ДИСПЛЕЙ ---------------------- ОПРЕДЕЛЕНИЕ ТИПА ------------------------- ----- КОМАНДА ===>
ТЕКУЩАЯ ENV: ИД СТАДИИ ТЕСТА: T СИСТЕМА: ТИП ФИНАНСИРОВАНИЯ: COBOLNEXT ENV: ИД СТАДИИ PROD: P СИСТЕМА: ТИП ФИНАНСИРОВАНИЯ: COBOL
ОПИСАНИЕ: COBOL II ОБНОВЛЕНО: 02JAN03 08:42 NDVADM ----------------- ОПЦИИ ЭЛЕМЕНТА ------------------- ВПЕРЕД / REV / IMG DELTA: F (F / R / I) COMPRESS BASE / ENCRYPT NAME: Y (Y / N) DFLT PROC GRP: COBOL REGRESSION PCT: 75 REGR SEV: C (I / W / C / E) SOURCE LENGTH : 80 СРАВНИТЬ С: 1 СРАВНИТЬ С: 72 AUTO CONSOL: Y (Y / N) LANGUAGE: COBOL PV / LB LANG: COBCONSOL AT LVL: 95 HFS RECFM: NL (COMP / CR / CRLF / CRNL / F / LF / NL / V) LVLS TO CONSOL: 40 ФОРМАТ ДАННЫХ: T FILE EXT: ------------- ОПЦИИ СПИСКА КОМПОНЕНТОВ ---------------- ДЕЛЬТА ВПЕРЕД / НАЗАД : F (F / R) AUTO CONSOL: Y (Y / N) CONSOL AT LVL: 96 LVLS TO CONSOL: 50 -------------------- БИБЛИОТЕКИ --- ------------------ БИБЛИОТЕКА БАЗЫ / ИЗОБРАЖЕНИЙ: NDVR. & C1ST..BASE.SORCLIB ДЕЛЬТА-БИБЛИОТЕКА: NDVr. & C1ST..DELTA.COBOL ВКЛЮЧАЕТ БИБЛИОТЕКУ: ИСТОЧНИК ИЛИ БИБЛИОТЕКА : NDVR. & C1ST..SORCLIB EXPAND ВКЛЮЧАЕТ: НЕТ (ДА / НЕТ)

В показанном примере объекты, связанные с кодом, в библиотеке BASE, библиотеке DELTA и библиотеке SOURCE Output обрабатываются системой Endevor, а не процессором. Система использует эти значения для определения исходного и целевого местоположений.

Типы, контролируемые Endevor, обычно включают COBOL, Assembler, JCL, REXX, панели ISPF, скелеты ISPF и parms. Таким образом Endevor можно настроить для обработки большинства файлов мэйнфреймов.

Рекомендации

  1. ^ «Описание продукта - CA Endevor® Software Change Manager, версия 15.1» (PDF). ca Технологии. Получено 15 мая 2013.
  2. ^ PCmag.com

Расширения

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

ПрограммаЦель
Быстрое редактированиеАвтономная программа для ускорения процесса извлечения, извлечения и возврата элементов
HarwebВеб-интерфейс среднего уровня для информации и функций Endevor
ACMАвтоматическое управление конфигурацией, расширяющее информацию о компонентах элементов Endevor.

Разделение окружающей среды

Endevor предоставляет несколько методов для установки и доступа к отдельным отдельным экземплярам Endevor, которые установлены на одном LPAR. Как правило, устанавливается и используется одна версия Endevor на LPAR.

Конкурирующие продукты

Такие же функции для управления версиями и управления выпусками предоставляются несколькими другими продуктами.

Интеграция с другими инструментами

Endevor интегрируется с RDz (Rational Developer для System z). Разработчики могут кодировать в RDz IDE и легко взаимодействовать с Endevor своими кодами. Нажмите здесь для подробностей.

внешняя ссылка