다음을 통해 공유


Runbook 작업 제어

Runbook Designer에서 작업을 함께 연결하여 Runbook에서 작업 시퀀스를 설정합니다. 이러한 링크를 스마트 링크라고 하는 이유는 한 활동에서 다른 작업으로 전달되는 데이터 형식을 제어하도록 구성할 수 있기 때문입니다. 포함된 루프를 사용하여 해당 작업이 실행되는 시기에 대한 논리를 설정하여 Runbook이 작업을 완료하는 시기를 제어할 수도 있습니다. 마지막으로 텍스트 및 숫자 연산을 사용하여 작업 간에 전달될 때 데이터를 조작하거나 작업 순서에 대한 조건을 설정할 수 있습니다. 이 문서에서는 Runbook 내에서 데이터를 시퀀싱하고 조작하는 방법을 설명합니다.

Runbook의 활동은 함께 연결하여 설정한 순서에 따라 완료됩니다. 링크 속성의 포함 및 제외 탭을 사용하여 활동 간에 흐르는 데이터를 제어할 수 있습니다. 예를 들어 특정 조건을 충족하는 후속 작업에 전달할 데이터만 포함할 수 있습니다.

Important

제외 탭의 스마트 링크 규칙은 포함 탭의 규칙보다 우선 적용됩니다.

Important

각 탭의 규칙은 OR 조건으로 결합됩니다. 탭에 정의된 여러 조건 중 하나만 참이면 전체 탭에 대해 참이 됩니다.

활동에서 게시하는 데이터 형식은 Runbook 시퀀스를 제어하기 위해 설정할 수 있는 조건 유형을 결정합니다. 일부 활동은 이진 데이터를 게시하고 다른 활동은 숫자 또는 텍스트 데이터를 게시합니다.

게시된 데이터가 텍스트 데이터인 경우 다음 중 어느 것을 사용하여 실행, 포함 또는 제외 조건을 설정할 수 있습니다.

조건 설명
contains 지정된 텍스트가 게시된 데이터 항목 값에 나타납니다.
포함하지 않음 지정된 텍스트가 게시된 데이터 항목 값에 나타나지 않습니다.
시작 문자 게시된 데이터 항목의 값이 지정된 텍스트로 시작합니다.
다음으로 끝남 게시된 데이터 항목의 값이 지정된 텍스트로 끝납니다.
다음 패턴과 일치 게시된 데이터 항목의 값이 특정 정규식과 일치합니다.
다음 패턴과 일치 안 함 게시된 데이터 항목의 값이 특정 정규식과 일치합니다.
같음 게시된 데이터 항목의 값이 지정된 텍스트와 정확히 일치합니다.
같지 않음 게시된 데이터 항목의 값이 지정된 텍스트와 일치하지 않습니다.

참고 항목

텍스트 값은 대/소문자를 구분하지 않습니다.

정규식을 사용하여 패턴 일치를 수행하는 조건을 설정할 수도 있습니다.

게시된 데이터가 숫자인 경우 다음 중 어느 것을 사용하여 실행, 포함 또는 제외 조건을 설정할 수 있습니다.

조건 설명
같음 게시된 데이터 항목의 값이 지정된 값과 정확히 일치합니다.
같지 않음 게시된 데이터 항목의 값이 지정된 값과 일치하지 않습니다.
다음보다 작은 경우 게시된 데이터 항목의 값이 지정된 값보다 작습니다.
다음보다 큼 게시된 데이터 항목의 값이 지정된 값보다 큽니다.
작거나 같음 게시된 데이터 항목의 값이 지정된 값보다 작거나 같습니다.
다음보다 크거나 같음 게시된 데이터 항목의 값이 지정된 값보다 크거나 같습니다.
사이 게시된 데이터 항목의 값이 지정된 두 값 사이에 있습니다.

스마트 링크 조건을 추가하거나 제거하는 단계에 필요한 탭을 선택합니다.

포함된 루프를 사용하여 작업 반복

루프를 사용하면 Runbook의 모든 위치에서 자동 재시도를 빌드하고 모니터링할 수 있습니다.

작업이 실패할 경우 작업을 다시 시도하거나 유효한 데이터에 대한 작업의 출력 정보를 테스트할 수 있도록 모든 작업에 대한 루프를 만들 수 있습니다. 이러한 메커니즘을 사용하여 워크플로에 대기 조건을 빌드할 수도 있습니다.

작업에 대한 루프를 구성하는 경우 원하는 종료 반복 조건에 도달할 때까지 동일한 입력 데이터로 계속 실행됩니다. 스마트 링크 구성과 비슷한 방식으로 루프에 대한 종료 조건을 빌드합니다. 작업에서 게시된 모든 데이터 항목을 종료의 일부로 사용하거나 구성을 종료하지 않을 수 있습니다. 일반적인 게시된 데이터에는 루프: 시도 횟수 및 루프: 반복 조건에서 루프 자체의 정보를 사용할 수 있는 총 기간과 같은 특수 데이터 항목이 포함됩니다.

루프는 작업에 전달되는 들어오는 각 데이터 조각에 대해 한 번 실행됩니다. 예를 들어 쿼리 데이터베이스 작업과 추가 줄을 사용하는 Runbook을 생각해 보세요. 쿼리 데이터베이스 작업에서 세 개의 행을 반환한 경우 추가 줄 작업은 세 번 실행됩니다. 추가 줄 활동에 루프가 있는 경우 세 개의 별도 루프를 실행합니다. 첫 번째 데이터 항목이 추가 줄 작업을 반복한 후 다음 항목은 추가 줄을 통과하고 종료될 때까지 반복한 다음 세 번째 항목이 시작됩니다. 세 항목이 모두 처리되면 Runbook의 다음 작업이 실행됩니다.

루프 구성

  1. Runbook에서 활동을 마우스 오른쪽 단추로 클릭하여 반복을 선택합니다. 반복 속성 대화 상자가 열립니다.

  2. 일반 탭에서 [사용]을 선택합니다.

  3. 시도 간 지연 상자에 활동을 실행하려는 각 시도 사이에 일시 중지할 시간(초)을 입력합니다.

종료 및 종료 안 함 조건

종료 탭의 규칙은 루프가 종료되는지 여부를 결정하는 조건을 지정합니다. 종료 안 함 탭의 규칙은 루프가 계속되도록 하는 조건을 지정합니다.

Important

종료 안 함 탭의 규칙은 종료 탭의 규칙을 대체합니다.

각 탭 내의 규칙은 Or 조건을 사용하여 조인됩니다. 전체 탭이 true이되려면 탭의 조건 중 하나만 true여야 합니다.

끝내기 조건을 추가하거나 제거하는 프로시저에 필요한 탭을 선택합니다.

종료 조건을 추가하려면 다음 단계를 수행합니다.

  1. 반복 속성 대화 상자에서 종료 탭 또는 종료 안 함 탭을 선택한 다음, 상자에 나열된 조건을 선택하여 조건을 추가합니다.

    Important

    규칙을 구성하는 값을 변경하려면 링크 조건의 각 밑줄이 그은 부분을 선택해야 합니다.

  2. 조건에서 나열된 활동을 선택하여 게시된 데이터 대화 상자를 엽니다.

  3. 모든 활동에 공통적인 속성을 표시하려면 일반 반환 데이터 표시 상자를 선택합니다.

  4. 게시된 데이터에서 속성을 선택한 다음 확인을 선택합니다. 조건 식은 속성에서 반환하는 데이터 유형에 따라 달라집니다.

  5. 식의 다른 부분을 변경하려면 밑줄이 그은 텍스트를 선택하고 적절한 값을 선택하거나 입력합니다.

  6. 마침을 선택합니다.

Runbook에 대한 일정 설정

Runbook이 실행되는 시기를 제어하도록 일정을 설정할 수 있습니다. 예를 들어 일반적인 업무 시간 동안 주 서버에서 Runbook을 백업하는 등 일부 Runbook을 실행하는 것이 부적절한 경우가 있습니다. 복잡한 간격으로 실행하는 일정을 만들 수도 있습니다. 예를 들어 매달 첫째 및 셋째 월요일과 목요일에 실행하되 공휴일인 경우는 제외할 수 있습니다.

일정은 Runbook을 실행하는 Runbook 서버의 시스템 클록을 사용합니다. 따라서 일정은 가상 머신 환경에서 기능하며 일광 절약 시간제의 이동으로 인해 시스템 클록이 조정되는 경우에도 계속 실행될 수 있습니다.

금지된 시간 전에 시작되는 Runbook은 금지된 시간이 도착할 때 처리 중인 경우에도 완료될 때까지 실행됩니다. 처리가 시작된 후에는 중단되지 않습니다.

Important

일정에 대한 액세스 권한을 수정할 수 있지만 Runbook 서버는 이러한 권한을 적용하지 않습니다.

참고 항목

시스템 시계가 1시간 앞으로 조정될 때 건너뛰는 시간 동안 Runbook이 시작되도록 예약하는 경우 해당 시작 시간은 건너뛰고 Runbook은 다음 예약된 시간에 시작됩니다. 시스템 클록이 1시간 뒤로 조정되어 두 번 발생하는 한 시간 동안 Runbook이 시작되도록 예약하면 Runbook이 두 번 시작됩니다.

참고 항목

오케스트레이터는 다중 선택 항목이 있는 여러 일정 이동을 지원하지 않습니다. 다른 폴더로 일정을 두 개 이상 이동하려면 각 일정을 개별적으로 이동해야 합니다.

일정을 만들거나, Runbook에 일정을 할당하거나, Runbook에서 일정을 제거하는 데 필요한 탭을 선택합니다.

다음 단계에 따라 일정을 만듭니다.

  1. 연결 창에서 일정 폴더 또는 일정 폴더의 하위 폴더를 마우스 오른쪽 단추로 클릭하고 새로 만들기를 가리킨 다음 일정을 선택하여 새 일정 대화 상자를 엽니다.

  2. 일반 탭의 이름 상자에 일정의 이름을 입력합니다.

  3. 설명 상자에 일정의 목적을 설명하거나 설명하는 설명을 입력합니다.

  4. 세부 정보 탭을 선택합니다. 이 일정에 따라 Runbook을 실행할 수 있는 일을 선택합니다.

    요일: 이 옵션을 선택하고 일정에 따라 Runbook을 실행할 요일을 선택합니다.

    발생: 한 달에 몇 주 동안 일정에 따라 Runbook을 실행할지 선택합니다.

    날짜: 이 옵션을 선택하고 일정에 따라 Runbook을 실행할 날짜를 선택합니다. 날짜를 숫자로 입력하여 한 달 중 실행할 날짜를 지정합니다. 하이픈을 사용하여 범위를 지정하거나 쉼표를 사용하여 항목을 구분할 수 있습니다. 예를 들어 1,3을 입력하면 월의 첫 번째 및 세 번째 날짜가 포함됩니다. 1-21을 입력하면 첫 번째부터 21일까지의 월이 포함됩니다. 두 기호를 조합하여 좀 더 복잡한 날짜를 지정할 수도 있습니다. 모두 입력하여 월의 모든 일을 지정합니다. 마지막을 입력하여 월의 마지막 날을 지정합니다.

    일 범위의 일부로 모든 날짜와 마지막을 사용할 수 없습니다. 또한 5-31 범위를 입력한 경우 이 범위는 28일, 29일, 30일 및 31일을 포함하여 모든 달에 대해 올바르게 작동합니다.

  5. 시간을 선택하여 시간 예약 대화 상자를 엽니다.

  6. 1주일에 시간 그룹을 선택하려면 선택하고 끕니다. 대화 상자의 맨 아래에 있는 텍스트는 선택한 기간을 보여줍니다. 다음 중 하나를 선택하십시오.

    허용됨 (파란색): 선택한 기간을 Runbook 실행을 허용하는 시간으로 할당합니다.

    거부됨 (흰색): 선택한 기간을 Runbook 실행을 금지하는 시간으로 할당합니다.

  7. 확인을 선택합니다.

  8. 예외 탭을 선택합니다. 목록에는 세부 정보 탭에 정의된 규칙에 대한 예외인 모든 날짜가 표시됩니다.

  9. 추가를 선택하여 날짜 대화 상자를 엽니다.

  10. 날짜를 지정하고 Runbook이 해당 날짜에 실행되도록 허용 또는 허용 안 을 선택한 다음 확인을 선택합니다. 항목이 목록에 나타납니다.

  11. 예외 항목을 수정하려면 예외 항목을 선택한 다음 수정을 선택합니다. 예외 항목을 제거하려면 예외 항목을 선택한 다음 제거를 선택합니다.

  12. 일정을 수정하려면 일정을 두 번 클릭합니다.

  13. 일정을 제거하려면 일정을 마우스 오른쪽 단추로 클릭하고 삭제를 선택합니다.

  14. 마침을 선택합니다.

함수를 사용하여 데이터 조작

텍스트 파일, 반환된 데이터 또는 기타 원본에서 문자열 데이터를 조작하고 Runbook 활동에 사용할 수 있는 형식으로 변환해야 할 수 있습니다. 또한 합계와 차이를 계산하고 나누기 및 곱하기 연산을 수행하는 것과 같은 간단한 산술 연산을 수행할 수 있습니다. 예를 들어 텍스트 파일 관리 작업을 사용하여 텍스트 파일에서 텍스트를 추출한 후 텍스트의 선행/후행 공백을 삭제하고, 텍스트의 특정 부분을 검색하여 다른 작업에 반환된 데이터 항목으로 전달할 수 있습니다.

함수를 삽입하여 Runbook의 데이터를 조작합니다. 데이터 조작 함수는 대괄호 '[' 및 ']'로 묶어야 합니다. 예시:

[Upper('this will be inserted in upper case')]

작업이 실행되면 예제의 'this will be inserted in uppercase' 텍스트는 'THIS WILL BE INSERTED IN UPPERCASE'로 바뀝니다.

함수는 대/소문자가 구분됩니다. 예를 들어 Upper('Text')는 처리되지만 upper('Text')는 처리되지 않습니다.

아래 표에서는 Runbook에 지원되는 함수를 나열합니다.

함수 및 정의 사용 매개 변수 예시
Upper - 텍스트를 대문자로 변환합니다. Upper('Text') Text - 대문자로 변환될 텍스트입니다. Upper('this will be converted to uppercase')를 입력하면 'THIS WILL BE CONVERTED TO UPPERCASE'가 반환됩니다.
Lower - 텍스트를 소문자로 변환합니다. Lower('Text') Text - 소문자로 변환될 텍스트입니다. Lower('This Will Be Converted To Lowercase')를 입력하면 'this will be converted to lowercase'가 반환됩니다.
Field - 특정 위치의 텍스트를 반환합니다. Field('Text', 'Delimiter', Field Number) Text - 검색되는 텍스트입니다.

Delimiter - 각 필드를 구분하는 문자입니다.

Field Number - 1부터 시작하여 반환될 필드의 위치입니다.
Field('John;Smith;9055552211', ';', 2)는 'Smith'를 반환합니다.
Sum - 숫자들의 합을 반환합니다. Sum(firstNumber, secondNumber, thirdNumber, ...) Number - 추가되는 숫자입니다. 임의의 숫자 집합을 쉼표(,)로 구분하여 넣을 수 있습니다. Sum(2,3,4,5)은 '14'를 반환합니다.
Diff - 두 수의 차를 반환합니다. Diff(Number1, Number2, <Precision>) Number1 - 차감되는 수(피감수)입니다.

Number2 - Number1에서 차감시키는 수(감수)입니다.

전체 자릿수 <선택 사항> - 결과가 반올림될 소수 자릿수입니다.
Diff(9, 7)은 '2'를 반환합니다.

Diff(9.3, 2.1, 2)는 '7.20'을 반환합니다.
Mult - 숫자들의 곱을 반환합니다. Mult(firstNumber, secondNumber, thirdNumber, ...) Number - 곱하는 숫자입니다. 임의의 숫자 집합을 쉼표(,)로 구분하여 넣을 수 있습니다. Mult(2, 3, 4)는 '24'를 반환합니다.
Div - 두 수의 몫을 반환합니다. Div(Number1, Number2, <Precision>) Number1 - 나눠지는 수(피제수)입니다.

Number2 - 나누는 수(제수)입니다.

전체 자릿수 <선택 사항> - 결과가 반올림될 소수 자릿수입니다.
Div(8, 4)는 '2'를 반환합니다.

Div(9, 2, 2)는 '4.50'을 반환합니다.
Instr - 다른 텍스트 내에서 발견된 첫 번째 텍스트의 위치를 반환합니다. Instr ('SearchText', 'TextToFind') SearchText - 검색되는 텍스트입니다.

TextToFind - 검색할 텍스트입니다.
Instr('This is a string that is searched', 'string')은 11을 반환합니다.
Right - 전체 텍스트의 오른쪽에서부터 텍스트를 반환합니다. Right('Text', Length) Text - 전체 텍스트입니다.

Length - 오른쪽에서 시작하여 반환할 문자 수입니다.
Right('Take from the right', 9)은 'the right'을 반환합니다.
Left - 전체 텍스트의 왼쪽에서부터 텍스트를 반환합니다. Left('Text', Length) Text - 전체 텍스트입니다.

Length - 왼쪽에서 시작하여 반환할 문자 수입니다.
Left('Take from the left', 4)는 'Take'를 반환합니다.
Mid - 전체 텍스트의 가운데에서부터 텍스트를 반환합니다. Mid('Text', Start, Length) Text - 전체 텍스트입니다.

Start - 문자를 반환하기 시작할 텍스트의 시작 위치입니다.

Length - 시작 위치에서 시작하여 반환할 문자 수입니다.
Mid('Take from the middle', 5, 4)는 'from'을 반환합니다.
LTrim - 텍스트에서 선행 공백을 삭제합니다. LTrim('Text') Text - 선행 공백을 삭제할 텍스트입니다. LTrim(' 선행 공백만 제거합니다. ') '선행 공백만 제거합니다. '
RTrim - 텍스트에서 후행 공백을 삭제합니다. RTrim('Text') Text - 후행 공백을 삭제할 텍스트입니다. RTrim(' 후행 공백만 제거합니다. ') '후행 공백만 제거합니다.'를 반환합니다.
Trim - 텍스트에서 선행/후행 공백을 삭제합니다. Trim('Text') Text - 선행/후행 공백을 삭제할 텍스트입니다. Trim(' 선행 및 후행 공백을 제거합니다. ') '선행 및 후행 공백 제거'를 반환합니다.
Len - 텍스트의 길이를 반환합니다. Len('Text') Text - 측정되는 텍스트입니다. Len('Measure this text')는 17을 반환합니다.

참고 항목

함수는 대/소문자가 구분됩니다. 예를 들어 Upper('Text')는 처리되지만 upper('Text')는 처리되지 않습니다.

다음 단계

샘플 Runbook을 만드는 가이드 연습을 읽으려면 샘플 Runbook 만들기 및 테스트를 참조하세요.