Puppet-매니페스트 파일

Puppet에서 Ruby 프로그래밍 언어를 사용하여 작성되고 확장자로 저장되는 모든 프로그램 .pp 불린다 manifests. 일반적으로 대상 호스트 컴퓨터를 만들거나 관리하려는 의도로 빌드 된 모든 Puppet 프로그램을 매니페스트라고합니다. Puppet으로 작성된 모든 프로그램은 Puppet 코딩 스타일을 따릅니다.

Puppet의 핵심은 리소스가 선언되는 방식과 이러한 리소스가 상태를 나타내는 방식입니다. 모든 매니페스트에서 사용자는 클래스와 정의를 사용하여 함께 그룹화 된 다양한 종류의 리소스 모음을 가질 수 있습니다.

어떤 경우에는 Puppet 매니페스트에 원하는 상태를 얻기 위해 조건문이있을 수도 있습니다. 그러나 궁극적으로 모든 리소스가 올바른 방식으로 정의되고 사용되는지 확인하고 카탈로그로 변환 한 후 적용 할 때 정의 된 매니페스트가 설계된 작업을 수행 할 수 있는지 확인해야합니다.

매니페스트 파일 워크 플로

꼭두각시 매니페스트는 다음 구성 요소로 구성됩니다.

  • Files (이 파일은 Puppet과 관련이없는 일반 파일입니다. 파일을 선택하여 대상 위치에 배치하기 만하면됩니다.)

  • Resources

  • Templates (노드에서 구성 파일을 구성하는 데 사용할 수 있습니다.)

  • Nodes (클라이언트 노드와 관련된 모든 정의가 여기에 정의 됨)

  • Classes

참고 사항

  • Puppet에서 모든 매니페스트 파일은 Ruby를 인코딩 언어로 사용하고 .pp 신장.

  • 많은 매니페스트의 "Import"문은 Puppet이 시작될 때 파일을로드하는 데 사용됩니다.

  • 디렉토리에 포함 된 모든 파일을 가져 오려면 import 'clients / *'와 같은 다른 방법으로 import 문을 사용할 수 있습니다. 이것은 모두 가져옵니다.pp 해당 디렉토리 내의 파일.

매니페스트 작성

변수 작업

매니페스트를 작성하는 동안 사용자는 매니페스트의 어느 지점에서나 새 변수를 정의하거나 기존 변수를 사용할 수 있습니다. Puppet은 다양한 종류의 변수를 지원하지만 문자열 및 문자열 배열과 같이 자주 사용되는 변수는 거의 없습니다. 그 외에도 다른 형식도 지원됩니다.

문자열 변수 예

$package = "vim"  

package {  $package: 
   ensure => "installed" 
}

루프 사용

루프는 정의 된 조건이 충족 될 때까지 동일한 코드 세트에서 여러 반복을 수행하고자 할 때 사용됩니다. 또한 다른 값 세트로 반복적 인 작업을 수행하는 데 사용됩니다. 10 가지 다른 작업에 대해 10 개의 작업 생성. 단일 작업을 생성하고 루프를 사용하여 설치하려는 다른 패키지로 작업을 반복 할 수 있습니다.

가장 일반적으로 배열은 다른 값으로 테스트를 반복하는 데 사용됩니다.

$packages = ['vim', 'git', 'curl']  

package { $packages: 
   ensure => "installed" 
}

조건문 사용

Puppet은 기존 프로그래밍 언어에서 찾을 수있는 대부분의 조건부 구조를 지원합니다. 조건을 사용하여 특정 작업을 수행할지 아니면 코드 집합을 실행할지 동적으로 정의 할 수 있습니다. if / else 및 case 문과 같습니다. 또한 execute와 같은 조건은 조건처럼 작동하는 속성도 지원하지만 명령 출력 만 조건으로 허용합니다.

if $OperatingSystem != 'Linux' { 
   warning('This manifest is not supported on this other OS apart from linux.') 
} else { 
   notify { 'the OS is Linux. We are good to go!': }
}