> Dockerfile 기반으로 테스트를 위한 프로젝트입니다.
> dockerfile을 기반으로 간단한 Nginx를 설치하고 index.html에 접근해봅니다.
- 참고 Reference : Dockerfile 이해하고 Nginx 구성 및 실행하기
# docker 컨테이너 이미지 생성
$ docker build -t nginx:simple-nginx .
# docker 컨테이너 생성 및 실행
$ docker run -d -p 8080:80 --name simple-nginx nginx:simple-nginx
> dockerfile을 기반으로 간단한 Vault를 설치하고 수행합니다.
- 참고 Reference : Dockerfile로 Vault 구성 방법
# docker 컨테이너 이미지 생성
$ docker build -t hashicorp/vault .
# docker 컨테이너 생성 및 실행
$ docker run -d --cap-add IPC_LOCK --name vault -p 8200:8200 hashicorp/vault
> dockerfile을 기반으로 간단한 React App을 생성하고 실행합니다.
- 참고 Reference : Dockerfile을 이용한 React 배포 환경 구성 및 실행하기
# 컨테이너 이미지 생성
$ docker build . -t simple-react-app .
# 컨테이너 생성 및 실행
$ docker run -d --name simple-react-app -p 3000:3000 simple-react-app
> dockerfile을 기반으로 간단한 Spring Boot App을 생성하고 실행합니다.
- 참고 Reference : Dockerfile을 이용한 Spring Boot App 배포 환경 구성 및 실행하기
# 컨테이너 이미지 생성
$ docker build -t simple-spring-boot-app .
# 컨테이너 생성 및 실행
$ docker run -d --name simple-spring-boot-app -p 8080:8080 simple-spring-boot-app
> dockerfile을 기반으로 간단한 Redis을 생성하고 실행합니다.
- 참고 Reference : Dockerfile을 이용한 Redis 환경 구성 및 실행방법
# 프로젝트 접근
$ cd simple-redis
# 컨테이너 이미지 생성
$ docker build . -t simple-redis
# 컨테이너 생성 및 실행
$ docker run -d --name simple-redis -p 6379:6379 simple-redis
# docker 컨테이너 아이디를 확인합니다
$ docker ps
# redis-cli를 접근합니다.
$ docker exec -it <CONTAINER ID> redis-cli
> dockerfile을 기반으로 간단한 RabbitMQ을 생성하고 실행합니다.
- 참고 Reference : Dockerfile을 이용한 RabbitMQ 환경 구성 및 실행방법
# 프로젝트 접근
$ cd simple-rabbitmq
# 컨테이너 이미지 생성
$ docker build -t simple-rabbitmq .
# 컨테이너 생성 및 실행
$ docker run -d --name simple-rabbitmq -p 5672:5672 -p 15672:15672 rabbitmq
> docker-compose를 이용한 React App, Spring Boot App 일괄 배포하기
- 참고 Reference : Docker 이해하기 -4 : Docker Compose 이해하고 구성하기
# 프로젝트 접근
$ cd simple-docker-compose
# docker compose 실행
$ docker-compose up
# docker compose 상태 확인
$ docker-compose ps
# docker compose 삭제
$ docker-compose down
> docker-compose를 이용하여 RabbitMQ 클러스터링 배포하기
# 프로젝트 접근
$ cd simple-docker-compose-rabbitmq-cluster
# docker compose 실행
$ docker compose up
# docker compose 상태 확인
$ docker compose ps
# 1. rabbitmq-1을 기준으로 rabbitmq-2, rabbitmq-3 앱을 중지(stop_app), 앱을 초기화(reset)를 수행합니다.
# 2. rabbitmq-1에 클러스터로 rabbitmq-2, rabbitmq-3을 추가합니다(join_cluster)
# 3. rabbitmq-2, rabbitmq-3을 실행합니다(start_app)
docker exec -it rabbitmq-2 rabbitmqctl stop_app
docker exec -it rabbitmq-2 rabbitmqctl reset
docker exec -it rabbitmq-2 rabbitmqctl join_cluster rabbit@rabbitmq-1
docker exec -it rabbitmq-2 rabbitmqctl start_app
docker exec -it rabbitmq-3 rabbitmqctl stop_app
docker exec -it rabbitmq-3 rabbitmqctl reset
docker exec -it rabbitmq-3 rabbitmqctl join_cluster rabbit@rabbitmq-1
docker exec -it rabbitmq-3 rabbitmqctl start_app
> docker-compose를 이용하여 Apache Kafka 배포하기
# 프로젝트 접근
$ cd simple-apache-kafka
# docker compose 실행
$ docker-compose -f compose.yml up -d
# docker compose 상태 확인
$ docker-compose -f compose.yml ps
# 컨테이너 접속
$ docker exec -it [kafka-container-id] bash
# 토픽 생성
$ kafka-topics --create --topic test-topic --bootstrap-server localhost:9092 --partitions 1 --replication-factor 1
# 토픽 목록 확인
$ kafka-topics --list --bootstrap-server localhost:9092