Skip to content

adjh54ir/multiflex-docker

Repository files navigation

multiflex-docker

> Dockerfile 기반으로 테스트를 위한 프로젝트입니다.


1. simple-nginx

> dockerfile을 기반으로 간단한 Nginx를 설치하고 index.html에 접근해봅니다.


실행 방법

# docker 컨테이너 이미지 생성
$ docker build -t nginx:simple-nginx .

# docker 컨테이너 생성 및 실행
$ docker run -d -p 8080:80 --name simple-nginx nginx:simple-nginx


2. simple-vault

> dockerfile을 기반으로 간단한 Vault를 설치하고 수행합니다.


실행 방법

# docker 컨테이너 이미지 생성
$ docker build -t hashicorp/vault .

# docker 컨테이너 생성 및 실행
$ docker run -d --cap-add IPC_LOCK --name vault -p 8200:8200 hashicorp/vault


3. simple-react-app

> dockerfile을 기반으로 간단한 React App을 생성하고 실행합니다.


실행 방법

# 컨테이너 이미지 생성
$ docker build . -t simple-react-app .

# 컨테이너 생성 및 실행
$ docker run -d --name simple-react-app -p 3000:3000 simple-react-app


4. simple-spring-boot

> 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


5. simple-redis

> 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


5. simple-rabbitmq

> dockerfile을 기반으로 간단한 RabbitMQ을 생성하고 실행합니다.


실행 방법

# 프로젝트 접근
$ cd simple-rabbitmq

# 컨테이너 이미지 생성
$ docker build -t simple-rabbitmq .

# 컨테이너 생성 및 실행
$ docker run -d --name simple-rabbitmq -p 5672:5672 -p 15672:15672 rabbitmq


6. simple-docker-compose

> docker-compose를 이용한 React App, Spring Boot App 일괄 배포하기


실행 방법

# 프로젝트 접근
$ cd simple-docker-compose

# docker compose 실행
$ docker-compose up

# docker compose 상태 확인
$ docker-compose ps

# docker compose 삭제
$ docker-compose down

6. simple-docker-compose-rabbitmq-cluster

> 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

7. simple-apache-kafka

> 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