WikiDer > CICS
изначальный выпуск | 8 июля 1969 г. |
---|---|
Стабильный выпуск | Сервер транзакций CICS V5.6 / 12 июня 2020 г. |
Операционная система | z / OS, z / VSE |
Платформа | IBM System z |
Тип | Монитор телеобработки |
Лицензия | проприетарный |
Интернет сайт | www |
IBM CICS (Система управления информацией о клиенте) - это семейство серверов приложений на разных языках, которые обеспечивают онлайн-управление транзакциями и возможность подключения приложений на Мэйнфрейм IBM системы под z / OS и z / VSE.
Продукты семейства CICS разработаны как промежуточное ПО и поддержка быстрого, большого объема онлайн-обработка транзакций. CICS сделка - это единица обработки, инициированная одним запросом, который может затронуть один или несколько объектов.[1] Эта обработка обычно интерактивна (ориентирована на экран), но возможны фоновые транзакции.
Сервер транзакций CICS (CICS TS) стоит во главе семейства CICS и предоставляет услуги, расширяющие или заменяющие функции операционной системы. Эти службы могут быть более эффективными, чем общие службы операционной системы, а также более простыми для использования программистами, особенно в отношении связи с различными оконечными устройствами.
Приложения, разработанные для CICS, могут быть написаны на различных языки программирования и использовать предоставляемые CICS языковые расширения для взаимодействия с такими ресурсами, как файлы, подключения к базе данных, терминалы или для вызова таких функций, как веб-службы. CICS управляет всей транзакцией таким образом, чтобы в случае сбоя части транзакции по какой-либо причине все восстанавливаемые изменения можно было отменить.
Хотя CICS TS пользуется наибольшим авторитетом среди крупных финансовых организаций, таких как банки и страховые компании, многие Fortune 500 Сообщается, что компании и государственные учреждения используют CICS. Другие, более мелкие предприятия также могут использовать CICS TS и другие продукты семейства CICS. CICS регулярно можно найти за кулисами, например, в приложениях для банковских служащих, Банкомат системы, системы управления промышленным производством, страховые приложения и многие другие типы интерактивных приложений.
Последние усовершенствования CICS TS включают новые возможности для улучшения взаимодействия с разработчиками, включая выбор API, фреймворков, редакторов и инструментов сборки, и в то же время предоставляют обновления в ключевых областях безопасности, устойчивости и управления. В более ранних, последних выпусках CICS TS поддержка предоставлялась для Веб-сервисы и Ява, обработка событий, Атом кормит, и RESTful интерфейсы.
CICS TS для z / OS 5.6 был объявлено 7 апреля 2020 г. и стал общедоступным 12 июня 2020 г. Этот последний выпуск укрепил репутацию CICS TS как премиального сервера приложений IBM для смешанного языка.
История
CICS предшествовала более ранняя однопоточная система обработки транзакций, IBM MTCS. Позже был разработан «мост MTCS-CICS», позволяющий выполнять эти транзакции под CICS без изменения исходных прикладных программ.
CICS изначально был разработан в США в Центре разработки IBM в г. Дес-Плейнс, Иллинойс, начиная с 1966 г., чтобы удовлетворить требования предприятий коммунального хозяйства. Первый продукт CICS был анонсирован в 1968 году под названием Система управления информацией о клиентах коммунальных предприятий, или PU-CICS. Сразу стало ясно, что он применим во многих других отраслях, поэтому префикс Public Utility был упразднен с появлением первого выпуска CICS. Программный продукт 8 июля 1969 года, вскоре после IMS система управления базами данных.
В течение следующих нескольких лет CICS разрабатывался в Пало-Альто и считался менее важным «меньшим» продуктом, чем IMS, которую IBM тогда считала более стратегической. Однако давление со стороны покупателей поддерживало его. Когда в 1974 г. IBM решила прекратить разработку CICS и сосредоточиться на IMS, ответственность за разработку CICS взяла на себя Сайт IBM Hursley в Великобритании, которая только что прекратила работу над PL / I компилятор и поэтому знал многих тех же клиентов, что и CICS. Основная работа по развитию продолжается сегодня в Хёрсли, наряду с участием лабораторий Индии, Китая, России, Австралии и США.
Ранняя эволюция
Изначально CICS поддерживала только несколько устройств марки IBM, например 1965 г. IBM 2741 Терминал на базе пишущей машинки Selectric (мяч для гольфа). 1964 год IBM 2260 и 1972 г. IBM 3270 видеотерминалы широко использовались позже.
На заре мэйнфреймов IBM компьютерное программное обеспечение было бесплатным - бесплатно поставлялось в комплекте с компьютерное железо. В OS / 360 операционная система и программное обеспечение для поддержки приложений, такое как CICS, были «открыты» для клиентов IBM задолго до программное обеспечение с открытым исходным кодом инициатива. Такие корпорации, как Standard Oil of Indiana (Amoco), внесли значительный вклад в CICS.
Команда IBM Des Plaines попыталась добавить поддержку популярных терминалов сторонних производителей, таких как ASCII Телетайп Модель 33 ASR, но небольшая команда разработчиков программного обеспечения с низким бюджетом не могла позволить себе аппаратное обеспечение стоимостью 100 долларов в месяц для его тестирования. Руководители IBM ошибочно полагали, что будущее будет похоже на прошлое с пакетная обработка используя традиционные перфокарты.
IBM неохотно предоставляла минимальное финансирование, когда коммунальные предприятия, банки и компании, выпускающие кредитные карты, требовали рентабельной интерактивной системы (похожей на систему 1965 года). Программа IBM Airline Control используется American Airlines Сабля компьютерная система бронирования) для высокоскоростного доступа к данным и обновления информации о клиентах для их телефонных операторов (не дожидаясь появления систем перфокарт для обработки пакетов в ночное время).
Когда CICS был доставлен Amoco с поддержкой Teletype Model 33 ASR, это привело к сбою всей операционной системы OS / 360 (включая приложения, не относящиеся к CICS). Большая часть программы управления терминалами CICS (TCP - сердце CICS) и часть OS / 360 должны были быть тщательно переработаны и переписаны производственной компанией Amoco в Талсе, штат Оклахома. Затем он был возвращен IBM для бесплатного распространения среди других.
Через несколько лет,[когда?] CICS принесла IBM более 60 миллиардов долларов дохода от нового оборудования и стала их самым успешным программным продуктом для мэйнфреймов.
В 1972 году CICS был доступен в трех версиях - DOS-ENTRY (номер программы 5736-XX6) для DOS / 360 машины с очень ограниченной памятью, DOS-STANDARD (номер программы 5736-XX7), для машин DOS / 360 с большим объемом памяти, и OS-STANDARD V2 (номер программы 5734-XX7) для больших машин, на которых работает OS / 360.[2]
В начале 1970 года ряд первоначальных разработчиков, в том числе Бен Риггинс (главный архитектор ранних выпусков), переехали в Калифорнию и продолжили разработку CICS в IBM. Пало-Альто Центр развития. Руководители IBM не признавали ценность программного обеспечения как продукта, приносящего доход, до тех пор, пока федеральный закон не потребовал программного обеспечения разделение. В 1980 году руководители IBM не прислушались к убедительным предложениям Бена Риггинса о том, что IBM должна предоставить свои собственные EBCDIC-на основе операционной системы и интегральной схемы микропроцессор чип для использования в Персональный компьютер IBM как CICS интеллектуальный терминал (вместо несовместимого чипа Intel и незрелого ASCII-на основе Microsoft 1980 ДОС).
Из-за ограниченной производительности даже крупных процессоров той эпохи при каждой установке CICS требовалось собрать исходный код для всех системных модулей CICS после завершения процесса, аналогичного генерация системы (sysgen), называется CICSGEN, чтобы установить значения для условных операторов языка ассемблера. Этот процесс позволил каждому клиенту исключить поддержку со стороны самого CICS для любой функции, которую он не намеревался использовать, например, поддержки устройств для неиспользуемых типов терминалов.
CICS обязана своей ранней популярностью своей относительно эффективной реализации, когда оборудование было очень дорого, своей многопоточной архитектурой обработки, относительной простотой разработки приложений транзакций реального времени на основе терминала и многочисленными предложениями заказчиков с открытым исходным кодом, включая как отладку, так и функции. улучшение.
Обозначение Z
Часть CICS была формализована с использованием Обозначение Z в 1980-х и 1990-х годах в сотрудничестве с Вычислительная лаборатория Оксфордского университетапод руководством Тони Хоар. Эта работа выиграла Премия Королевы для технологических достижений.[3]
CICS как распределенный файловый сервер
В 1986 году IBM объявила о поддержке CICS для файловых сервисов, ориентированных на запись, определенных Распределенная архитектура управления данными (DDM). Это позволило программам на удаленных компьютерах, подключенных к сети, создавать файлы, управлять ими и обращаться к ним, которые ранее были доступны только в средах обработки транзакций CICS / MVS и CICS / VSE.[4]
В более новых версиях CICS удалена поддержка DDM. Поддержка компонента DDM в CICS z / OS была прекращена в конце 2003 года и удалена из CICS для z / OS в версии 5.2 и новее.[5] В CICS TS для z / VSE поддержка DDM была стабилизирована на уровне V1.1.1 с объявленным намерением прекратить ее поддержку в будущих версиях.[6] В CICS для z / VSE 2.1 и более поздних версий CICS / DDM не поддерживается.[7]
CICS и всемирная паутина
Сервер транзакций CICS впервые представил собственный HTTP интерфейс в версии 1.2, вместе с технологией Web Bridge для упаковки программ терминала с зеленым экраном в фасад HTML. API-интерфейсы CICS Web и Document были улучшены в CICS TS V1.3, чтобы можно было писать веб-приложения для более эффективного взаимодействия с веб-браузерами.
CICS TS версий с 2.1 по 2.3 был посвящен представлению CORBA и EJB технологии для CICS, предлагая новые способы интеграции ресурсов CICS в модели распределенных компонентов приложений. Эти технологии полагались на хостинг Ява приложения в CICS. Среда размещения Java претерпела многочисленные улучшения по сравнению с многими выпусками, что в конечном итоге привело к встраиванию Профиль WebSphere Liberty в сервер транзакций CICS V5.1. В CICS с использованием Java можно было разместить множество веб-технологий, что в конечном итоге привело к удалению встроенных технологий CORBA и EJB.
В CICS TS V3.1 добавлена собственная реализация МЫЛО и WSDL технологии для CICS вместе с клиентскими HTTP API для исходящей связи. Эти двойные технологии позволили упростить интеграцию компонентов CICS с другими корпоративными приложениями и получили широкое распространение. Были включены инструменты для использования традиционных программ CICS, написанных на таких языках, как КОБОЛи преобразование их в определенные WSDL веб-службы с небольшими изменениями программы или без них. Эта технология регулярно улучшалась по сравнению с последовательными выпусками CICS.
В CICS TS V4.1 и V4.2 были внесены дальнейшие улучшения в возможности веб-подключения, включая встроенную реализацию АТОМ протокол публикации.
Многие из новых веб-технологий были доступны для более ранних выпусков CICS с использованием моделей доставки, отличных от традиционного выпуска продукта. Это позволило первым пользователям предоставить конструктивную обратную связь, которая могла повлиять на окончательный дизайн интегрированной технологии. Примеры включают предварительную версию Soap для технологии CICS SupportPac для TS V2.2 или ATOM SupportPac для TS V3.1. Этот подход был использован для введения JSON поддержка CICS TS V4.2, технологии, которая впоследствии была интегрирована в CICS TS V5.2.
В JSON технология в CICS похожа на более раннюю МЫЛО технологии, которые позволяют программам, размещенным в CICS, обернуть современный фасад. В свою очередь, технология JSON была усовершенствована в z / OS Connect Enterprise Edition, продукте IBM для создания API-интерфейсов JSON, которые могут использовать ресурсы нескольких подсистем мэйнфреймов.
Многие партнерские продукты также использовались для взаимодействия с CICS. Популярные примеры включают использование шлюза транзакций CICS для подключения к CICS из JCA совместимые серверы приложений Java и устройства IBM DataPower для фильтрации веб-трафика до того, как он достигнет CICS.
Современные версии CICS предоставляют множество способов интеграции существующих и новых программных ресурсов в распределенные потоки приложений. Ресурсы CICS могут быть доступны из удаленных систем и могут иметь доступ к удаленным системам; идентификация пользователя и транзакционный контекст могут быть распространены; RESTful API можно составлять и управлять ими; устройства, пользователи и серверы могут взаимодействовать с CICS, используя стандартные технологии; а среда IBM WebSphere Liberty в CICS способствует быстрому внедрению новых технологий.
MicroCICS
К январю 1985 года основанная в 1969 году консалтинговая компания, разработавшая «массовые онлайн-системы» для отелей Hilton, FTD Florists, Amtrak, Budget Rent-a-Car, объявила, что стало MicroCICS.[8] Первоначальный акцент был сделан на IBM XT / 370 и IBM AT / 370.[9]
Семья CICS
Хотя когда упоминается CICS, люди обычно имеют в виду сервер транзакций CICS, Семья CICS относится к портфелю серверов транзакций, соединителей (называемых Шлюз транзакций CICS) и CICS Tools.
CICS на распределенных платформах, а не на мэйнфреймах называется IBM TXSeries. TXSeries - это промежуточное ПО для распределенной обработки транзакций. Он поддерживает приложения C, C ++, COBOL, Java ™ и PL / I в облачных средах и традиционных центрах обработки данных. TXSeries доступен на AIX, Linux x86, Windows, Солярис и HP-UX платформы.[10] CICS также доступен в других операционных системах, в частности IBM i и OS / 2. Реализация z / OS (т. Е. CICS Transaction Server для z / OS) на сегодняшний день является самой популярной и важной.
Две версии CICS ранее были доступны для ВМ / CMS, но с тех пор оба были сняты с производства. В 1986 году IBM выпустила CICS / CMS,[11][8] который был однопользовательской версией CICS, предназначенной для использования в разработке, приложения позже были перенесены в MVS или DOS / VS система производственного исполнения.[12][13] Позже, в 1988 году, IBM выпустила CICS / VM.[14][15] CICS / VM был предназначен для использования на IBM 9370мэйнфрейм низкого уровня, предназначенный для использования в отделах; IBM позиционирует CICS / VM, работающую на мэйнфреймах отделов или филиалов, для использования вместе с центральным мэйнфреймом, на котором работает CICS для MVS.[16]
Инструменты CICS
Инициализация, управление и анализ систем и приложений CICS обеспечивается CICS Tools. Это включает в себя управление производительностью, а также развертывание и управление ресурсами CICS. В 2015 году четыре основных базовых инструмента CICS (и пакет решений CICS Optimization Solution Pack для z / OS) были обновлены с выпуском CICS Transaction Server для z / OS 5.3. Четыре основных инструмента CICS: CICS Interdependency Analyzer для z / OS, CICS Deployment Assistant для z / OS, CICS Performance Analyzer для z / OS и CICS Configuration Manager для z / OS.
Программирование
Соображения по программированию
Многопользовательские прикладные программы с интерактивными транзакциями должны были быть квази-повторно въезжающий для поддержки нескольких одновременных сделка потоки. Ошибка программного кода в одном приложении может заблокировать доступ всех пользователей к системе. Модульная конструкция реентерабельных / многоразовых управляющих программ CICS означала, что при разумном «отсечении» несколько пользователей с несколькими приложениями могут быть запущены на компьютере с всего 32 КБ дорогих ресурсов. магнитный сердечник физическая память (в том числе Операционная система).
Программистам приложений CICS потребовались значительные усилия, чтобы сделать свои транзакции максимально эффективными. Распространенной техникой было ограничение размера отдельных программ не более чем 4096 байтами, или 4 КБ, чтобы CICS мог легко повторно использовать память, занятую любой программой, которая в настоящее время не используется, для другой программы или других потребностей в хранилище приложений. Когда виртуальная память был добавлен в версии OS / 360 в 1972 году, стратегия 4K стала еще более важной для сокращения пейджинг и взбучка непродуктивные накладные расходы из-за нехватки ресурсов.
Эффективность скомпилированных программ на языке COBOL и PL / I высокого уровня оставляла желать лучшего. Многие прикладные программы CICS продолжали писать на языке ассемблера даже после того, как стала доступна поддержка COBOL и PL / I.
Из-за того, что аппаратные ресурсы 1960-х и 1970-х были дорогими и дефицитными, среди аналитиков по оптимизации систем развивалась конкурентная «игра». Когда критический путь код был идентифицирован, фрагмент кода передавался от одного аналитика к другому. Каждый человек должен был либо (а) уменьшить количество требуемых байтов кода, либо (б) уменьшить количество ЦПУ требуется циклов. Молодые аналитики учились у более опытных наставников. В конце концов, когда никто не смог сделать (а) или (б), код сочли оптимизированным, и они перешли к другим фрагментам. Небольшие магазины с одним аналитиком изучали оптимизацию CICS очень медленно (или совсем не учились).
Поскольку прикладные программы могут использоваться многими одновременный потоки, использование статические переменные встроенные в программу (или использование памяти операционной системы) были ограничены (только по соглашению).
К сожалению, многие из «правил» часто нарушались, особенно программистами на COBOL, которые могли не понимать внутренности своих программ или не использовать необходимые ограничительные время компиляции опции. Это приводило к "невозвращающемуся" коду, который часто был ненадежным, что приводило к ложным нарушения хранения и вся система CICS дает сбой.
Первоначально весь раздел, или Множественное виртуальное хранилище (МВС), эксплуатируемые с той же ключ защиты памяти включая код ядра CICS. Повреждение программы и повреждение блока управления CICS были частой причиной простоя системы. Ошибка программного обеспечения в одной прикладной программе может привести к перезаписи памяти (кода или данных) одной или всех текущих транзакций приложения. Поиск проблемного кода приложения для сложных временных ошибок синхронизации может быть очень сложной проблемой для аналитика операционной системы.
Эти недостатки сохранялись для нескольких новых выпусков CICS на протяжении более 20 лет, несмотря на их серьезность и тот факт, что высококачественные навыки CICS пользовались большим спросом и были в дефиците. Они были адресованы в TS V3.3, V4.1 и V5.2 с функциями защиты хранилища, изоляции транзакций и подпространства соответственно, которые используют аппаратные функции операционной системы для защиты кода приложения и данных в одном адресном пространстве, даже если заявки не писались для разделения. Транзакции приложений CICS остаются критически важными для многих коммунальных предприятий, крупных банков и других многомиллиардных финансовых учреждений.
Кроме того, можно обеспечить меру расширенной защиты приложений, выполнив тестирование под управлением программы мониторинга, которая также обеспечивает функции тестирования и отладки.
Программирование на макроуровне
Когда CICS был впервые выпущен, он поддерживал только программы транзакций приложений, написанные на Ассемблер IBM 360. КОБОЛ и PL / I поддержка была добавлена спустя годы. Из-за первоначальной ориентации на ассемблер запросы на сервисы CICS выполнялись на языке ассемблера. макросы. Например, запрос на чтение записи из файла, сделанный вызовом макроса к «Программе управления файлами» CICS, может выглядеть следующим образом:
DFHFC TYPE = READ, DATASET = myfile, TYPOPER = UPDATE, .... и т. Д.
Это привело к появлению более поздней терминологии "Макроуровень CICS. "
Когда была добавлена поддержка языков высокого уровня, макросы были сохранены, а код был преобразован предварительным компилятором, который расширил макросы до их эквивалентов операторов COBOL или PL / I CALL. Таким образом готовится HLL приложение было фактически "двухэтапным" компилировать - вывод препроцессора подается в компилятор HLL в качестве ввода.
Соображения COBOL: в отличие от PL / I, IBM COBOL обычно не предусматривает манипуляции с указателями (адресами). Чтобы позволить программистам COBOL получить доступ к блокам управления CICS и динамической памяти, дизайнеры прибегли к тому, что, по сути, было взломом. КОБОЛ Раздел связи обычно использовался для межпрограммного взаимодействия, такого как передача параметров. Компилятор создает список адресов, каждый из которых называется Базовый локатор для связи (BLL), которые были установлены при входе в вызываемую программу. Первый BLL соответствует первому элементу в разделе «Связь» и так далее. CICS позволяет программисту обращаться к ним и манипулировать ими, передавая адрес списка в качестве первого аргумента программе. Затем BLL могут быть динамически установлены либо CICS, либо приложением, чтобы разрешить доступ к соответствующей структуре в разделе Linkage.[17]
Программирование на уровне команд
В течение 1980-х годов IBM в Hursley Park выпустила версию CICS, которая поддерживала то, что стало известно как «CICS командного уровня», которая по-прежнему поддерживала старые программы, но представила новый стиль API для прикладных программ.
Типичный вызов уровня команды может выглядеть следующим образом:
EXEC CICS ОТПРАВИТЬ MAPSET('ЛОСМАТТ') КАРТА(«ЛОСАТТ») END-EXEC
Значения, указанные в команде SEND MAPSET, соответствуют именам, используемым в первом макросе DFHMSD в определении карты, приведенном ниже для аргумента MAPSET, и макросе DFHMSI для аргумента MAP. Это предварительно обрабатывается этапом трансляции пакета перед компиляцией, который преобразует встроенные команды (EXEC) в операторы вызова подпрограммы-заглушки. Таким образом, подготовка прикладных программ к дальнейшему выполнению все еще требовала двух этапов. Можно было написать "Смешанный режим"приложения, использующие операторы макро-уровня и командного уровня.
Первоначально во время выполнения команды командного уровня были преобразованы с помощью транслятора времени выполнения, «Программа интерфейса EXEC», в старый вызов макроуровня, который затем выполнялся практически неизменными программами ядра CICS. Но когда ядро CICS было переписано для TS V3, EXEC CICS стал единственным способом программирования приложений CICS, поскольку многие из базовых интерфейсов были изменены.
Преобразование времени выполнения
В Только на уровне команд CICS, представленная в начале 1990-х годов, предлагала некоторые преимущества по сравнению с более ранними версиями CICS. Однако IBM также отказалась от поддержки прикладных программ макроуровня, написанных для более ранних версий. Это означало, что многие прикладные программы пришлось преобразовать или полностью переписать, чтобы использовать только команды EXEC на уровне команд.
К тому времени во всем мире, возможно, были миллионы программ, которые во многих случаях производились десятилетиями. Их переписывание часто приводит к появлению новых ошибок без обязательного добавления новых функций. Было значительное количество пользователей, которые запускали области, владеющие приложениями (AOR) CICS V2, чтобы продолжать выполнять макрокод в течение многих лет после перехода на V3.
Также было возможно запускать старые программы макроуровня с помощью программного обеспечения для преобразования, такого как APT International's Команда CICS.[18]
Новые стили программирования
Последние усовершенствования CICS Transaction Server включают поддержку ряда современных стилей программирования.
В CICS Transaction Server версии 2.1 появилась поддержка Java. Сервер транзакций CICS версии 2.2 поддерживает набор инструментов разработчика программного обеспечения. CICS предоставляет тот же контейнер времени выполнения, что и семейство продуктов IBM WebSphere, поэтому приложения EJB можно переносить между CICS и Websphere, а также есть общие инструменты для разработки и развертывания приложений EJB.
Кроме того, в более новых версиях CICS делается упор на «обертку» существующих прикладных программ внутри современных интерфейсов, чтобы давно установленные бизнес-функции могли быть включены в более современные сервисы. К ним относятся интерфейсы WSDL, SOAP и JSON, которые обертывают устаревший код, чтобы веб-приложение или мобильное приложение могло получать и обновлять основные бизнес-объекты, не требуя значительного переписывания внутренних функций.
Сделки
Транзакция CICS - это набор операций, которые вместе выполняют задачу. Обычно большинство транзакций представляют собой относительно простые задачи, такие как запрос инвентарного списка или ввод дебета или кредита на счет. Основной характеристикой транзакции является то, что она должна быть атомный. На IBM System z серверов, CICS легко поддерживает тысячи транзакций в секунду, что делает его основой корпоративных вычислений.
Приложения CICS содержат транзакции, которые могут быть записаны в различных языки программирования, включая COBOL, PL / I, C, C ++, язык ассемблера IBM Basic, REXX и Java.
Каждая программа CICS запускается с использованием идентификатора транзакции. Экраны CICS обычно отправляются в виде конструкции, называемой картой, модуля, созданного с помощью Базовая поддержка картографии (BMS) макросы ассемблера или сторонние инструменты. CICS экраны может содержать текст, который выделен, имеет разные цвета и / или мигает в зависимости от типа используемого терминала. Пример того, как карту можно отправить через COBOL, приведен ниже. Конечный пользователь вводит данные, которые становятся доступными для программы после получения карты от CICS.
EXEC CICS ПОЛУЧИТЬ MAPSET('ЛОСМАТТ') КАРТА(«ЛОСАТТ») В(НАША КАРТА) END-EXEC.
По техническим причинам аргументы некоторых параметров команды должны быть указаны в кавычках, а некоторые не должны указываться, в зависимости от того, на что делается ссылка. Большинство программистов будут писать код из справочника до тех пор, пока не получат «зависание» или концепцию цитируемых аргументов, или они обычно будут использовать «шаблонный шаблон», где у них есть пример кода, который они просто копируют и вставляют, а затем редактируют в изменить значения.
Пример кода карты BMS
Базовая поддержка отображения определяет формат экрана с помощью макросов ассемблера, таких как следующие. Это было собрано для генерации как набор физических карт - модуль загрузки в библиотеке загрузки CICS - и набор символических карт - определение структуры или DSECT в PL / I, COBOL, ассемблере и т. д., который был скопирован в исходную программу.[19]
ЛОСМАТТ DFHMSD ТИП=КАРТА, Икс РЕЖИМ=INOUT, Икс TIOAPFX=ДА, Икс СРОК=3270-2, Икс LANG=КОБОЛ, Икс MAPATTS=(ЦВЕТ,HILIGHT), Икс DSATTS=(ЦВЕТ,HILIGHT), Икс МЕСТО ХРАНЕНИЯ=АВТО, Икс CTRL=(FREEKB,FRSET) * ЛОСАТТ DFHMDI РАЗМЕР=(24,80), Икс ЛИНИЯ=1, Икс СТОЛБЕЦ=1 * LSSTDII DFHMDF POS=(1,01), Икс ДЛИНА=04, Икс ЦВЕТ=СИНИЙ, Икс ИСХОДНЫЙ="MQCM", Икс ATTRB=PROT * DFHMDF POS=(24,01), Икс ДЛИНА=79, Икс ЦВЕТ=СИНИЙ Икс ATTRB=ASKIP, Икс ИСХОДНЫЙ='PF7- 8-9-10- X 11- 12-ОТМЕНА' * DFHMSD ТИП=ФИНАЛЬНЫЙ КОНЕЦ
Структура
в z / OS среда, установка CICS включает один или несколько регионы (обычно именуемый «регион CICS»),[20] распространяться по одному или нескольким системным образам z / OS. Хотя он обрабатывает интерактивные транзакции, каждый регион CICS обычно запускается как пакетная обработка | пакетное адресное пространство со стандартным JCL операторы: это задание, которое выполняется бесконечно до выключения. Как вариант, каждый регион CICS может быть запущен как запущенная задача. Будь то пакетное задание или запущенная задача, регионы CICS могут работать в течение нескольких дней, недель или даже месяцев, прежде чем будут отключены для обслуживания (MVS или CICS). После перезапуска параметр определяет, должен ли запуск быть «холодным» (без восстановления) или «теплым» / «аварийным» (с использованием горячего завершения или перезапуска из журнала после сбоя). Холодный запуск больших регионов CICS с большим количеством ресурсов может занять много времени, поскольку все определения повторно обрабатываются.
Установки разделены на несколько адресных пространств по множеству причин, например:
- разделение приложений,
- разделение функций,
- избежание ограничений емкости рабочей нагрузки для одного региона, адресного пространства или экземпляра мэйнфрейма в случае z / OS SysPlex.
Типичная установка состоит из нескольких отдельных приложений, составляющих службу. У каждой службы обычно есть несколько «областей-владельцев терминалов» (TOR), которые направляют транзакции в несколько «областей-владельцев приложений» (AOR), хотя возможны и другие топологии. Например, AOR могут не выполнять файловый ввод-вывод. Вместо этого будет «область владения файлом» (FOR), которая будет выполнять файловый ввод-вывод от имени транзакций в AOR - учитывая, что в то время файл VSAM мог поддерживать только восстанавливаемый доступ на запись из одного адресного пространства в время.
Но не все приложения CICS используют VSAM в качестве основного источника данных (или исторически другого хранилища данных с единым адресом, например CA Datacom) - многие используют либо IMS / DB, либо Db2 в качестве базы данных, и / или MQ в качестве администратора очередей. Во всех этих случаях TOR могут балансировать нагрузку транзакций на наборы AOR, которые затем напрямую используют общие базы данных / очереди. CICS поддерживает двухфазную фиксацию XA между хранилищами данных, поэтому транзакции, охватывающие, например, MQ, VSAM / RLS и Db2, возможны со свойствами ACID.
CICS поддерживает распределенные транзакции с использованием протокола SNA LU6.2 между адресными пространствами, которые могут выполняться в одном или разных кластерах. Это позволяет обновлять ACID в нескольких хранилищах данных за счет взаимодействия распределенных приложений. На практике возникают проблемы с этим, если происходит сбой системы или связи, потому что обработка транзакции (возврат или фиксация) может быть сомнительной, если один из взаимодействующих узлов не восстановился. Таким образом, использование этих средств никогда не было очень распространенным.
Sysplex эксплуатация
Во времена CICS ESA V3.2, в начале 1990-х, IBM столкнулась с проблемой: как заставить CICS использовать новую zOS. Sysplex линия мэйнфреймов.
Sysplex должен был быть основан на CMOS (Дополнительный оксид металла кремния), а не существующие ECL (Эмиттерная логика) оборудование. Стоимость масштабирования ECL, уникального для мэйнфреймов, была намного выше, чем у CMOS, разработанной кэйрэцу с крупномасштабными сценариями использования, такими как Sony PlayStation, чтобы снизить удельную стоимость процессоров каждого поколения. ECL также был дорогостоящим для пользователей, потому что ток стока затвора произвел так много тепла, что ЦП пришлось поместить в специальный модуль, называемый модулем теплопроводности (TCM).[21]), которые имели поршни инертного газа и нуждались в водопроводе для подачи охлажденной воды большого объема. Но скорость процессора CMOS-технологии с воздушным охлаждением изначально была намного ниже, чем у ECL (особенно у производителей мэйнфреймов-клонов). Амдал и Hitachi). Это особенно беспокоило IBM в контексте CICS, поскольку почти все крупнейшие заказчики мэйнфреймов использовали CICS, и для многих из них это была основная рабочая нагрузка мэйнфреймов.
Чтобы достичь одинаковой общей пропускной способности транзакций на Sysplex, необходимо будет использовать несколько блоков параллельно для каждой рабочей нагрузки, но адресное пространство CICS из-за своей модели программирования полуреентерабельных приложений не может использовать более 1,5 процессоров на одном блоке при время - даже с использованием подзадач MVS. Без этого эти клиенты будут склонны переходить к конкурентам, а не к Sysplex, поскольку они наращивают рабочие нагрузки CICS. Внутри IBM были серьезные споры о том, будет ли правильным подходом отказаться от восходящей совместимости приложений и перейти к такой модели, как IMS / DC который был полностью реентерабельным, или для расширения подхода, принятого клиентами для более полного использования возможностей одного мэйнфрейма, - с использованием многорегиональной операции (MRO).
В конце концов, второй путь был выбран после того, как сообщество пользователей CICS было проконсультировано и решительно выступило против нарушения восходящей совместимости, учитывая, что в то время у них была перспектива проблемы 2000 года, с которой нужно бороться, и они не видели ценности в переписывании и тестировании миллионов строк в основном COBOL, PL / 1 или код ассемблера.
Рекомендуемая IBM структура для CICS на Sysplex заключалась в том, что на каждом узле Sysplex размещался по крайней мере один регион-владелец терминала CICS, который отправлял транзакции во многие регионы-владельцы приложений (AOR), распределенные по всему Sysplex. Если этим приложениям требовался доступ к общим ресурсам, они либо использовали хранилище данных, использующее Sysplex (например, Db2 или IMS / DB) или сконцентрировали, посредством доставки функций, запросы ресурсов в отдельные для каждого ресурса области владения ресурсами (ROR), включая области владения файлами (FOR) для VSAM и таблицы данных CICS, области владения очередями (QOR) для MQ, Переходные данные CICS (TD) и временное хранилище CICS (TS). Это позволило сохранить совместимость для унаследованных приложений за счет сложности эксплуатации многих регионов CICS и управления ими.
В последующих выпусках и версиях CICS могла использовать новые возможности использования Sysplex в VSAM / RLS,[22] MQ для zOS[23] и разместил свои собственные таблицы данных, ресурсы TD и TS в спроектированном диспетчере общих ресурсов для Sysplex -> Сцепное устройство или CF, без необходимости в большинстве ROR. CF обеспечивает отображение ресурсов, включая общую временную базу, буферные пулы, блокировки и счетчики с аппаратными средствами обмена сообщениями, что сделало совместное использование ресурсов в Sysplex более эффективным, чем опрос, и надежным (с использованием полусинхронизированного резервного CF для использования в случае отказ).
К этому времени в линейке CMOS были отдельные блоки, мощность которых превышала мощность, доступную самому быстрому блоку ECL с большим количеством процессоров на ЦП, и когда они были соединены вместе, 32 или более узлов могли бы масштабировать на два порядка больше общей мощности для разовая рабочая нагрузка. Например, к 2002 году Charles Schwab запускал «MetroPlex», состоящий из резервной пары его мэйнфреймов Sysplexes в двух местах в Фениксе, штат Аризона, каждый с 32 узлами, управляемыми одной общей рабочей нагрузкой CICS / DB / 2 для поддержки огромного объема предварительнодоткомовский пузырь запросы веб-клиента.
Эта более дешевая, гораздо более масштабируемая технологическая база CMOS, а также огромные инвестиционные затраты, связанные с необходимостью как перехода к 64-битной адресации, так и независимого создания клонированных функций CF, одного за другим вытеснили производителей клонов мэйнфреймов IBM.[24][25]
Восстановление / перезапуск CICS
Целью восстановления / перезапуска в CICS является минимизация и, если возможно, устранение ущерба, нанесенного онлайн-системе в случае сбоя, чтобы сохранить целостность системы и данных.[26] Если регион CICS был отключен вместо сбоя, он выполнит «теплый» запуск, используя контрольную точку, записанную при завершении работы. Область CICS также может быть принудительно запущена на «холодный» запуск, который перезагружает все определения и стирает журнал, оставляя ресурсы в том состоянии, в котором они находятся.
В рамках CICS следующие ресурсы считаются восстанавливаемыми. Если кто-то желает, чтобы эти ресурсы можно было восстановить, в соответствующих определениях CICS должны быть указаны специальные параметры:
- Файлы VSAM
- Таблицы данных, поддерживаемые CMT CICS
- Внутрираздельный TDQ
- Очередь временного хранилища во вспомогательной памяти
- Сообщения ввода-вывода из / в транзакции в сети VTAM
- Другие ресурсы базы данных / очередей, подключенные к CICS, которые поддерживают протокол двухфазной фиксации XA (например, IMS / DB, Db2, VSAM / RLS)
CICS также предлагает широкие возможности восстановления / перезапуска для пользователей, чтобы установить собственные возможности восстановления / перезапуска в своей системе CICS. Обычно используемые средства восстановления / перезапуска включают:
- Динамический откат транзакции (DTB)
- Автоматический перезапуск транзакции
- Восстановление ресурсов с использованием системного журнала
- Восстановление ресурсов с помощью журнала
- Перезагрузка системы
- Расширенное средство восстановления
Компоненты
Каждый регион CICS включает одну главную задачу, по которой выполняется каждая транзакция, хотя определенные службы, такие как доступ к Db2 данные используют другие задачи (TCB). Внутри региона транзакции совместная многозадачность - ожидается, что они будут вести себя хорошо и уступить ЦП, а не ждать. Сервисы CICS обрабатывают это автоматически.
Каждый уникальный CICS »Задача"или транзакции назначается собственная динамика объем памяти при запуске и последующие запросы на дополнительную память обрабатывались вызовом «программы управления памятью» (часть CICS ядро или "ядро"), что аналогично Операционная система.
Система CICS состоит из онлайн- ядро, пакетные программы поддержки и службы приложений.[27]
Ядро
Исходное ядро CICS состояло из ряда функциональных модулей, написанных на ассемблере 370 до V3.
- Программа управления задачами (KCP).
- Программа управления хранением (SCP).
- Программа управления программой (PCP).
- Программа управления прерыванием программы (PIP).
- Программа контроля интервалов (ICP).
- Программа управления дампом (DCP).
- Программа управления терминалами (TCP).
- Программа управления файлами (FCP).
- Программа управления переходными данными (TDP).
- Программа контроля временного хранения (TSP).
Начиная с версии V3, ядро CICS было переписано в структуру ядра и домена с использованием IBM PL / AS язык - который скомпилирован в ассемблер.
Предыдущая структура не требовала разделения функций и поэтому имела много межпрограммных зависимостей, которые приводили к ошибкам, если не был проведен исчерпывающий анализ кода. Новая структура была более модульной и устойчивой, потому что ее было легче изменить без каких-либо последствий. Первые домены часто строились с именем предыдущей программы, но без буквы «P» в конце. Например, домен управления программой (DFHPC) или переходный домен данных (DFHTD). Ядро работало как переключатель для междоменных запросов - изначально это оказалось дорогостоящим для часто вызываемых доменов (таких как Trace), но благодаря использованию макросов PL / AS эти вызовы были встроены без ущерба для дизайна отдельного домена.
В более поздних версиях были добавлены полностью переработанные домены, такие как домен регистрации DFHLG и домен транзакции DFHTM, которые заменили программу управления журналом (JCP).
Программы поддержки
В дополнение к онлайн-функциям CICS имеет несколько программ поддержки, которые запускаются как пакетные задания.[28] :стр.34–35
- Препроцессор языка высокого уровня (макро).
- Переводчик командного языка.
- Утилита дампа - печатает отформатированные дампы, созданные CICS Dump Management.
- Утилита трассировки - форматирует и печатает выходные данные трассировки CICS.
- Утилита форматирования журнала - печатает отформатированный дамп области CICS в случае ошибки.
Приложения услуги
Следующие компоненты CICS поддерживают разработку приложений.[28]:стр.35–37
- Базовая поддержка отображения (BMS) обеспечивает независимый от устройства ввод и вывод терминала.
- Поддержка APPC, обеспечивающая поддержку API LU6.1 и LU6.2 для совместной работы распределенных приложений, поддерживающих двухфазную фиксацию.
- Программа обмена данными (DIP) обеспечивает поддержку IBM 3770 и IBM 3790 программируемые устройства.
- 2260 Совместимость позволяет программам, написанным для IBM 2260 устройства отображения для работы на 3270 дисплеях.
- EXEC Interface Program - программа-заглушка, которая преобразует вызовы, сгенерированные
EXEC CICS
команды для вызовов функций CICS. - Встроенные функции - поиск по таблице, фонетическое преобразование, проверка полей, редактирование полей, проверка битов, форматирование ввода, взвешенное извлечение.
Произношение
В разных странах разное произношение[29]
- Внутри IBM (в частности Тиволи) он называется /ˈkɪks/.
- В США это чаще произносится, читая каждую букву /ˌsяˌаɪˌsяˈɛs/.
- В Австралии, Бельгии, Канаде, Гонконге, Великобритании и некоторых других странах произносится /ˈkɪks/.
- В Финляндии произносится [кикс]
- Во Франции произносится [se.i.se.ɛs].
- В Германии, Австрии и Венгрии произносится [ˈTsɪks] и, реже, [ˈKɪks].
- В Греции произносится кикс.
- В Индии произносится пинки.
- В Иране произносится пинки.
- В Израиле произносится C-I-C-S.
- В Италии произносится [ˈTʃiks].
- В Польше произносится [ˈKʲiks].
- В Португалии и Бразилии произносится [ˈSiks].
- В России произносится кикс.
- В Словении произносится кикс.
- В Испании произносится [ˈΘiks].
- В Швеции произносится пинки.
- В Израиле произносится пинки.
- В Уганде произносится пинки.
- В Турции произносится кикс.
Смотрите также
- IBM TXSeries (CICS на распределенных платформах)
- IBM WebSphere
- IBM 2741
- IBM 2260
- IBM 3270
- OS / 360
- VSAM
- z / TPF
использованная литература
- ^ Корпорация IBM. "Сервер транзакций CICS для z / OS, Версия 3.2 Глоссарий: T". Архивировано из оригинал 25 января 2013 г.. Получено 7 декабря, 2012.
- ^ Руководство по общей информации о системе управления информацией о клиентах (CICS) (PDF). Уайт-Плейнс, Нью-Йорк: IBM. Декабрь 1972 г. GH20-1028-3. Получено 2016-04-01.
- ^ Кинг, Стив (1993). «Использование Z в реструктуризации IBM CICS». В Hayes, Ян (ред.). Спецификации Примеры использования (2-е изд.). Нью-Йорк: Прентис-Холл. С. 202–213. ISBN 978-0-13-832544-2.
- ^ Уорнер, Эдвард (1987-02-23). «IBM предоставляет программам для ПК прямой доступ к мэйнфрейму: приложения для ПК могут изменять файлы». InfoWorld. 9 (8): 1. Получено 2016-04-01.
- ^ «IBM CICS Transaction Server для z / OS, V5.2 выводит гибкость обслуживания, операционную эффективность и поддержку облачных вычислений на новый уровень». IBM. 2014-04-07. Получено 2016-04-14.
CICS DDM больше не доступен от IBM, и поддержка была прекращена по состоянию на 31 декабря 2003 г. CICS DDM больше не доступен в CICS TS, начиная с версии 5.2.
- ^ "Центральные функции IBM z / VSE версии 9.2 - z / VSE версии 5.2". IBM. 7 апреля 2014 г.. Получено 2016-04-14.
Поддержка распределенного управления данными (DDM) CICS стабилизирована в CICS TS для VSE / ESA V1.1.1. В будущем выпуске CICS TS для z / VSE IBM намеревается прекратить поддержку CICS DDM.
- ^ «IBM CICS Transaction Server для z / VSE V2.1 обеспечивает усовершенствования для будущих рабочих нагрузок». IBM. 5 октября 2015 г.. Получено 2016-04-14.
Распределенное управление данными CICS (CICS / DDM) не поддерживается с CICS TS для z / VSE V2.1.
- ^ а б Пол Э. Шиндлер-младший (27 октября 1986 г.). «Unicorn делает ставку на то, что CICS проще и дешевле на ПК». Информационная неделя. С. 41–44.
- ^ «Единорог MicroCICS / RT». Computerworld. 9 декабря 1985 г. с. 98.
Семейство персональных компьютеров IBM XT / 370
- ^ «IBM Получите свой CICS». Системы среднего уровня. 10 ноября 1992 г. с. 35.
- ^ "объявлено .. Октябрь 1985 .. поставки начались только в июле этого года".
- ^ «CICS / CMS». IBM. Получено 2016-04-01.
- ^ «СИСТЕМА КОНТРОЛЯ ИНФОРМАЦИИ ДЛЯ КЛИЕНТОВ / СИСТЕМА КОНВЕРСАЦИОННОГО МОНИТОРА (CICS / CMS), ОБЪЯВЛЕННАЯ И ВЫПУСКАЕМАЯ НА ИЮНЬ 1986». IBM. 15 октября 1985 г.. Получено 2016-04-02.
- ^ "(CICS / VM) Система управления информацией о клиенте / Виртуальная машина". IBM. Получено 2016-04-01.
- ^ "СИСТЕМА УПРАВЛЕНИЯ ИНФОРМАЦИЕЙ КЛИЕНТА / ВИРТУАЛЬНАЯ МАШИНА (CICS / VM)". IBM. 20 октября 1987 г.. Получено 2016-04-02.
- ^ Бэбкок, Чарльз (2 ноября 1987 г.). «Обновление VM / SP упрощает миграцию». Computerworld. Vol. 21 нет. 44. IDG Enterprise. С. 25, 31. ISSN 0010-4841.
- ^ Корпорация IBM (1972 г.). Справочное руководство программиста системы управления информацией о клиентах (CICS) (PDF). Получено 4 января, 2016.
- ^ "Команда / CICS". IBM. Получено 22 апреля 2018.
- ^ Корпорация IBM. «Базовая поддержка картографии». Информационный центр CICS. Архивировано из оригинал на 2013-01-03.
- ^ IBM (13 сентября 2010 г.). «Глоссарий сервера транзакций CICS». Сервер транзакций CICS для z / OS V3.2. Информационный центр IBM, Боулдер, Колорадо. Архивировано из оригинал 1 сентября 2013 г.. Получено 12 декабря, 2010.
- ^ "Архивы IBM: модуль теплопроводности". www-03.ibm.com. 2003-01-23. Получено 2018-06-01.
- ^ «Контекст IMS». IMS. Чичестер, Великобритания: John Wiley & Sons, Ltd. 2009. стр. 1–39. Дои:10.1002 / 9780470750001.ch1. ISBN 9780470750001.
- ^ «Центр знаний IBM MQ для zOS». www.ibm.com. Получено 2018-06-01.
- ^ Виджаян, Джайкумар. «Амдал отказывается от бизнеса с мэйнфреймами». Computerworld. Получено 2018-06-01.
- ^ «Hitachi откажется от оборудования для мэйнфреймов, но будет сотрудничать с IBM над z Systems». Получено 2018-06-01.
- ^ «Центр знаний IBM». publib.boulder.ibm.com. Получено 22 апреля 2018.
- ^ Корпорация IBM (1975). Справочное руководство системного программиста системы управления информацией о клиентах (CICS) (PDF).
- ^ а б Корпорация IBM (1977). Система управления информацией о клиенте / виртуальное хранилище (CICS / VS) Версия 1, Выпуск 3 Введение в руководство по программной логике (PDF). Архивировано из оригинал (PDF) на 2011-02-17. Получено 2012-11-24.
- ^ «CICS - Введение» (PDF). Корпорация IBM. 8 июля 2004 г.. Получено 20 апреля, 2014.
внешняя ссылка
- Официальный сайт семейства IBM CICS
- Почему следует выбрать CICS Transaction Server для новых ИТ-проектов - Технический документ IBM CICS
- Официальный сайт 35-летия CICS
- Форум поддержки программирования CICS
- Сайт сообщества пользователей CICS для новостей, объявлений и обсуждений, связанных с CICS
- Сайт Боба Елавича, ориентированный на CICS. (Обратите внимание, что на этом сайте используются фреймы, но на экранах с высоким разрешением левый фрейм, содержащий индекс сайта, может быть скрыт. Прокрутите вправо внутри фрейма, чтобы увидеть его содержимое.) на Wayback Machine (архивировано 5 февраля 2005 г.)