OpenFrame 구성

본 장에서는 OpenFrame의 아키텍처와 구성요소에 대해 기술한다.

1. OpenFrame 아키텍처

OpenFrame은 Mainframe 환경의 업무 시스템을 오픈 환경 플랫폼으로 전환하여 운용할 수 있도록 해주는 리호스팅 솔루션이다. 전환하려는 업무 애플리케이션의 성격에 따라 Online 업무와 Batch 업무로 구분이 된다. 전환 대상 업무에 맞추어 OpenFrame 솔루션도 Online 제품(OpenFrame OSC)과 Batch 제품(OpenFrame Batch)으로 구분되어 사용자에게 제공된다.

OpenFrame을 적용하면 Mainframe 시스템에서 요구하는 애플리케이션과 기존 데이터를 UNIX 환경에서 바로 운용할 수 있다. 또한 엔터프라이즈 미들웨어인 TP-Monitor Tmax, 웹 서버, WAS, Batch 솔루션, 프레임워크, APM, 보안, 그리고 스토리지 기술 등의 진보한 기술들과 서로 연동하여 사용할 수 있도록 설계되었다.

다음은 OpenFrame의 구성을 도식화한 그림이다.

figure 3 1
OpenFrame 구성도

2. OpenFrame 구성 요소

본 절에서는 OpenFrame 시스템을 사용하기 위한 제품군의 구성 요소에 대해서 설명한다.

2.1. OpenFrame Base

OpenFrame Base(이하 Base)는 OpenFrame 솔루션의 Online 제품(OpenFrame OSC, 이하 OSC)과 OpenFrame Batch(이하 Batch) 제품에서 공통으로 사용되는 모듈과 기반이 되는 서비스를 하나의 패키지로 묶은 제품이다. 따라서 Base 시스템은 Online 업무, Batch 업무에 상관없이 기본적으로 설치가 되어야 한다.

Base는 기존의 Mainframe에서 제공하던 OS 레벨의 자원과 서비스 제공는 시스템으로 UNIX 시스템에서 에뮬레이션하는 계층으로 생각할 수 있다.

Base 시스템은 Tmax 엔진, 데이터셋, 코드 페이지, 콘솔로 구성된다.

  • Tmax 엔진

    Tmax는 분산 환경 시스템에서 다른 기종 컴퓨터 간의 트랜잭션 처리를 보장하면서 부하를 분산시키고 에러가 발생할 때 적절한 조치를 담당하는 TP-Monitor 제품이다. 주요 기능은 프로세스 관리, 트랜잭션 관리, 부하 조절 및 장애 대책이다.

    OpenFrame 솔루션은 Tmax 엔진을 기반으로 개발되어 멀티 노드 클러스터링, 로드 밸런싱 및 Fail-Over 특성을 물려받아, 기존의 Mainframe에서 제공하던 고가용성과 안전성을 사용자에게 보장한다.

  • 데이터셋

    Mainframe에서는 OS 레벨에서 레코드 I/O 및 트랜잭션을 지원하는 다양한 종류의 데이터셋을 사용할 수 있다. 반면에 UNIX 파일 시스템에서는 기본적인 Block 단위의 Read/Write 기능만을 제공한다.

    Base 시스템에서는 자체적으로 보유하고 있는 관계형 데이터베이스 기술을 응용하여, Mainframe에서 제공하는 데이터셋 기능을 오픈 환경에서 제공하기 위해 데이터셋 모듈과 서비스를 제공한다.

  • 코드 페이지

    일반적으로 Mainframe에 저장된 사용자 데이터는 EBCDIC 코드 셋에 따라 저장되어 있다. 하지만 OpenFrame 솔루션은 오픈 환경의 표준인 ASCII 코드 셋에 따라서 사용자 데이터를 저장한다.

    따라서 Mainframe의 데이터를 오픈 환경으로 이관할 때, Mainframe과의 업무 연동을 위해 오픈 환경에서 Mainframe으로 데이터를 전송할 때, 코드 셋을 변환하는데 코드 셋 변환에 대한 Mapping 테이블로 코드 페이지를 관리해야 한다.

  • 콘솔

    시스템 콘솔 혹은 콘솔은 시스템 커널에서 시스템 관리자에게 메시지를 출력하고, 시스템 관리자가 시스템을 관리하는 명령을 입력할 수 있도록 해주는 화면과 키보드를 의미한다. Mainframe 관리자는 제공된 콘솔을 사용해서 시스템을 관리하고 운영한다.

    하지만 일부 Mainframe 시스템에서는 시스템 콘솔을 Mainframe 시스템을 관리하는 용도로만 사용하는 것이 아니라, 특정 업무 애플리케이션이 실행될 때 실시간으로 필요한 데이터를 애플리케이션에 직접 입력할 수 있는 창구 역할도 담당한다. OpenFrame에는 이러한 Mainframe의 콘솔 기능을 제공하기 위해 가상의 콘솔 인터페이스를 제공한다.

2.2. OpenFrame Batch

OpenFrame Batch(이하 Batch)는 리호스팅 솔루션인 OpenFrame을 구성하는 여러 제품들 중 하나로 Mainframe에서 구동하던 Batch 작업을 JCL이나 업무 로직 또는 데이터를 최소한으로 수정하여 저비용의 개방형 환경에서 운영할 수 있게 하는 제품이다.

Batch의 특징은 다음과 같다.

  • JCL과 Batch 애플리케이션의 코드 수정 불필요

    고객의 업무 로직을 변경하지 않고 Mainframe에서 실행되던 업무 프로그램을 그대로 오픈 시스템 환경에서 구동할 수 있다. JCL이나 업무 프로그램을 변경없이 사용할 수 있으므로 프로그램 재개발로 인한 위험 부담을 줄일 수 있다.

  • 다양한 UNIX 애플리케이션과의 연동 및 확장 용이

    UNIX 시스템에서 제공하는 다양한 애플리케이션 사용으로 새로운 Batch 작업 개발이 쉽다.

  • 여러 대의 UNIX 서버를 1개의 Batch 시스템처럼 사용하여 분산 처리 환경 구축 가능

    Batch 작업 증가로 인해 발생한 부하를 Tmax를 통해 분산시키거나 물리적인 서버 증설로 부하를 분산함으로써 문제를 해결한다.

    TP-Monitor인 Tmax를 기반 시스템으로 하여 개발된 OpenFrame은 데이터베이스 장애와 하드웨어 장애 등의 문제가 발생해도 탁월한 fail-over 기능으로 Batch 작업을 수행하는데 영향을 받지 않는다.

    Tmax 서버의 자동 감시를 통해 자동 복구 기능을 제공한다.

  • 각종 유틸리티 및 툴을 이용한 편리한 시스템 관리 기능 제공

    실제 전환 업무를 처리할 때 필요한 다양한 유틸리티 및 툴 지원과 유틸리티 개발을 위한 라이브러리를 제공한다. 기존 MVS JCL에서 사용되던 여러 가지 유틸리티 프로그램을 Batch 환경에서 실행할 수 있다.

다음은 Batch 시스템의 구성을 도식화한 그림이다.

figure 3 5
OpenFrame Batch 시스템 구성
  • TJES

    Mainframe의 JES에 대응하는 OpenFrame 시스템의 Batch JOB 관리 시스템이다. JCL을 통해 사용자로부터 JOB을 받아들이고, 이를 시스템의 자원상황에 맞추어 스케줄링 한 후 RUNNER를 통해 수행하고, JOB의 수행 결과를 프린트하고 조회하는 등 OpenFrame에서 일어나는 JOB에 관한 모든 수행을 관장한다.

  • UTILITY

    기존의 Mainframe에서 제공되었던 데이터셋 조작관련 유틸리티는 오픈 환경에서도 동일하게 제공하고 있으며, 이외에 Mainframe에서 사용되었던 3rd-Party 유틸리티도 기존과 동일하게 사용할 수 있도록 인터페이스를 제공하고 있다.

    JCL의 PGM에 기술되는 유틸리티는 해당 JOB을 전송했을 때 실제 Batch 작업을 실행하는 프로그램 요소이며, 기능에 따라 다양한 유틸리티를 제공한다.

  • TOOL

    Mainframe에서 사용되던 데이터셋이나 데이터베이스 등을 마이그레이션하는 과정에서나 OpenFrame 시스템을 운영하는 데 필요한 다양한 기능을 제공한다.

2.3. OpenFrame OSC

OpenFrame OSC(이하 OSC) 시스템은 OpenFrame의 Online에서 제공하는 시스템 타입 중에서 CICS를 리호스팅하는 시스템 타입이다. 트랜잭션 처리 미들웨어인 Tmax 기반 위에서 운영되므로, OSC 시스템을 이해하기 위해서는 Tmax 제품에 대한 이해도 함께 수행되어야 한다.

OSC 시스템은 기존 CICS에서 수행되던 트랜잭션 서비스들을 UNIX와 같은 개방형 환경에서 동일 또는 유사하게 제공한다. 이와 더불어, 기존 환경에서 개발된 각종 업무 프로그램들이 개방형 환경에서도 업무 로직 및 코드 수정없이 그대로 운영될 수 있도록 한다.

다음은 OSC의 개념을 기반으로 한 시스템의 특징이다.

  • 각 서버 프로세스는 최적의 환경에서 업무 처리

    OSC 애플리케이션 서버는 하나 이상의 프로세스로 구성된다. 따라서 클라이언트로부터 다수의 트랜잭션 요청을 받았을 때 프로세스 스케줄링 기능을 통해 최적의 업무 환경에서 트랜잭션 요청을 처리한다.

    업무 부하에 맞춰 자동으로 서버 프로세스 개수를 제어하여 효율적인 분산 처리가 가능하다.

  • 업무 요청에 대해 동시에 병렬적인 트랜잭션 처리 가능

    설정 파일, RTSD(Run-Time System Definition) 등의 기능으로 동일한 애플리케이션 서버의 모든 프로세스들이 동시에 같은 리소스 서비스 제공이 가능하다. 하나의 애플리케이션 서버와 보조 서버들은 Mainframe CICS에 있는 하나의 Region에 Mapping되어 둘 이상의 프로세스들로 구성되어 있더라도 동일한 설정, 리소스 설정 및 리소스 정의들을 내부적으로 관리한다.

  • CICS 업무 프로그램들이 업무 로직에 대한 변환 없이 OSC 애플리케이션 서버에 그대로 적용되어 작동 가능

    OSC 시스템은 기존 CICS 시스템에서 제공되던 리소스 서비스들을 Mainframe subsystem에 대응되는 OpenFrame 제품을 통해 동일 또는 유사하게 서비스를 제공한다.

    OSC 시스템은 기존 CICS에서 개발된 사용자 프로그램에 사용할 수 있도록 EXEC CICS, EXEC DLI 구문 및 CBLTDLI 함수를 제공한다. 또한 CICS나 IMS/DC 에서 제공하는 리소스를 변경없이 마이그레이션 할 수 있어 사용자는 기존에 작성한 사용자 업무 프로그램들을 간단한 마이그레이션 작업만으로도 오픈 시스템에서도 사용할 수 있다.

  • 각종 툴 및 유틸리티를 이용하여 편리한 시스템 관리 기능 제공

    TP-Monitor 시스템 관리 유틸리티 프로그램들을 함께 활용할 수 있다.

  • OpenFrame Manager/Online Manager를 통해 사용자 편의성을 갖춘 GUI 환경 제공

    OSC 시스템 로그 조회, 서비스 리소스 정의에 대한 생성, 조회 및 수정이 가능하다. OSC 서버 상태 또는 서버 정보 및 동적 터미널 정보 등 동적인 시스템의 상태 조회 서비스 기능을 제공한다.

    기존 Mainframe CICS Supplied Transaction에 대응되는 기능들을 GUI 환경에서 제공한다.

다음은 OSC 시스템의 구성을 도식화한 그림이다.

figure 3 3
OpenFrame OSC 시스템 구성

OSC의 특징과 각 서버에 대한 더 자세한 내용은 "OpenFrame OSC 운영자 안내서"를 참고한다.

2.4. OpenFrame TACF

IBM Mainframe의 RACF에 대응되는 제품으로 OpenFrame에서 인증 및 리소스에 대한 접근을 제어한다.

OpenFrame TACF(이하 TACF)의 특징은 다음과 같다.

  • 사용자 인증

    OpenFrame 시스템에 접근하는 사용자에 대해 적절한 사용자인지를 확인하는 과정으로 사용자 ID와 비밀번호를 필요로 하며, 인증에 실패한 사용자는 시스템과 시스템에서 제공하는 리소스에 접속할 수 없다.

  • 리소스 접근제어

    리소스 접근 리스트에 따라 사용자별로 특정 리소스에 대한 접근을 제어한다.

  • 리소스 접근에 대한 기록

    시스템 접속시간, 접근횟수, 접근한 리소스에 대한 통계정보를 기록하여 시스템 관리자가 각종 리소스 통계와 리소스의 보안 노출 정도를 확인할 수 있다.

TACF는 Tmax 클라이언트/서버 형태 및 API 라이브러리로 구성되어 있다.

다음은 TACF 동작과정에 대한 설명이다.

figure 3 4
OpenFrame TACF 동작과정

Resource Manager에게 특정 자원에 대한 접근이 이루어지면 Resource Manager는 해당 접근권한을 TACF Server에게 요청하게 되고 TACF Server는 정의된 접근권한을 TACF 데이터베이스에서 검색하여 해당 접근요청에 대한 가불을 Resource Manager에게 돌려준다. 따라서 개별적인 자원접근에 대한 통합적인 관리를 하게 된다.

2.5. OpenFrame GW

OpenFrame GW는 OpenFrame에서 접속된 다수의 TN3270E 애뮬레이터를 실시간으로 관리하고, 온라인 제품군과 애뮬레이터 사이에서 발생하는 데이터, 트랜잭션 및 터미널을 관리한다. OpenFrame GW는 WAS 위의 웹 서버로 구현되며, DB(Tibero)에는 현재 접속된 터미널, 기동되어 있는 Online Region들의 정보가 저장된다.

OpenFrame GW의 특징은 다음과 같다.

  • 터미널의 시작과 종료 및 접근 제어

    애플리케이션 프로그램을 통하여 터미널의 연결을 종료할 수 있으며 설정에 따라 터미널에 연결할 수 있다. 할당된 리소스에 따라 터미널의 연결을 제어한다.

  • 웹 터미널 사용

    OpenFrame GW에서 사용자에게 웹 터미널을 제공하며, 사용자는 웹 터미널을 통해서 OpenFrame GW 내부적으로 3270 데이터 프로토콜을 유지하며 3270프로토콜 애뮬레이터와 동일하게 사용 가능하다.

  • DB를 통한 리소스 공유

    사용 가능한 애플리케이션 서버와 이와 관련된 리소스들을 DB를 통하여 공유한다.

figure 3 6
OpenFrame GW 구성도

OpenFrame GW의 특징과 각 서버에 대한 자세한 내용은 “OpenFrame GW 운영자 안내서”를 참고한다.

2.6. OpenFrame Manager

OpenFrame Manager는 OpenFrame에서 일어나는 전반적인 작업들에 대한 개발, 제어, 관리, 분석을 담당한다. OpenFrame Manager는 Web 기반의 클라이언트와 Java로 개발된 서버로 구성된다.

Base, Batch, TACF, OSC에 대한 전반적인 제어와 관리, 모니터링을 담당하는 Common Manager, Batch Manager, TACF Manager, Online Manager으로 구성된다.

OpenFrame Manager의 특징은 다음과 같다.

  • OpenFrame을 위한 사용자 인터페이스

    OpenFrame을 운영하는 데 필요한 전반적인 사용자 인터페이스를 제공하기 위한 툴로 Web기반의 UI를 제공한다. 사용자는 UNIX 운영체제 또는 OpenFrame 시스템에 대한 충분한 이해없이도 사용자 입장에서 설계된 GUI 화면을 통해 친숙한 환경을 경험할 수 있다.

  • TACF 인증

    설정 파일의 인증 타입을 TACF로 설정할 경우 OpenFrame 자체 인증 시스템인 TACF와 연동하여 인증 기능을 사용할 수 있다. 이 경우 TACF 매니저를 통하여 개별 리소스에 대해 사용자마다 서로 다른 인증 권한을 등록할 수 있으므로 사용자에 맞게 권한을 제어할 수 있다.