영사-설치
데모 목적으로 -dev 모드를 사용하여 개발자 모드에서 consul 에이전트를 사용할 것입니다. 로컬 머신 설정을 위해 단일 시스템 consul 설정을 수행 할 것입니다.Please do not use this single node consul cluster in your production. Hashicorp가 이미 단일 노드 consul 클러스터의 경우 시나리오에서 언급했듯이the data loss is inevitable.
Consul 설치
Consul은 다운로드 페이지 ( www.consul.io/downloads.html) 를 통해 설치할 수 있습니다.
컴퓨터의 다운로드 섹션에서 바이너리 패키지를 추출 할 수 있습니다.
$ cd Downloads
$ chmod +x consul
$ sudo mv consul /usr/bin/
이제 영사를 사용하여 -dev flag.
$ consul agent -dev -data-dir=/tmp/consul
출력은 다음 스크린 샷과 같습니다.
이제 다음 명령을 사용하여 영사 원을 확인할 수 있습니다.
$ consul members
출력은 다음 스크린 샷과 같습니다.
이 노드에 다른 노드를 결합하려면-
$ consul join <Node 2> <Node 3>
또는 노드 2 및 3에서 다음 명령을 실행할 수 있습니다.
$ consul join <Node 1>
명령 줄 사용
consul의 명령 줄은 여러 가지 옵션으로 구성되어 있으며 가장 일반적으로 사용되는 옵션은 다음과 같습니다.
agent − Consul 에이전트를 운영합니다.
configtest − 구성 파일의 유효성을 검사합니다.
event − 새로운 이벤트를 시작합니다.
exec − Consul 노드에서 명령을 실행합니다.
force-leave − 클러스터 구성원이 클러스터를 떠나도록 강요합니다.
info − 운영자를위한 디버깅 정보를 제공합니다.
join − Consul 에이전트가 클러스터에 참여하도록합니다.
keygen − 새 암호화 키를 생성합니다.
keyring − 가십 레이어 암호화 키를 관리합니다.
kv − 키-값 저장소와 상호 작용합니다.
leave − Consul 클러스터를 떠나 강제로 종료합니다.
lock − 잠금을 유지하는 명령을 실행합니다.
maint − 노드 또는 서비스 유지 관리 모드를 제어합니다.
members − Consul 클러스터의 구성원을 나열합니다.
monitor − Consul 에이전트의 로그를 스트리밍합니다.
operator − Consul 운영자를위한 도구 클러스터를 제공합니다.
reload − 에이전트가 구성 파일을 다시로드하도록 트리거합니다.
rtt − 노드 간의 네트워크 왕복 시간을 추정합니다.
snapshot − Consul 서버 상태의 스냅 샷을 저장, 복원 및 검사합니다.
version − 현재 Consul 버전을 인쇄합니다.
watch − 영사의 변경 사항을주의하십시오.
영사 템플릿
consul-template은 Consul 인스턴스를 쿼리하고 파일 시스템에서 지정된 템플릿 수를 업데이트하는 데몬을 제공합니다. consul-template은 업데이트 프로세스가 완료되면 선택적으로 임의의 명령을 실행할 수 있습니다. 이 옵션을 사용하면 모든 작업을 직접 수행하지 않고도 consul 클러스터를 설정할 수 있습니다.
영사 템플릿은 /tmp/<name-of-file>.conf.tmpfl. 템플릿이 작성된 언어Hashicorp Configuration Language (HCL).
이 페이지 에서 consul-template을 다운로드 할 수 있습니다 .
다음 명령을 사용하여 시도하십시오-
$ ./consul-template -h
출력은 다음 스크린 샷과 같습니다.
이 바이너리를 더 눈에 잘 띄는 공간으로 이동하여 매번 사용자가 사용할 수 있도록하려면. 다음 명령을 입력 할 수 있습니다-
$ chmod +x consul-template
$ sudo mv consul-template /usr/share/bin/
데모 목적으로 다음의 샘플 구성을 사용할 것입니다. nginx우리의 서비스로 사용됩니다. 더 많은 데모를 시도해 볼 수 있습니다.https://github.com/hashicorp/consul-template/tree/master/examples 또는 자신의 템플릿을 작성하는 것이 좋습니다.
$ vim /tmp/nginx.conf.ctmpl
출력은 다음 스크린 샷과 같습니다.
설정 파일은 다음과 같습니다.
{{range services}} {{$name := .Name}} {{$service := service .Name}}
upstream {{$name}} {
zone upstream-{{$name}} 64k;
{{range $service}}server {{.Address}}:{{.Port}} max_fails = 3 fail_timeout = 60
weight = 1;
{{else}}server 127.0.0.1:65535; # force a 502{{end}}
} {{end}}
server {
listen 80 default_server;
location / {
root /usr/share/nginx/html/;
index index.html;
}
location /stub_status {
stub_status;
}
{{range services}} {{$name := .Name}}
location /{{$name}} {
proxy_pass http://{{$name}};
}
{{end}}
}
이제 consul 템플릿 바이너리 파일을 사용하여 다음 명령을 실행하십시오.
$ consul-template \
-template = "/tmp/nginx.conf.ctmpl:/etc/nginx/conf.d/default.conf"
이전 명령으로 프로세스가 시작되었습니다. 나중에 다른 터미널을 열고 다음 명령을 사용하여 완전히 렌더링되는 nginx.conf 파일을 볼 수 있습니다.
$ cat /etc/nginx/conf.d/default.conf
출력은 다음 스크린 샷과 같습니다.