SaltStack-MinionFS를 파일 서버로 사용

그만큼 MinionFSMinions가 파일을 교환 할 수 있도록 Salt에서 제공하는 특수 파일 서버입니다. MinionFS에서 제공하는 파일은 미니언이 의도적으로 공유 한 파일입니다. 파일을 공유하려면 미니언이 아래 단계를 따라야합니다.

  • 소스 미니언은 파일을 솔트 마스터로 푸시해야합니다. cp.push 함수.

  • 소스 미니언이 파일을 푸시하면 MinionFS 파일 서버를 사용하여 다른 미니언이 배포 된 파일에 액세스 할 수 있습니다.

푸시 활성화

기본적으로 미니언이 파일을 마스터에 푸시하는 것은 비활성화되어 있습니다. 미니언의 파일을 수락하려면 마스터는 구성 파일에 "file_recv"옵션이 있어야하며 해당 값은 다음으로 설정되어야합니다.True. 기본적으로 "file_recv"인 경우 값은false.

file_recv: True

옵션이 활성화되면 마스터 서비스를 다시 시작하십시오.

파일 푸시

미니언은 파일을 마스터에게 푸시 할 수 있습니다. 그것은에 의해 수행됩니다cp.push함수. 이 cp.push 함수는 미니언 ID를 사용하여 미니언별로 파일을 푸시하는 쉬운 메커니즘을 제공합니다.

salt 'minion-id' cp.push /path/to/the/file

여기에서 minion-id는 파일을 푸시하는 미니언을 식별하는 데 사용됩니다. 이 명령은 파일을 다음과 같은 하위 디렉토리에 저장합니다.minions 아래의 master's cachedir. 일반적으로 경로는 – / var / cache / salt / master / minions입니다.

미니언에게는 m1 그리고 파일 – /var/log/mylog.txt, 파일은 – /var/cache/salt/master/minions/m1/var/log/mylog.txt에 저장됩니다.

MinionFS 활성화

MinionFS를 활성화하려면 간단히 minion 다음 코드 블록과 같이 파일 서버 백엔드 설정에서.

fileserver_backend:
   - roots
   - minion

MinionFS가 활성화되면 미니언 푸시 파일을 다음과 같이 사용할 수 있습니다.

salt://<minion-id>/path/to/pushed/file

미니언에게는 m1 푸시 된 파일 – /var/log/mylog.txt, 푸시 된 파일은 salt : //m1/var/log/mylog.txt에서 제공됩니다.

이 minionFS는 다음 구성을 사용하여 특수 디렉토리에 마운트 할 수 있습니다. minionFS 파일을 다른 파일과 분리하고 미니언 파일을 구성하는 데 도움이됩니다.

minionfs_mountpoint: salt://minionfs

위 구성의 경우 파일은 minionfs 디렉토리-salt : //minionfs/m1/var/log/mylog.txt

MinionFS 고급 옵션

MinionFS는 또한 특정 미니언에서 푸시 된 파일의 가용성을 활성화 / 비활성화하는 옵션을 제공합니다. 옵션은minionfs_whitelist, 미니언 및 minionfs_blacklist, 미니언을 비활성화합니다.

minionfs_whitelist:
   - webserver
   - develop*
   - ‘mail\d+.mysite.com'

minionfs_blacklist:
   - testing

위의 구성에서 testing minionFS를 사용하여 파일을 공유 할 수 있습니다.

  • Webserver1

  • ID가 정규 표현식과 일치하는 미니언은 다음을 개발합니다. *

  • ID가 정규 표현식과 일치하는 미니언 mail\d+.mysite.com.

  • Testing

다음 장에서는 Cron을 Salt와 함께 사용하는 방법을 배웁니다.