일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | |||
5 | 6 | 7 | 8 | 9 | 10 | 11 |
12 | 13 | 14 | 15 | 16 | 17 | 18 |
19 | 20 | 21 | 22 | 23 | 24 | 25 |
26 | 27 | 28 | 29 | 30 | 31 |
- 포인트앱
- Container
- docker network
- built-in
- 하나머니
- 리뷰
- 커피머니불리기
- Python
- DocumentDB
- namespace
- 리워드앱
- 토스카드
- python3
- Linux
- MongoDB
- VPC
- network
- S3
- 도커
- codecommit
- clone
- 재테크
- 실사용
- mininet
- 후기
- aws codecommit
- AWS
- docker
- MongoEngine
- 앱테크
- Today
- Total
ㅍㅍㅋㄷ
Saltstack 너란 녀석. - Grains와 Pillar (2) 본문
Saltstack : Grains 와 Pillar
Saltstack을 이용해 인프라 구성 자동화를 구현하려면 Grains 와 Pillar 의 개념을 잘 알아야 한다.
이 두가지는 비슷하면서도 달라서 처음 사용하는 경우 헷갈리기 쉽다.
Grains와 Pillar의 특징과 이용방법에 대해 간단히 알아보자.
1. Grains
[출처: https://docs.saltstack.com ]
Grains는 타겟 서버에 대한 시스템 정보들을 가리킨다.
이 정보에는 서버의 OS, kernel 정보에서 부터 CPU, MEM 같은 resource 정보들이 포함되어 있다.
Grains 정보들은 salt-minion 데몬에 의해 자동으로 수집되거나 master에게 명령을 받았을때 수행하게 되고
취합 결과를 master 에게 전달하게 된다.
아래는 minion이 설치된 서버에서 수집한 Grains 정보 이다.
Grains 정보를 보려면 master에서 아래와 같이 입력하면 된다.
root@~~# salt '*' grains.items
saltstack.song.test:
----------
...(중략)
cpu_model:
Intel(R) Xeon(R) CPU E5-2630 0 @ 2.30GHz
cpuarch:
x86_64
domain:
song.test
fqdn:
saltstack.song.test
fqdn_ip4:
- 10.0.200.27
fqdn_ip6:
gpus:
|_
----------
model:
SVGA II Adapter
vendor:
unknown
host:
saltstack
hwaddr_interfaces:
----------
ens160:
XX:XX:XX:XX:XX:XX
lo:
00:00:00:00:00:00
id:
saltstack.song.test
init:
systemd
ip_interfaces:
----------
ens160:
- 10.0.200.27
- XX:XX:XX:XX:XX:XX
lo:
- 127.0.0.1
- ::1
kernel:
Linux
kernelrelease:
3.10.0-327.4.4.el7.x86_64
locale_info:
----------
defaultencoding:
UTF-8
defaultlanguage:
en_US
detectedencoding:
UTF-8
localhost:
proti-mp01-mor03
lsb_distrib_id:
CentOS Linux
manufacturer:
VMware, Inc.
master:
10.0.200.17
mdadm:
mem_total:
1840
nodename:
saltstack
num_cpus:
1
num_gpus:
1
os:
CentOS
os_family:
RedHat
osarch:
x86_64
oscodename:
Core
osfinger:
CentOS Linux-7
osfullname:
CentOS Linux
osmajorrelease:
7
osrelease:
7.2.1511
osrelease_info:
- 7
- 2
- 1511
...(중략)
위에서 볼 수 있듯이 Grains의 기본 포맷은 YAML 이다.
이 포맷은 --out 옵션으로 변경도 가능하다. 아래는 json 포맷으로 변경하여 출력하는 예이다.
root@~~# salt --out=json '*' grains.items
출력 결과를 보면,
Grains 정보에는 현재 OS 배포판, 커널 정보 부터
이더넷 인터페이스 이름과 IP, MAC 정보 와 같은 네트워크 관련 정보도 알 수 있다.
그리고 현재 서버의 CPU, Memory같은 resource 정보들도 손쉽게 얻을 수 있다.
"그렇다면 Grains 는 어떻게 이용하면 되는가?"
이렇게 수집된 Grains 정보는 인프라 자동화를 구현하는데 유용하게 쓰일 수 있다.
예를 들어보자.
만약 saltstack 으로 관리하려는 서버가 1000대가 있다고 가정해보자.
이 서버의 일부는 CentOS 일수도 있고, Ubuntu 또는 Windows 일수 도 있다.
이러한 경우에 작업자가 CentOS 에만 작업을 하고 싶다면?
또는 특정 커널 버전의 OS만 작업을 하고 싶은 경우도 있다.
또는 CPU 가 2core 인 서버만 작업을 하고 싶은 경우도 있을 수 있다.
즉, 작업 대상을 시스템 정보를 기준으로 구분짓고 싶을 경우
Grains는 굉장히 유용하게 사용이 가능하다.
예를들어, Grains를 이용해 OS가 CentOS인 서버의 hostname만 출력해보자.
root@~~# salt -G os:CentOS grains.item host
또는 kernel 버전이 3.10 인 서버의 IP만을 출력해보자.
root@~~# salt -G kernelrelease:3.10* grains.item ipv4
이렇게 Grains를 이용해 원하는 대상만 고를 수 있다.
또한, 사용자가 직접 Grains에 정보를 추가할 수도 있다.
root@~~# salt 'web-01' grains.append roles webserver
web-01 이라는 서버의 grains 에 roles : webserver 라는 key:value 값을 추가하는 명령이다.
이렇게 사용자가 직접 grains 값을 입력하여 이용이 가능하다.
2. Pillar
[출처: https://docs.saltstack.com ]
Pillar 는 master 에서 global 하게 정의하는 변수이다.
이 변수는 key value 형태로 사용자가 master에 파일로 작성한다.
그리고 minion은 이 pillar 파일을 받아 사용하게 된다.
즉, Pillar는 Grains와 정보 추출 방향이 정 반대 방향임을 알 수 있다.
- Grains : Minion이 수집하여 Master에게 전달
- Pillar : Master의 Pillar 파일 정보를 Minion에게 전달
pillar 파일 위치는 master의 설정에 따라 다르다.
master의 설정 파일은 /etc/salt/master 에 있다.
root@~~# vim /etc/salt/master
... (중략)
# Salt Pillars allow for the building of global data that can be made selectively
# available to different minions based on minion grain filtering. The Salt
# Pillar is laid out in the same fashion as the file server, with environments,
# a top file and sls files. However, pillar data does not need to be in the
# highstate format, and is generally just key/value pairs.
pillar_roots:
base:
- /srv/pillar
현재 pillar의 root path는 /srv/pillar 로 정의되어 있다.
최초로 실행되는 pillar 파일은 /srv/pillar 디렉토리 하위에 init.sls 라는 이름으로 정의하면 된다.
"보통 pillar 에 정의하는 변수는 어떤 것들이 있을까?"
보통의 경우 pillar 에는 시스템 정보 외에 주로 application을 위한 설정 정보들을 선언하여 사용한다.
예를 들면,
- service URL
- application의 설정 Path
- 참조되는 IP, Port 정보
- username
mysql:
master: mdb01
keepalived:
service_interface: ens160
auth_pass: AYQBCB$@
vips:
- 10.0.0.101
set_mysql: True
root_password: XXXXXXX
set_replication: True
replication_user: repl
replication_password: XXXXXXXX
Grains 와 Pillar의 조합
Saltstack에서 제공하는 Grains 와 Pillar 를 적절히 조합하면 인프라 자동화를 위한 다양한 케이스에 대해 대응이 가능하다.
예를 들어,
saltstack으로 관리하는 수천대의 서버중
hostname이 mdb01 과 mdb02에 두 서버에 mysql 을 설치 자동화로 구현 한다고 가정해 보자.
가장 첫번째로 해야할 일은 작업할 target 선정이다.
간단한 방법으로 위에서 설명했던 Grains를 이용해 mdb01 과 mdb02에 role:db 로 저장한 후,
pillar에 mysql을 위한 설정 변수들을 선언해 자동화 코드를 구현하면 될 것이다.
[참고]
- https://docs.saltstack.com/en/getstarted/overview.html
- https://docs.saltstack.com/en/getstarted/system/data.html
- https://www.digitalocean.com/community/tutorials/an-introduction-to-saltstack-terminology-and-concepts
'IT > Saltstack' 카테고리의 다른 글
Saltstack 너란 녀석. - 장점과 구조(1) (2) | 2016.05.26 |
---|