소개
HashiCorp의 Consul는 현대 DevOps 환경에서 다양한 기능을 수행하는 유용한 도구입니다. 이를 서비스 DISCOVERY, 健壮性 ckeck, 로드 balancing 및 특이히 분산 KeY-VALUE (KV) 스토어로 널리 사용합니다. Consul의 KV 스토어는 동적 구성 데이터, 기능 flags, secrets, 및 metadata를 하이 availability, 일관성을 보장하는 인프RASTRUCTURE 내에서 동적으로 서비스에서 사용할 수 있는 방식으로 보관하는 것에 완벽합니다. Docker을 사용하여 Consul의 KV 스토어를 구성하면 빠른 세팅과 isolate 환경을 얻을 수 있습니다. 이를 테스트와 개발에서 理想한 것입니다.
이 자습서는 Docker를 사용하여 Consul의 KV 스토어를 설정하고 구성하는 과정을 guided 할 것입니다. 결과적으로, Docker에서 실제 기능이 완전한 Consul 인스턴스가 실행되고, KV 쌍이 구성되어 있고 액세스 할 수 있습니다. 이 세팅은 분산 시스템에서 서비스 구성과 상태 관리에 필요합니다.
사전 요구 사항
시작하기 전에는 다음과 같은 것을 확인하십시오 :
- DigitalOcean 云 계정.
- Ubuntu 서버를 실행하고 루트 권한을 갖지 않은 sudo 사용자를 가지고 있으며, 활성화 된 방화벽을 갖추고 있습니다. 이러한 조건을 만족시키는 방법에 대한 지침은 다음 목록에 있는 여러분의 분리 정보에 따라 시작하여 우리의 기본 서버 세팅 가이드를 遵循하십시오. Ubuntu의 지원되는 버전을 사용하여 작업하십시오.
- Ubuntu Droplet에 Docker이 설치되었습니다. 이러한 도커 Installation and Usage Guide를 遵循하십시오.
- Linux 명령行工具에 慣れている 것입니다. 명령行에 대한 소개 또는 다시 배우는 것이 필요하면 이곳의 Linux Command Line Primer Guide를 访问하십시오.
- Docker 명령어 및 컨테이너 관리에 대한 기본 지식을 갖추었습니다.
Step 1 — Pulling the Consul Docker Image
Docker Hub에서 공식 Consul 이미지를 풀어 봅니다. 이 이미지는 HashiCorp에 의해 관리되며 Consul를 실행하기 위해 필요한 모든 것을 포함합니다.
Ubuntu Droplet의 콘솔에 로그인하고 다음을 실행합니다.:
스텝 2 — Consul 컨테이너 실행
Consul 이미지가 다운로드 되었으면 새로운 Consul 컨테이너를 시작할 수 있습니다. 이 컨테이너는 Consul 서버로 사용되며 KV 스토어와 interact with를 permits you to interact with the KV store.
컨테이너를 시작하려면 다음 명령을 실행합니다:
-d
컨테이너를 배경 모드로(bg) 실행합니다.
--name=consul-server
컨테이너에 이름을 지정합니다.-e CONSUL_BIND_INTERFACE=eth0
Consul가 bind 해야하는 network interface를 설정합니다. 이것은 적절한 네트워크 통신을 위해 필요합니다.-p 8500:8500
Consul web UI와 API 포트를 호스트에 매핑합니다.-p 8600:8600/udp
service discovery 用的 DNS 서비스 포트를 매핑합니다.- 이 단계는 的核心 Consul 서비스를 설정하는 것이 중요합니다. 이를 통해 KV 스토어를 구성할 수 있습니다.
이번 단계가 중요합니다.
스텝 3 — Consul 설치 확인
Consul가 正確하게 실행 중인지 확인하고 Consul UI에 접근하기 위해서는 컨테이너 상태를 확인해야 합니다.
퍼스트, docker ps
명령을 실행하여 모두 실행 중인 컨테이너 목록을 列出하고 컨사이클 컨테이너가 실행 중인지 확인합니다.
이제, 컨사이클이 存 Scientifically 하는지 확인하고, 웹 브라우저를 OPEN하고 http://localhost:8500
으로 이동하여 컨사이클 UI를 보여 주는지 확인합니다.
이 확인 단계는 第五 단계에서 KV 스토어에 데이터를 저장하기 전에 Your Consul instance is running without any issues 를 확인하는 重要性를 가지고 있습니다.
第四步 — 방화벽 구성 (옵셕)
Your Consul instance needs to be accessed externally (e.g., from other nodes in a cluster), you must adjust your firewall settings to allow traffic on the necessary ports.
For example, if you’re running Consul on a cloud instance, you may need to allow inbound traffic on ports 8500 (HTTP API) and 8600 (DNS). The specific commands will vary based on your firewall solution (UFW, iptables, etc.).
This step ensures that your Consul instance is accessible from other machines, which is essential for distributed configurations.
第五步 — 键值对 저장
Consul이 실행 중이면 KV 스토어를 사용하여 configurations 데이터를 저장할 수 있습니다. Consul CLI나 웹 UI를 사용하여 キー-値 쌍을 추가할 수 있습니다.
CLI를 사용하여 키-값 쌍을 저장하려면 다음과 같은 명령을 실행합니다:
이 명령어는 다음과 같은 일을 합니다:
-it
– 로컬 시스템から 컨테이너로 인터랙티브 터미널을 실행합니다.consul kv put
– kv put 명령어는 give 경로 KV 스토어에 데이터를 기록합니다.config/db_host
– 값을 저장하는 경로입니다.192.168.1.100
– 값입니다.
웹 UI를 사용하여,
- Consul UI로 이동하세요 (
http://localhost:8500
). - “Key/Value” 탭을 클릭하세요.
- 새 키를 생성하기 위해 “Create”를 클릭하세요.
- 키(예:
config/db_host
)와 값(예:192.168.1.100
)를 입력하세요.
이러한 명령과 동작은 서비스가 실시간에 동적으로 액세스할 수 있는 중요한 구성 데이터를 저장합니다.
Step 6 — 키-값 쌍 조회
KV 쌍을 저장한 다음, 그들이 正しく 저장되었는지 여부를 확인하기 위해 조회하는 것이 중요합니다.
CLI를 사용하여 다음 명령을 사용하여 값을 조회합니다:
웹 UI를 사용하여,
- Consul UI 中的 “Key/Value” 标签页로 가십시오.
- 생성하신 키를 찾으십시오. 그리고 그 키에 클릭하여 보관된 값을 보십시오.
KV 쌍을 가져오는 과정은 자신의 데이터가 correct하게 보관되고 액세스 가능한지 확인하는 필수적인 단계입니다.
第七步 — 使用 Docker 卷持久化数据
Docker 컨테이너는 기본적으로 영구적이 아닌 것을意味하는 ephemeral로, 컨테이너를 제거하면 내부에 보관된 모든 데이터가 사라집니다. Consul KV 데이터를 보관하려면 Docker 卷를 사용해야 합니다.
- 현재 Consul 컨테이너를 중지하고 제거하십시오:
이제, 컨테이너를 확인하면 Consul 컨테이너가 더 이상 실행되고 있지 않을 것입니다.
2. Docker 卷를 연결한 새로운 Consul 컨테이너를 실행하십시오:
`-v consul_data:/consul/data` 옵션은 Docker 卷을 컨테이너에 마ount하여 KV 스토어가 컨테이너 재시작 사이에 보관되는 것을 Ensure합니다.
第八步 — Consul 시작을 자동화하는 방법 (선택적)
생산 배포 시에는 Docker Compose를 사용하여 Consul 컨테이너의 시작을 자동화하는 것이 좋습니다. Docker Compose는 다수의 컨테이너를 사용하는 Docker 응용 프로그램을 간단하게 관리하고 서비스를 관리하는 것을 简単하게 도와줍니다.
다음과 같은 내용으로 docker-compose.yml
파일을 생성합니다.
그 다음, 다음 명령을 실행합니다.
이 명령은 Consul을 자동으로 시작하고 실패하면 다시 시작하도록 하여 생산用途에 적절한 健壮性을 제공합니다.
단계 9 — 정리
Consul 인스턴스를 사용하고 있었다면, Docker 환경을 정리하여 자원을 释放해야 합니다.
Consul 컨테이너를 중지하고 제거하는 것을 하고 있습니다.
Consul을 사용하지 않는다면 Docker 이미지도 제거할 수 있습니다.
정리는 開発 환경을 整潔하게 유지하고 Docker 자원을 unnecessarily 소모하지 않도록 도와줍니다.
결론
이 튜토리얼에서는 Docker를 사용하여 Consul KV 스토어를 세팅하고 configurations. With these steps, you can now use Consul to dynamically manage configuration data in your distributed systems, leveraging the power of Docker for easy deployment and management.
Source:
https://www.digitalocean.com/community/tutorials/how-to-configure-consul-kv-using-docker