Section | |||||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|---|---|
|
리소스 그룹
리소스 그룹은 장애가 발생했을 때에 페일오버 되는 리소스들의 집합을 말합니다.
MCCS는 노드간의 페일오버를 그룹 단위로 수행합니다. 따라서 페일오버가 되는 단위로 리소스들을 묶어 그룹으로 만들어야 합니다.
또한 하나의 클러스터에는 여러 개의 그룹을 생성할 수 있습니다.
시작/종료 순서
리소스는 그룹 내에서 상호간의 의존 관계에 따라 시작 또는 종료되는 과정이 정해진 순서를 갖습니다.
예를 들면 데이터베이스 관련 애플리케이션은 네트워크 리소스(네트워크 카드, 네트워크 주소)와 데이터 리소스(공유 디스크 혹은 미러 디스크)가 정상적으로 시작 된 이후에 시작되어야 합니다.
왜냐하면 네트워크 IP 주소와 데이터베이스가 저장된 디스크가 없는 상태에서는 데이터베이스 관련 애플리케이션이 정상으로 구동되지 않기 때문입니다.
네트워크 리소스와 데이터 리소스는 상호 의존 관계가 없으므로 독립적으로 시작 될 수 있습니다.
이렇게 리소스를 각각의 의존 관계에 따라 구동 순서를 정해주면 MCCS에서는 이 순서에 따라 서비스를 시작하고 종료합니다.
리소스 그룹 상태
그룹 상태는 리소스들의 상태에 의해 결정됩니다.
그룹내의 모든 리소스가 온라인 상태라면 그룹은 온라인 상태가 되고, 모두 오프라인 상태라면 그룹도 오프라인 상태가 됩니다.
일부만 온라인이라면 일부 동작 상태가 되며, 하나 이상의 리소스가 장애 상태라면 그룹도 장애 상태가 됩니다.
그룹에 대한 제어는 상태에 따라 가능한 메뉴가 활성화 됩니다.
예를 들면 종료 명령은 그룹이 일부 동작 혹은 온라인 상태일 때만 활성화 되고, 장애 표시 제거 명령은 그룹이 장애 상태일 때만 활성화됩니다.
(상세한 내용은 " 4.1 그룹 제어" 편을 참조해 주십시오.)
모니터링과 서비스 복구
그룹은 하나 이상의 노드가 온라인 상태가 되면 서비스를 자동 복구할 수 있는 상태가 됩니다.
어떤 노드에서 온라인 상태였던 리소스에서 장애가 발생하면 그룹 상태는 장애 상태가 되고 복구 관련 설정에 따라 복구 과정이 이루어 집니다.
병렬 모드에서는 재시작 설정 옵션에 따라 복구할 수 있습니다.
페일오버 모드는 재시작 뿐만 아니라 대기 노드로 페일오버 할 수도 있습니다.
그룹이 장애 상태인 노드로는 페일오버 하지 않습니다. 그룹을 어떤 방법으로 복구할 것인지, 재시작 횟수, 페일오버 여부 등은 개별 속성값으로 지정할 수 있습니다.
리소스 그룹 속성
그룹의 속성은 그룹의 상태 뷰와 속성 뷰에서 파악할 수 있습니다.
MCCS 콘솔의 그룹 관리 뷰에서 그룹 선택 후 오른쪽의 '그룹 속성값' 탭의 상세 정보를 볼수 있습니다.
회색으로 표기된 값은 읽기 전용입니다. 이 값들은 그룹 상태를 나타내기 위한 정보입니다.
흰색으로 표기된 값은 사용자에 의해 정의 된, 수정가능한 값입니다.
[그림] 그룹 속성 화면
...
Resource Group Attribute
Group attribute can be identified from Group Attributes view and Group State view.
From the group management view of MCCS web console, select group, then select the ‘Group Attributes’ tab located on right top of detailed information panel.
The values of gray colored are for read only. They just contain and show the information of group state. The values of white colored are configurable by user definition.
[Figure] Group Attribute View
Attribute | Description | Type | Default | Edit | Note | |
---|---|---|---|---|---|---|
ActionState | It represents the action status for the ongoing group. | STRING | X |
| ||
AutoDisabled | 자동비활성화 된 상태입니다. | BOOLEAN | false | X | ||
AutoFailover그룹 내에 장애가 발생하였을 때 자동으로 페일오버 할 것인지를 결정합니다 | Determine whether to perform automatic failover when trouble occurs within the group. | BOOLEAN | true | O | ||
AutoFaultClearTIme | 장애 발생 후에 페일오버가 되고 이 시간 값만큼 정상 온라인을 유지하면 | INTEGER0초 | 0 sec | O | ||
AutoRestart | 그룹이 감지 전용 리소스 장애로 시작되지 못한 경우에 그 리소스가 정상화 되거나 | BOOLEAN | false | O | ||
AutoStart | 엔진이 시작되면 그룹을 자동으로 시작하는지를 알려줍니다*AutoStart | When the engine starts, it will notify when the group will be started automatically. | BOOLEAN | true | O | |
BatchAfterOnline | 그룹을 온라인 한 후에 실행할 배치 파일을 설정합니다. | FILE | O | |||
BatchBeforeOffline | 그룹을 오프라인 하기 이전에 실행할 배치 파일을 설정합니다. | FILE | O | |||
BatchTimeout배치 파일의 실행 완료 제한 시간을 지정합니다 | Designate the time out for running the batch file. | INTEGER300초 | 300 sec | O | ||
Enabled | 그룹 관리를 가능하게 합니다. | BOOLEAN | true | O | ||
*Failover | 장애로 인한 페일오버가 진행 중인지 나타냅니다Indicates whether there is an ongoing failover due to troubles. | BOOLEAN | false | X | ||
GroupName등록한 | 그룹 이름을 나타냅니다It represents the registered name of group. | NAME | X | |||
Locked | 영구잠금, 그룹을 잠금상태로 만들어 모든 동작과 명령을 제한한다. | BOOLEAN | false | X | ||
MaxDependencyLevel그룹 내에서 리소스간의 의존 관계를 설정 할 수 있는 상하의 최대 단계를 지정합니다 | Designate the max vertical level that sets the dependencies among the resources in a group. | INTEGER20단계 | 20 levels | X | ||
Monitored활성화 된 모든 리소스에 대한 감시가 완료되었는지 여부를 나타냅니다 | It indicates whether all the activated resources are monitored. | BOOLEAN | X | |||
OnlineCount | 그룹 내에서 온라인 상태의 리소스 개수입니다. | INTEGER | X | |||
Parallel | 그룹 병렬 속성입니다. | BOOLEAN | false | X | ||
PreActive이전에 그룹이 실행되었던 노드 이름을 알려줍니다 | It represents the name of node where a group was executed before. | STRING | X | |||
State | 노드의 그룹 상태(온라인, 오프라인, 장애, 미확인 등)을 알려주는 속성입니다The attribute represents the group status of node (online, offline, trouble, unchecked). | STRING | X | |||
TargetNodeList | 그룹의 운영 대상이 되는 노드 목록입니다. | STRING | X | |||
TLocked | '임시 잠금' 상태를 알려주는 속성입니다. | BOOLEAN | false | X |
* AutoStart (true/false)
시스템 부팅 단계에서 새롭게 클러스터 연결을 시작할 때에 그룹을 자동으로 시작할 것인지를 결정합니다.
(MCCS 서비스를 다시 시작하는 경우이거나 한 노드만 재시작하여 이미 운영중인 MCCS에 연결하는 경우는 무시됩니다.)
병렬 모드 그룹인 경우는 로컬 노드에서 오프라인 상태나 일부 온라인 상태면 자동으로 시작합니다.
페일오버 그룹은 타깃 노드에서 우선 순위가 가장 높은 노드부터 자동으로 시작합니다. 잠금이나 장애 상태인 그룹은 시작되지 않습니다.
리소스에 따른 그룹 자동 시작 옵션
...
1.모든 원격 노드 가 FAULTED상태가 아니어야 한다.
2.노드가 모두 클러스터에 합류되어야 합니다.
3.미러 디스크의 상태가 MIRRORING 또는 MIRROR_RESYNCING 이어야 합니다.
4.롤이 한 노드에서는 Source, 다른 노드에서는 Target 이어야 합니다. Source상태의 노드를 소스 노드로 결정.
5.미러롤이 Source 인 노드로 Online 시도합니다.
5.그룹내에 여러개의 미러디스크 리소스가 있다면, 리소스들은 한 노드에 모두 source이어야 Online이 가능 합니다.
...
Determine whether to automatically start a group when making a new connection to a cluster in the system booting phase. (If the MCCS service is restarted or a single node is restarted to connect to operating MCCS, it will be ignored.) If a parallel group is offline at a local node or some members are online, it will automatically start. In case of a failover group, the node with the highest priority will be automatically started first. In case of locking or troubles, a group will not be started.
Group auto start option for each resource
Prerequisite | In case there is mirror disk | In case there is not mirror disk |
---|---|---|
AutoStart should be set to true. | 1. None of the remote nodes should be FAULTED. | 1. If the both nodes are booted, the first booted node will be automatically started. |
*Failover (true/false)
장애로 인한 페일오버가 진행 중인지를 나타냅니다.
true로 설정된 상태에서 다음과 같은 경우가 발생하면 false로 재설정됩니다.
- 잠금 명령에 의해 Locked/TLocked 속성이 true로 설정되었을 때
- 초기화 명령(Flush)이 전달되었을 때
...
그룹상태
그룹 상태는 해당 리소스들의 상태에 따라 결정됩니다.
하지만 모니터링 전용 리소스들은 그룹 상태에 영향을 미치지 않습니다.
왜냐하면 모니터링 전용 리소스의 그룹을 어떤 노드에서 시작하든지 온라인 상태여야 하기 때문입니다.
그룹 상태는 기본적으로 다음과 같습니다.
[그림] 그룹 상태 화면
온라인
모든 리소스들이 온라인 되어 있는 상태입니다.
오프라인
모든 리소스들이 오프라인 되어 있는 상태입니다.
화면상에서는 회색 톤의 비활성화 된 아이콘으로 표시됩니다.
모니터링 전용 리소스는 활성화된 상태로 나타나지만 그룹의 오프라인 상태와는 무관합니다. (네트워크 어댑터 같은 경우)
일부 동작
일부 리소스들이 온라인 되어 있는 상태를 말하며 녹색으로 체크 표시 되어 나타납니다.
모니터링 전용 리소스는 상태 결정에서 제외되기 때문에 일부 동작 상태에 영향을 미치지 않습니다.
장애
그룹 내에서 한 개의 리소스라도 장애가 발생되었으면 그 그룹은 장애 상태로 간주되며 붉은 색으로 체크 표시되어 나타납니다.
그러나, 장애 상태는 현재 장애가 발생 중이라는 것을 의미하지는 않습니다. 장애가 발생했었다는 사실을 알려줄 뿐이며 관리자의 분석 및 처리를 기다리는 상태를 의미합니다.
관리자가 장애 상태를 직접 해제하거나 AutoFaultClearTime 같은 속성 값으로 인해 해제되지 않는 이상 장애 상태는 계속 남아 있습니다.
CLI 사용(mcgroup 명령)
그룹에 관한 명령을 전달합니다. 그룹에 대해 추가, 삭제, 온라인, 오프라인, 속성 편집 등의 명령을 내릴 수 있습니다.
...
It indicates whether there is an ongoing failover due to troubles. When it is set to true, if the following event occurs, it is reset to false.
- The locking command sets the Locked/TLocked attribute to false.
- The initialization command (Flush) is sent.
- A group goes online.
Group State
The state of the group is determined by the state of the resources.
However, the status of persistent resources like Ethernet adapter do not affect on the status of group because these resources should be online on both nodes commonly.
Basically the group may have the following states.
[Figure] Group State View
Online
This is a state where all the resources are online.
Offline
This is a state where all the resources are offline.
They are displayed on the console window as gray colored icons.
But a Persistent Resources (e.g. Ethernet adapter) still remain online with colored icon regardless the group offline.
Partial
This is a state where only some of the resources are online and shows as a green check marks.
A persistent resources are excluded from state determination, they do not affect the partial online state.
Faulted
This is a state where one or more resources are failed and the group will also be regarded as faulted. It shows in red check marks.
The failure state does not mean that a failure is occurring at present. It only shows that a failure occurred, and refers to waiting for the administrator's analysis and actions.
Unless the administrator directly clears the failure state, and uses an attribute like 'AutoFaultClearTime' to cancel it, the failure state will remained.
CLI Use (mcgroup command)
It sends the commands related to MCCS group. Group related commands such as add, delete, online, offline, attribute edit can be done.
Info |
---|
When you install MCCS, the initial user account ID is set to 'admin' and the password is set to 'password'. |
Syntax
mcgroup [-u userid -pw password] [-ip node_ip_address] [-p port] -command [ group ] [-a attribute] [-r resource] [-n node] |
Options
Option | 설명Description | ||
-h | 도움말을 출력합니다It prints help menu. | ||
-u | 사용자 ID를 지정합니다Designate the user ID. | ||
-pw | 사용자 패스워드를 지정합니다 Enter the user password. | ||
-ip명령을 실행하기 위해 접근할 IP를 지정합니다. | It defines the node to access to execute command. If omitted, it will access to execute command for local node. | ||
-p | 명령을 실행하기 위해 접근할 포트를 지정합니다. | -groupcommand | 그룹에 내릴 명령을 지정합니다.It specifies the port to access to execute command. |
-groupcommand | It defines group command. | ||
group작업의 | 대상이 되는 그룹을 지정합니다.It enters name of the group. | ||
-a | -dep | 그룹이나 리소스의 의존성을 표시합니다[list] 명령일 경우 속성값을 나열할 속성을 지정합니다. | |
-r | 작업 할 리소스를 지정합니다. | ||
-n | 작업 할 노드명을 지정합니다. | ||
-t | 시간주기를 지정합니다. | ||
It defines the attribute value that should be listed if it is command. | |||
-r | It defines the resource to be managed. | ||
-n | It defines node name to be managed. | ||
-t | It defines the interval time. | ||
-dep | It shows dependency of the group or the resource. |
Example
add
그룹 Adds testGroup을 생성합니다.
mcgroup -u admin -pw password -add testGroup |
delete
그룹 Delete testGroup을 삭제합니다.
mcgroup -u admin -pw password -delete testGroup |
online
testNode에서 testGroup을 온라인 시킵니다Bring online testGroup on testNode..
mcgroup -u admin -pw password -online testGroup [-n testNode] |
offline
testNode에서 testGroup을 오프라인 시킵니다.Take offline testGroup on testNode
mcgroup -u admin -pw password -offline testGroup [-n testNode] |
move
testNode로 testGroup을 페일오버 시킵니다.Switchover testGroup to testNode
mcgroup -u admin -pw password -move testGroup [-n testNode] |
clear
testNode에서 testGroup의 장애 표시를 제거합니다Remove fault mark on testGroup of testNode.
mcgroup -u admin -pw password -clear testGroup [-n testNode] |
flush
testNode의 testGroup을 초기화 시킵니다Initiate all command for testGroup of testNode.
mcgroup -u admin -pw password -flush testGroup -n testNode |
modify
testNode의 testGroup 속성을 수정합니다Modify a value of attribute of testGroup on testNode.
mcgroup -u admin -pw password -modify test -a attribute attribute_value -n testNode |
testNode의 testGroup 속성인 AutoStart를 true로 변경합니다Modify the value of ‘AutoStart’ attribute of testGroup on testNode.
mcgroup -u admin -pw password -modify testGroup -a AutoStart true -n testNode |
list
그룹 상태를 출력합니다Prints state of the group.
mcgroup -u admin -pw password -list [group [-all] | [-dep [-r resource]] | [-a attribute] [-n testNode]] |
그룹의 모든 속성값을 출력합니다It shows all the attribute value of the group.
mcgroup -u admin -pw password [-ip node_ipaddress] [-p port] -list [group [ -all]] |
그룹에 속한 리소스의 의존성을 보여줍니다.It shows dependency of resource that belongs to the group.
mcgroup -u admin -pw password [-ip node_ipaddress] [-p port] -list [-dep [-r resource]] |
...
mcgroup -u admin -pw password [-ip node_ipaddress] [-p port] -list [-a attribute] [-n testNode]] |
lock
testGroup을 임시 잠금 상태로 합니다Locks testGroup temporarily.
mcgroup -u admin -pw password -lock testGroup |
testGroup을 영구 잠금 상태로 합니다Locks testGroup permanently.
mcgroup -u admin -pw password -lock testGroup -p |
unlock
testGroup의 잠금 상태를 해제합니다Unlocks testGroup.
mcgroup -u admin -pw password -unlock testGroup |
state
test Node의 testGroup 상태를 출력합니다It prints state of testGroup of testNode.
mcgroup -u admin -pw password -state testGroup [-n testNode] |
monitor
Monitors testGroup 상태를 interval 간격으로 모니터링 합니다 state on every time interval.
mcgroup -u admin -pw password -monitor testGroup [-t interval(seconds)] |