Docker Compose
서비스의 개발과 CI를 위해 여러 개의 컨테이너를 하나의 프로젝트로서 다루기 위해 사용한다. 컨테이너의 옵션과 환경을 정의한 파일을 순차적으로 읽으며 구축한다.
- 각 컨테이너의 의존성, 네트워크, 볼륨을 함께 정의할 수 있다.
- 설정파일에 정의된 서비스의 컨테이너 수를 유동적으로 조절할 수 있다.
- 서비스 디스커버리는 자동으로 이뤄진다.
Docker Compose Usage
Compose 기본
web, mysql services에 대한 도커 이미지 명과 기본적인 포트, 링크정보를 포함하고 있다. 다만 docker-compose ps 로 확인하기 위해서는 해당 컨테이너의 프로젝트 경로( 직접 명시하지 않았다면 yml파일이 있던 루트경로 )에서 명령어를 입력해야 확인할 수 있다. docker ps는 그냥 확인가능하다.
1
2
3
4
5
6
7
8
9
10
11
12
| version: '3.0'
services:
web:
image: alicek106/composetest:web
ports:
- "80:80"
links:
- mysql:db
command: apachectl -DFOREGROUND
mysql:
image: alicek106/composetest:mysql
command: mysqld
|
1
2
3
4
5
6
| docker-compose psㅋ
Name Command State Ports
----------------------------------------------------------------------------------
docker_mysql_1 mysqld Up
docker_web_1 apachectl -DFOREGROUND Up 0.0.0.0:80->80/tcp,:::80->80/tcp
|
Compose 활용
yarm file은 크게 버전 정의, 서비스 정의, 볼륨 정의, 네트워크 정의 4가지 항목으로 구성된다.
Questions
1. 특정 yarm 파일에서 생성된 다수의 프로젝트를 제어하기 위해서는 -f
옵션과 -p
옵션을 사용한다. 각 옵션을 설명하라
1
2
| 1) -f : yarm file의 위치를 지정한다.
2) -p : 프로젝트의 이름을 명시한다.
|
2. 컨테이너들이 의존관계를 가지는 경우, 선행 컨테이너가 완벽히 준비되고 나서 후행 컨테이너를 실행시키려면 어떤 방법을 사용하는가?
1
| 선행 컨테이너의 상태를 확인할 수 있는 쉘 스크립트를 후행 컨테이너의 entrypoint로 지정한다.
|
3. YAML 파일과 스웜모드를 함께 사용하는 환경에서 생성된 컨테이너의 묶음을 뜻하는 말로, YAML의 서비스를 스웜모드의 서비스로 변환한 이 개념은 무엇인가?
또, 스택 생성시에 무시되는 YAML 옵션은 무엇인가?
1
2
| 1) 스택(stack)
2) links, depends_on과 같이 의존성을 나타내는 항목. 의존성 개념을 사용하려면 양 컨테이너가 같은 호스트에 생성되어야 하기 떄문이다.
|
4. 도커 컨테이너를 구성하는 3가지 구성요소와 각각의 기능을 설명하라
1
2
3
| 1) runC : OCI(Open Container Initiative) 런타임 표준을 준수하는 컨테이너를 생성 및 실행하기 위한 툴
2) containerd : 여러개의 runC 컨테이너 프로세스 및 이미지를 관리하는 주체
3) docker-engine : containerd와 통신해 runC를 사용할 수 있게 하는 엔드유저용 툴
|
5. on-premise와 cloud 모두에서 사용 가능한 k8s(kubernetes) 서비스는 무엇인가?