꼭두각시-개요

Puppet은 인프라 관리 및 구성을 자동화하기 위해 Puppet Labs에서 개발 한 구성 관리 도구입니다. Puppet은 코드로서의 인프라 개념을 돕는 매우 강력한 도구입니다. 이 도구는 Ruby DSL 언어로 작성되어 전체 인프라를 코드 형식으로 변환하는 데 도움이되며 쉽게 관리하고 구성 할 수 있습니다.

Puppet은 클라이언트-서버 모델을 따르며, 클러스터의 한 시스템은 puppet 마스터라고하는 서버 역할을하고 다른 시스템은 노드에서 슬레이브로 알려진 클라이언트 역할을합니다. Puppet은 초기 구성부터 특정 시스템의 수명이 다할 때까지 모든 시스템을 처음부터 관리 할 수있는 기능이 있습니다.

Puppet System의 특징

다음은 Puppet의 가장 중요한 기능입니다.

멱 등성

Puppet은 고유하게 만드는 멱 등성을 지원합니다. Chef와 유사하게 Puppet에서는 동일한 시스템에서 동일한 구성 세트를 여러 번 안전하게 실행할 수 있습니다. 이 흐름에서 Puppet은 대상 컴퓨터의 현재 상태를 확인하고 구성에 특정 변경 사항이있는 경우에만 변경합니다.

멱등 성은 시스템 생성부터 시스템의 구성 변경, 수명이 끝날 때까지 수명주기 동안 특정 시스템을 관리하는 데 도움이됩니다. Puppet Idempotency 기능은 구성 변경이있을 때 동일한 시스템을 여러 번 재 구축하는 것보다 수년간 시스템을 업데이트하는 데 매우 유용합니다.

크로스 플랫폼

Puppet에서는 Puppet 리소스를 사용하는 RAL (Resource Abstraction Layer)의 도움을 받아 구현 세부 사항과 기본 구성에 정의 된 구성 명령이 시스템 내에서 작동하는 방식에 대해 걱정하지 않고 지정된 시스템 구성을 대상으로 지정할 수 있습니다. 파일.

Puppet-워크 플로우

Puppet은 다음 워크 플로를 사용하여 시스템에 구성을 적용합니다.

  • Puppet에서 Puppet 마스터가 수행하는 첫 번째 작업은 대상 컴퓨터의 세부 정보를 수집하는 것입니다. 모든 Puppet 노드 (Chef의 Ohai와 유사)에있는 요소를 사용하여 모든 머신 수준 구성 세부 정보를 가져옵니다. 이러한 세부 정보는 수집되어 Puppet 마스터로 다시 전송됩니다.

  • 그런 다음 Puppet 마스터는 검색된 구성을 정의 된 구성 세부 정보와 비교하고 정의 된 구성과 함께 카탈로그를 생성하여 대상 Puppet 에이전트로 보냅니다.

  • 그런 다음 Puppet 에이전트는 이러한 구성을 적용하여 시스템을 원하는 상태로 만듭니다.

  • 마지막으로 대상 노드가 원하는 상태에 있으면 보고서를 Puppet 마스터로 다시 전송하여 Puppet 마스터가 카탈로그에 정의 된대로 시스템의 현재 상태를 이해하는 데 도움을줍니다.

Puppet-주요 구성 요소

다음은 Puppet의 주요 구성 요소입니다.

꼭두각시 리소스

Puppet 리소스는 특정 머신을 모델링하기위한 핵심 구성 요소입니다. 이러한 리소스에는 자체 구현 모델이 있습니다. Puppet은 동일한 모델을 사용하여 원하는 상태의 특정 리소스를 가져옵니다.

제공자

공급자는 기본적으로 Puppet에서 사용되는 특정 리소스의 이행자입니다. 예를 들어 패키지 유형 'apt-get'및 'yum'은 모두 패키지 관리에 유효합니다. 때로는 특정 플랫폼에서 둘 이상의 공급자를 사용할 수 있습니다. 각 플랫폼에는 항상 기본 공급자가 있습니다.

명백한

매니페스트는 모든 대상 시스템을 구성하기 위해 함수 또는 클래스 내에서 결합 된 리소스 모음입니다. 여기에는 시스템을 구성하기위한 Ruby 코드 세트가 포함되어 있습니다.

모듈

모듈은 Puppet의 핵심 빌딩 블록으로, 리소스, 파일, 템플릿 등의 모음으로 정의 할 수 있습니다. 동일한 풍미로 정의되는 여러 종류의 OS간에 쉽게 배포 할 수 있습니다. 쉽게 배포 할 수 있기 때문에 하나의 모듈을 동일한 구성으로 여러 번 사용할 수 있습니다.

템플릿

템플릿은 Ruby 표현식을 사용하여 사용자 정의 된 콘텐츠 및 변수 입력을 정의합니다. 사용자 지정 콘텐츠를 개발하는 데 사용됩니다. 템플릿은 매니페스트에 정의되고 시스템의 위치에 복사됩니다. 예를 들어 사용자 정의 가능한 포트로 httpd를 정의하려는 경우 다음 표현식을 사용하여 수행 할 수 있습니다.

Listen <% = @httpd_port %>

이 경우 httpd_port 변수는이 템플릿을 참조하는 매니페스트에 정의되어 있습니다.

정적 파일

정적 파일은 특정 작업을 수행하는 데 필요한 일반 파일로 정의 할 수 있습니다. Puppet을 사용하여 한 위치에서 다른 위치로 간단히 복사 할 수 있습니다. 모든 정적 파일은 모든 모듈의 파일 디렉토리에 있습니다. 매니페스트의 파일 조작은 파일 리소스를 사용하여 수행됩니다.