SaltStack-작업 관리

Salt는 많은 시스템과의 고속 통신 기능을 가지고 있습니다. 이 접근 방식은 Salt가 강력한 멀티 태스킹 시스템을 만드는 데 도움이됩니다. Salt는 둘 이상의 시스템에서 작업을 실행할 수 있으므로 Salt는 작업 관리 기술을 사용하여 모든 시스템에서 실행되는 각 작업을 관리합니다. 이 장에서는 작업 관리에 대해 자세히 설명합니다.

Job ID 란 무엇입니까?

Salt에는 캐시 디렉토리가 있습니다. cachedir. 이 안에 미니언이 유지하는 디렉토리를proc예배 규칙서. 다음 디렉토리 / var / cache / salt / proc에 있습니다.

proc 디렉토리는 모든 파일을 유지하는 데 사용됩니다. 이러한 파일이 실행되면 고유 한 작업 ID가 할당됩니다. 이 작업 ID는 미니언에서 현재 실행중인 작업을 식별하고 작업을 조회하는 데 도움이됩니다.

SALTUTIL 모듈

Salt는 Saltutil 작업 관리 프로세스라는 새로운 모듈을 도입했습니다. 이 모듈에는 작업을 관리하는 다양한 기능이 포함되어 있습니다. 이 기능은 미니언 레벨에서 작업을 관리하는 데 사용됩니다. 기능은 다음과 같이 간략하게 설명됩니다.

  • running − proc 디렉토리에있는 실행중인 모든 작업 데이터를 반환합니다.

  • find_job − 작업 ID를 기반으로 특정 작업에 대한 특정 데이터를 반환합니다.

  • signal_job − 주어진 작업 ID (jid)에 신호를 보낼 수 있습니다.

  • term_job − 지정된 작업에 대한 종료 신호를 보냅니다.

  • kill_job − 지정된 작업에 대한 종료 신호를 보냅니다.

잡스 러너

작업 실행기에는 데이터를보다 쉽고 깔끔하게 볼 수있는 기능이 포함되어 있습니다. 다른 기능이 있습니다. 이러한 각 기능에 대해 자세히 설명하겠습니다.

활성 기능

활성 기능은 아직 실행중인 작업을 식별하고 작업을 완료 한 시스템과 대기중인 시스템을 확인하는 데 사용됩니다. 다음 명령을 사용하여 실행됩니다.

salt-run jobs.active

LOOKUP_JID 함수

lookup_jid 실행기는 현재 찾고있는 작업에 대한 데이터를 표시합니다. 이러한 작업은keep_jobs마스터 구성의 옵션. 다음 명령을 사용하여 실행됩니다.

salt-run jobs.lookup_jid <job id number>

LIST_JOBS 함수

List_jobs 함수는 작업에 대한 작업 데이터를 나열하는 데 사용됩니다. 다음 명령으로 표현됩니다-

salt-run jobs.list_jobs

작업 일정

일정 시스템은 미니언 또는 마스터의 러너에 대한 실행 기능의 실행을 노출합니다.

다음과 같은 방법으로 수행됩니다.

  • Schedule − 마스터 또는 미니언의 일정 옵션 config 파일.

  • Minion pillar data − saltutil.refresh_pillar 명령을 사용하여 미니언 필러 데이터를 새로 고칩니다.

  • 일정 상태 또는 일정 모듈입니다.

솔트 상태는 미니언에서 실행됩니다. 위치 인수를 전달하고YAML dict 명명 된 인수의 config file 아래 그림과 같이.

schedule:
   job1:
      function: saltstate.sls
      seconds: 3600
      args:
         - httpd
      kwargs:
         test: True

여기, job1 함수를 실행합니다 saltstate.sls 지정된 인수로 httpd매시간. 그만큼test: True 에 대한 추가 인수입니다. httpd 정의 된 명령 saltstate.sls.