Solaris OS용 Sun Cluster 데이터 서비스 개발 안내서

Agent Builder 사용

이 절에서는 Agent Builder 사용 전에 완료해야 할 작업을 포함하여 Agent Builder 사용 방법에 대해 설명합니다. 또한 이 절에서는 자원 유형 코드를 생성한 후의 Agent Builder 이용 방법에 대해서도 설명합니다.

이 장은 다음 내용으로 구성되어 있습니다.

응용 프로그램 분석

Agent Builder를 사용하려면 먼저 응용 프로그램이 가용성 또는 확장성이 뛰어난 응용 프로그램이 되기 위한 기준을 충족시키는지 확인해야 합니다. Agent Builder에서는 응용 프로그램의 런타임 특성만을 토대로 분석을 하므로 이러한 분석을 수행할 수 없습니다. 이에 대한 자세한 내용은 응용 프로그램 적합성 분석을 참조하십시오.

Agent Builder는 개발자 응용 프로그램에 대해 항상 전체 자원 유형을 생성할 수 있는 것은 아니지만 대부분의 경우 적어도 부분적인 솔루션을 제공합니다. 예를 들어, 보다 복잡한 응용 프로그램에는 Agent Builder에서 기본적으로 생성하지 않는 추가 코드가 필요 할 수 있습니다. 이러한 코드에는 추가 등록 정보에 대한 검증 확인을 추가하는 코드, Agent Builder에서 제공하지 않는 매개 변수를 조정하는 코드 등이 포함됩니다. 이런 경우 생성된 소스 코드나 RTR 파일을 변경해야 합니다. Agent Builder는 이런 종류의 융통성을 제공할 수 있도록 설계되었습니다.

Agent Builder는 생성된 소스 코드의 특정 지점에 사용자 정의 자원 유형 코드를 추가할 수 있는 주석을 배치합니다. 소스 코드를 변경한 후 Agent Builder에서 생성한 makefile을 사용하여 소스 코드를 다시 컴파일하고 자원 유형 패키지를 다시 생성할 수 있습니다.

Agent Builder에서 생성한 코드를 사용하지 않고 전체 자원 유형 코드를 작성한 경우라도 Agent Builder에서 제공한 makefile 및 구조를 이용하여 자원 유형에 대한 Solaris 패키지를 만들 수 있습니다.

Agent Builder 설치 및 구성

Agent Builder에는 특수 설치가 필요하지 않습니다. Agent Builder는 기본적으로 표준 Sun Cluster 소프트웨어 설치 중에 설치되는 SUNWscdev 패키지에 포함되어 있습니다. 자세한 내용은 Solaris OS용 Sun Cluster 소프트웨어 설치 안내서를 참조하십시오.

Agent Builder를 사용하기 전에 다음 요구 사항을 확인하십시오.


주 –

표준 cc 컴파일러가 아닌 다른 컴파일러를 Agent Builder와 함께 사용할 수 있습니다. 다른 컴파일러를 사용하려면 cc에서 gcc 등 다른 컴파일러로의 심볼릭 링크를 $PATH에 만듭니다. 또는 makefile(현재 CC=cc)의 컴파일러 지정을 다른 컴파일러의 전체 경로로 변경합니다. 예를 들어, Agent Builder에서 생성한 makefile에서 CC=cc CC=pathname/gcc로 변경합니다. 이 경우 Agent Builder를 직접 실행할 수 없으며 데이터 서비스 코드와 패키지를 생성하려면 makemake pkg 명령을 사용해야 합니다.


Agent Builder 화면

Agent Builder는 단계별로 해당 화면이 있는 2단계 마법사입니다. Agent Builder에서는 새로운 자원 유형 작성 프로세스를 안내하는 다음 두 개의 화면을 제공합니다.

  1. Create 화면. 이 화면에서 만들려는 자원 유형에 대한 기본 정보(예: 이름, 생성된 파일의 작업 디렉토리 등)를 제공합니다. 작업 디렉토리는 자원 유형 템플리트를 만들고 구성하는 위치입니다. 또한 다음 정보를 지정합니다.

    • 만들려는 자원의 종류(확장 가능 또는 페일오버)

    • 기본 응용 프로그램이 네트워크를 인식하는지 여부(즉, 네트워크를 사용하여 클라이언트와 통신하는지 여부)

    • 생성할 코드 유형(C, Korn 쉘(ksh) 또는 GDS)

    GDS에 대한 자세한 내용은 10 장, 일반 데이터 서비스를 참조하십시오. 이 화면에서 모든 정보를 제공하고 Create를 선택하여 해당 출력을 생성해야 합니다. 그런 다음 구성 화면을 표시할 수 있습니다.

  2. Configure 화면. 이 화면에서 UNIX 쉘에 전달될 수 있는 전체 명령줄을 지정하여 기본 응용 프로그램을 시작해야 합니다. 또는 응용 프로그램을 중지 및 검사하기 위한 명령을 제공할 수 있습니다. 이러한 명령을 지정하지 않으면 생성된 출력은 신호를 사용하여 응용 프로그램을 중지하고 기본 검사 기법을 제공합니다. 검사 명령에 대한 자세한 내용은 Configure 화면 사용을 참조하십시오. Configure 화면을 사용하여 시작, 중지, 검사 명령의 각 시간 초과값도 변경할 수 있습니다.

Agent Builder 시작


주 –

Agent Builder의 GUI 버전에 액세스할 수 없는 경우 명령줄 인터페이스를 통해 Agent Builder에 액세스할 수 있습니다. Agent Builder 명령줄 버전 사용 방법을 참조하십시오.


기존 자원 유형의 작업 디렉토리에서 Agent Builder를 시작하면 Agent Builder에서 Create 및 Configure 화면을 기존 자원 유형 값으로 초기화합니다.

다음 명령을 입력하여 Agent Builder를 시작합니다.


% /usr/cluster/bin/scdsbuilder

Create 화면이 나타납니다.

그림 9–1 Agent Builder의 Create 화면

주 Agent Builder 화면을 표시하는 SunPlex Agent Builder라는 대화 상자

Agent Builder 탐색

다음 작업을 수행하여 Create 및 Configure 화면에 대한 정보를 입력합니다.

각 화면 아래 있는 버튼을 사용하면 작업을 완료하거나, 다음이나 이전 화면으로 이동하거나, Agent Builder를 종료할 수 있습니다. Agent Builder는 이러한 버튼을 필요에 따라 강조표시하거나 비활성화합니다.

예를 들어, Create 화면에서 필드를 입력하고 원하는 옵션을 선택한 경우 화면 아래쪽에 있는 Create를 누릅니다. 이전 화면이 없고 이 단계를 완료하기 전에는 다음 단계로 이동할 수 없기 때문에 Previous 및 Next는 비활성화됩니다.

Create, Previous, Next 및 Cancel 명령을 표시하는 화면 아래쪽 패널

Agent Builder는 화면 아래쪽에 있는 Output Log 영역에 진행 메시지를 표시합니다. Agent Builder가 완료되면 성공 메시지 또는 경고 메시지를 표시합니다. Next가 강조 표시됩니다. 마지막 화면인 경우에는 Cancel만 강조 표시됩니다.

언제든지 Cancel을 눌러 Agent Builder를 종료할 수 있습니다.

Browse 명령

특정 Agent Builder 필드를 사용하여 정보를 입력하거나 Browse를 눌러 디렉토리 구조를 찾아보고 파일이나 디렉토리를 선택할 수 있습니다.

Browse 명령

Browse를 누르면 다음 화면과 유사한 화면이 나타납니다.

파일 목록을 표시하는 Browse 화면

폴더를 두 번 눌러 폴더를 엽니다. 커서를 파일로 이동하면 파일 이름이 File Name 상자에 표시됩니다. 원하는 파일을 찾아서 커서를 이동한 다음 Select를 누릅니다.


주 –

디렉토리를 찾으려면 커서를 원하는 디렉토리로 이동하고 Open을 누릅니다. 디렉토리에 하위 디렉토리가 없으면 Agent Builder에서 Browse 창을 닫고 커서를 이동한 디렉토리 이름을 해당 필드에 넣습니다. 디렉토리에 하위 디렉토리가 있는 경우 Close를 눌러 찾아보기 창을 닫고 이전 화면을 다시 표시합니다. Agent Builder에서 커서를 이동한 디렉토리 이름을 해당 필드에 넣습니다.


Browse 화면의 오른쪽 위에 있는 아이콘은 다음 작업을 수행합니다.

아이콘 

목적 

위쪽 화살표를 표시하는 아이콘

디렉토리 트리에서 한 수준 위로 이동합니다. 

홈을 표시하는 아이콘

홈 폴더로 되돌아갑니다. 

새 폴더를 표시하는 아이콘

현재 선택된 폴더에 새 폴더를 만듭니다. 

뷰를 변경하기 위해 사용하는 아이콘

서로 다른 뷰 간을 전환하기 위한 이 아이콘은 나중에 사용하기 위해 예약되어 있습니다.  

Agent Builder 메뉴

Agent Builder는 File 및 Edit 드롭다운 메뉴를 제공합니다.

Agent Builder File 메뉴

File 메뉴에는 다음 두 가지 옵션이 있습니다.

Agent Builder Edit 메뉴

Edit 메뉴에는 다음 두 가지 옵션이 있습니다.

Create 화면 사용

자원 유형을 만드는 첫 번째 단계는 Agent Builder를 시작할 때 나타나는 Create 화면에 정보를 입력하는 것입니다. 다음 그림에서는 필드에 정보를 입력한 후의 Create 화면을 보여줍니다.

그림 9–2 정보를 입력한 후의 Agent Builder Create 화면

정보를 입력한 후의 Create 화면을 표시하는 대화 상자

Create 화면에는 다음과 같은 필드, 라디오 버튼 및 확인란이 포함되어 있습니다.


주 –

cc 컴파일러가 $PATH 변수에 없는 경우 Agent Builder에서 C 라디오 버튼을 비활성화하고 ksh 라디오 버튼을 선택하도록 허용합니다. 다른 컴파일러를 지정하려면 Agent Builder 설치 및 구성 마지막 부분의 설명을 참조하십시오.


필수 정보를 지정한 후 Create을 누릅니다. 화면 아래쪽의 Output Log 영역에 Agent Builder가 수행 중인 작업이 표시됩니다. Edit 메뉴에서 Save Output Log를 선택하여 출력 로그의 정보를 저장할 수 있습니다.

작업이 완료되면 Agent Builder는 성공 메시지 또는 경고 메시지를 표시합니다.


주 –

전체 자원 유형 생성은 2단계의 프로세스이며, 첫 번째 단계(Create)를 완료한 다음 지정한 정보나 Agent Builder에서 완료한 작업을 잃어버리지 않고 Agent Builder를 종료할 수 있습니다. Agent Builder를 사용하여 작성한 코드 재사용을 참조하십시오.


Configure 화면 사용

Agent Builder에서 자원 유형 생성을 완료한 후 Create 화면에서 Next를 누르면 다음 그림과 같은 Configure 화면이 나타납니다. 자원 유형을 만들기 전에는 Configure 화면에 액세스할 수 없습니다.

그림 9–3 Agent Builder의 Configure 화면

Configure 화면을 표시하는 대화 상자

Configure 화면에는 다음과 같은 필드가 있습니다.

Agent Builder Korn 쉘 기반 $hostnames 변수 사용

많은 응용 프로그램, 특히 네트워크 인식 응용 프로그램의 경우 응용 프로그램에서 수신하는 호스트 이름과 서비스 고객 요청을 명령줄의 응용 프로그램에 전달해야 합니다. 대부분의 경우 호스트 이름은 Configure 화면에서 대상 자원 유형에 대한 시작, 중지 및 검사 명령에 지정해야 하는 인자입니다. 그러나 응용 프로그램이 수신하는 호스트 이름은 클러스터에 특정합니다. 호스트 이름은 자원이 클러스터에서 실행될 때 결정되고 Agent Builder에서 자원 유형 코드를 생성할 때는 결정될 수 없습니다.

이 문제를 해결하기 위해 Agent Builder는 개발자가 명령줄에서 시작, 중지 및 검사 명령에 지정할 수 있는 $hostnames 변수를 제공합니다.


주 –

$hostnames 변수는 Korn 쉘 기반 서비스에서만 지원됩니다. $hostnames 변수는 C 기반 및 GDS 기반 서비스에서는 지원되지 않습니다.


다음 예와 같이 $hostnames 변수를 실제 호스트 이름과 같이 정확하게 지정합니다.


% /opt/network_aware/echo_server -p port-no -l $hostnames

대상 자원 유형의 자원이 클러스터에서 실행되는 경우 해당 자원에 대해 구성된 LogicalHostname 또는 SharedAddress 호스트 이름이 $hostnames 변수 값으로 대체됩니다. 호스트 이름은 자원의 Network_resources_used 자원 등록 정보에서 해당 자원에 대해 구성됩니다.

멀티 호스트 이름을 가진 Network_resources_used 등록 정보를 구성한 경우 $hostnames 변수에는 모든 호스트 이름이 쉼표로 구분되어 포함됩니다.

등록 정보 변수 사용

등록 정보 변수를 사용하여 RGM 프레임워크에서 선택한 Sun Cluster 자원 유형, 자원 및 자원 그룹 등록 정보 값을 검색할 수도 있습니다. Agent Builder는 등록 정보 변수에 대한 시작, 검사 또는 중지 명령 문자열을 검색하여 Agent Builder에서 명령을 실행하기 전에 이러한 변수를 해당 값으로 대체합니다.


주 –

등록 정보 변수는 Korn 쉘 기반 서비스에는 지원되지 않습니다.


등록 정보 변수 목록

이 절에는 사용할 수 있는 등록 정보 변수가 나열되어 있습니다. Sun Cluster 자원 유형, 자원 및 자원 그룹 등록 정보에 대해서는 부록 A, 표준 등록 정보에서 설명합니다.

자원 등록 정보 변수

자원 유형 등록 정보 변수

자원 그룹 등록 정보 변수

등록 정보 변수 구문

이 예에 표시된 것처럼 등록 정보 이름 앞에 퍼센트 기호(%)를 포함하여 등록 정보 변수를 나타냅니다.

/opt/network_aware/echo_server -t %RS_STOP_TIMEOUT -n %RG_NODELIST

앞의 예에서 Agent Builder는 이러한 등록 정보 변수를 해석하고 다음 값을 사용하여 echo_server 스크립트를 시작할 수 있습니다.

/opt/network_aware/echo_server -t 300 -n phys-node-1,phys-node-2,phys-node-3

Agent Builder에서 등록 정보 변수를 대체하는 방법

Agent Builder는 등록 정보 변수 유형을 다음과 같이 해석합니다.

Agent Builder를 사용하여 작성한 코드 재사용

Agent Builder를 사용하여 다음과 같은 방법으로 완료된 작업을 재사용할 수 있습니다.

Procedure기존 자원 유형 복제 방법

Agent Builder에서 생성한 기존 자원 유형을 복제하려면 다음 절차를 수행합니다.

단계
  1. 다음 중 하나의 방법을 사용하여 기존 자원 유형을 Agent Builder로 로드합니다.

    • Agent Builder에서 만든 기존 자원 유형의 작업 디렉토리에서 Agent Builder를 시작합니다. 작업 디렉토리에 rtconfig 파일이 들어 있는지 확인합니다. Agent Builder는 Create 및 Configure 화면에서 해당 자원 유형에 대한 값을 로드합니다.

    • File 드롭다운 메뉴에서 Load Resource Type 옵션을 사용합니다.

  2. Create 화면에서 작업 디렉토리를 변경합니다.

    Browse를 사용하여 디렉토리를 선택해야 합니다. 새 디렉토리 이름을 입력하는 것만으로는 충분하지 않습니다. 디렉토리를 선택한 후 Agent Builder에서 Create 버튼을 다시 사용할 수 있습니다.

  3. 기존 자원 유형을 변경합니다.

    자원 유형에 대해 생성된 코드 유형을 변경할 수도 있습니다. 예를 들어, 처음에 Korn 쉘 버전의 자원 유형을 만들었지만 시간이 지나면서 C 버전이 필요한 경우 다음을 수행할 수 있습니다.

    • 기존 Korn 쉘 자원 유형을 로드합니다.

    • 출력 언어를 C로 변경합니다.

    • Create를 눌러 Agent Builder에서 C 버전의 자원 유형을 만들도록 합니다.

  4. 복제된 자원 유형을 만듭니다.

    1. Create를 눌러 자원 유형을 만듭니다.

    2. Next를 눌러 Configure 화면을 표시합니다.

    3. Configure를 눌러 자원 유형을 구성한 다음 Cancel을 눌러 마칩니다.

생성된 소스 코드 편집

Agent Builder는 자원 유형 생성 프로세스를 간소화하기 위해 지정할 수 있는 정보 양을 제한하며, 이에 따라 생성된 자원 유형의 범위도 제한됩니다. 따라서 고급 기능을 추가하려면 생성된 소스 코드나 RTR 파일을 수정해야 합니다. 이러한 기능에는 추가 등록 정보에 대한 검증 확인을 추가하는 코드, Agent Builder에서 제공하지 않는 매개 변수를 조정하는 코드 등이 포함됩니다.

소스 파일은 install-directory/rt-name/src 디렉토리에 있습니다. Agent Builder는 소스 코드에 개발자가 코드를 추가할 수 있는 주석을 포함합니다. 주석의 형식은 다음과 같습니다(C 코드의 경우).

/* User added code -- BEGIN vvvvvvvvvvvvvvv */
/* User added code -- END   ^^^^^^^^^^^^^^^ */

주 –

이러한 주석은 파운드 기호(#)로 주석의 시작을 나타낸다는 점을 제외하고 Korn 쉘 소스 코드에서와 동일합니다.


예를 들어, rt-name.h는 다른 프로그램에서 사용하는 모든 유틸리티 함수를 선언합니다. 선언 목록 끝에는 개발자가 코드에 추가했을 수 있는 추가 함수를 선언할 수 있는 주석이 있습니다.

또한 Agent Builder는 install-directory/rt-name/src 디렉토리에 적절한 대상과 함께 makefile을 생성합니다. make 명령을 사용하여 소스 코드를 다시 컴파일하고 make pkg 명령을 사용하여 자원 유형 패키지를 다시 생성합니다.

RTR 파일은 install-directory/rt-name/etc 디렉토리에 있습니다. 표준 텍스트 편집기를 사용하여 RTR 파일을 편집할 수 있습니다. RTR 파일에 대한 자세한 내용은 자원 및 자원 유형 등록 정보 설정을 참조하십시오. 등록 정보에 대한 자세한 내용은 부록 A, 표준 등록 정보를 참조하십시오.

ProcedureAgent Builder 명령줄 버전 사용 방법

Agent Builder 명령줄 버전은 그래픽 사용자 인터페이스(GUI)와 동일한 기본 프로세스를 따릅니다. 그러나 GUI에 정보를 입력하는 대신 scdscreatescdsconfig 명령에 인자를 전달합니다. 자세한 내용은 scdscreate(1HA)scdsconfig(1HA) 설명서 페이지를 참조하십시오.

Agent Builder 명령줄 버전을 사용하려면 다음 단계를 수행합니다.

단계
  1. scdscreate를 사용하여 가용성이 높거나 확장 가능한 응용 프로그램을 만들기 위한 Sun Cluster 자원 유형 템플리트를 만듭니다.

  2. scdsconfigure를 사용하여 scdscreate로 만든 자원 유형 템플리트를 구성합니다.

    등록 정보 변수를 지정할 수 있습니다. 등록 정보 변수에 대해서는 등록 정보 변수 사용에서 설명합니다.

  3. 디렉토리를 작업 디렉토리의 pkg 하위 디렉토리로 변경합니다.

  4. pkgadd 명령을 사용하여 scdscreate로 만든 패키지를 설치합니다.

    • 영역 환경에서 Solaris 10 OS를 실행 중인 경우 전역 영역의 전역 관리자로 다음 명령을 입력합니다.


      # pkgadd -G -d . package-name
      

      패키지 내용이 비전역 영역과 공유되는 전역 영역에 영향을 주지 않는 경우 지정한 패키지가 전역 영역에 추가됩니다.

    • Solaris OS의 다른 버전이나 비영역 환경에서 실행 중인 Solaris 10 OS의 경우 다음 명령을 입력합니다.


      # pkgadd -d . package-name
      
  5. (옵션) 생성된 소스 코드를 편집합니다.

  6. 시작 스크립트를 실행합니다.