13.3. 검사 구성 및 스크립트 알림
keepalived는 사용자 제공 검사 스크립트를 주기적으로 실행하여 애플리케이션의 상태를 모니터링합니다. 예를 들어 스크립트는 요청을 발행하고 응답을 확인하여 웹 서버를 테스트할 수 있습니다. 클러스터 관리자는 상태가 변경될 때마다 호출되는 선택적 알림 스크립트를 제공할 수 있습니다.
검사 및 알림 스크립트가 IP 페일오버 Pod에서 실행되고 호스트 파일 시스템이 아닌 Pod 파일 시스템을 사용합니다. 그러나 IP 페일오버 Pod를 사용하면 /hosts
마운트 경로에서 호스트 파일 시스템을 사용할 수 있습니다. 검사 또는 알림 스크립트를 구성할 때 스크립트의 전체 경로를 제공해야 합니다. 스크립트를 제공하는 데 권장되는 접근 방식은 ConfigMap
오브젝트를 사용하는 것입니다.
Keepalived가 시작될 때마다 로드되는 검사 및 알림 스크립트의 전체 경로 이름이 Keepalived 구성 파일인 _/etc/keepalived/keepalived.conf
에 추가됩니다. 스크립트는 다음 방법에 설명된 대로 ConfigMap
오브젝트를 사용하여 Pod에 추가할 수 있습니다.
스크립트 확인
검사 스크립트를 제공하지 않으면 TCP 연결을 테스트하는 간단한 기본 스크립트가 실행됩니다. 이 기본 테스트는 모니터 포트가 0
이면 비활성화됩니다.
각 IP 페일오버 Pod는 Pod가 실행 중인 노드에서 하나 이상의 가상 IP(VIP) 주소를 관리하는 Keepalived 데몬을 관리합니다. Keepalived 데몬은 해당 노드의 각 VIP 상태를 유지합니다. 특정 노드의 특정 VIP는 master
,backup
또는 fault
상태가 될 수 있습니다.
검사 스크립트가 0이 아닌 값을 반환하면 노드가 백업
상태가 되고 보유한 VIP가 다시 할당됩니다.
스크립트 알림
keepalived는 다음 세 가지 매개변수를 알림 스크립트에 전달합니다.
-
$1
-group
또는instance
-
$2
-group
또는instance
이름 -
$3
- 새 상태:master
,backup
또는fault
사전 요구 사항
-
OpenShift CLI(
oc
)를 설치합니다. -
cluster-admin
권한이 있는 사용자로 클러스터에 로그인합니다.
프로세스
원하는 스크립트를 생성하고 저장할
ConfigMap
오브젝트를 생성합니다. 스크립트에는 입력 인수가 없으며OK
의 경우0
을fail
의 경우1
을 반환해야 합니다.검사 스크립트,
mycheckscript.sh
:#!/bin/bash # Whatever tests are needed # E.g., send request and verify response exit 0
ConfigMap
오브젝트를 생성합니다.$ oc create configmap mycustomcheck --from-file=mycheckscript.sh
pod에 스크립트를 추가합니다. 마운트된
ConfigMap
오브젝트 파일의defaultMode
는oc
명령을 사용하거나 배포 구성을 편집하여 실행할 수 있어야 합니다.0755
,493
10진수 값이 일반적입니다.$ oc set env deploy/ipfailover-keepalived \ OPENSHIFT_HA_CHECK_SCRIPT=/etc/keepalive/mycheckscript.sh
$ oc set volume deploy/ipfailover-keepalived --add --overwrite \ --name=config-volume \ --mount-path=/etc/keepalive \ --source='{"configMap": { "name": "mycustomcheck", "defaultMode": 493}}'
참고oc set env
명령은 공백 문자를 구분합니다.=
기호 양쪽에 공백이 없어야 합니다.작은 정보또는
ipfailover-keepalived
배포 구성을 편집할 수 있습니다.$ oc edit deploy ipfailover-keepalived
spec: containers: - env: - name: OPENSHIFT_HA_CHECK_SCRIPT 1 value: /etc/keepalive/mycheckscript.sh ... volumeMounts: 2 - mountPath: /etc/keepalive name: config-volume dnsPolicy: ClusterFirst ... volumes: 3 - configMap: defaultMode: 0755 4 name: customrouter name: config-volume ...
변경 사항을 저장하고 편집기를 종료합니다. 이렇게 하면
ipfailover-keepalived
가 다시 시작됩니다.