728x90
반응형
source 는 Github 에 있습니다.
spring-boot, docker, flyway 활용해서 로컬 mysql 테스트 환경 구축
- 로컬에 docker + flyway 를 통해 로컬에 mysql 테스트 환경 구축하는 방법을 정리했습니다.
- docker 는 가상화 컨테이너이고, flyway 는 database 마이그레이션 tool 입니다.
- flyway 는 ddl 이력 관리도 가능합니다. (형상 관리)
- 또한, flyway 를 spring-boot 에서 사용하는 것은 테스트 환경을 구축할 때, 편합니다.
- 이 예제에서는 docker 를 통해 가상의 mysql 을 생성하고, flyway 를 통해 테이블을 하나 생성해 볼 예정입니다.
- docker 는 설치돼있다고 가정하고 진행하겠습니다.
source
gradle
mysql 과 flyway 설정입니다.
runtimeOnly 'mysql:mysql-connector-java' implementation 'org.flywaydb:flyway-core:7.10.0'
docker-compose
- docker 설정이며, terminal 에서 아래 명령어를 수행 시, container 가 만들어집니다.
- docker-compose -p test-db up -d
- docker-compose -p test-db up -d
# 실행 명령어
# docker-compose -p test-db up -d
version: "1"
services:
order-db:
image: mysql:8.0
ports:
- "3306:3306"
environment:
- MYSQL_DATABASE=test
- MYSQL_ROOT_PASSWORD=test1234
- MYSQL_USER=test
- MYSQL_PASSWORD=test1234
- TZ=UTC
command: # 수행 할 명령어
- --character-set-server=utf8mb4 # mysql character
- --collation-server=utf8mb4_unicode_ci # collation setting
- --lower_case_table_names=1 # 테이블 이름은 디스크에 소문자로 저장되며, 이름 비교는 대소문자를 구분하지 않습니다.
volumes:
- ./mysql:/var/lib/mysql
ddl
create table test
(
id bigint auto_increment primary key comment 'ID',
name varchar(100) not null comment '이름',
created_at datetime(6) not null comment '생성 일시',
updated_at datetime(6) null comment '수정 일시'
) comment 'test' charset = utf8mb4;
실행방법
- 위에 docker-compose 명령어를 실행해서 docker 를 생성해줍니다.
- spring-boot application 을 실행시켜줍니다.
- classpath:/db/migration 위치에 있는 DDL 파일이 실행되며, 테이블이 생성됩니다.
마무리
로컬에서 mysql 테스트 환경을 구축할 때, spring-boot, docker, flyway 를 활용하는 방식에 대해 간략히 정리했습니다.
docker 사용 시, M1 mac 의 경우
no matching manifest for linux/arm64/v8 in the manifest list entries
에러가 발생했습니다.아래와 같이 플랫폼을 명시해서 처리했습니다.
local-db: platform: linux/x86_64 # 추가된 라인
추가로 flyway 를 통해 테이블에 대한 변경 등을 관리할 수 있습니다.
- 예를 들면, test 라는 테이블에 컬럼이 추가가 되거나 삭제가 된다면 v1, v2 이런식으로 flyway 를 통해 버전관리를 할 수 있습니다.
- 이렇게 버전관리된 것을 git 을 이용해 remote 환경에서 관리할 수 있고, 개발팀이 DB 운영 배포를 할 수 있다면 flyway 를 통해 운영 까지 배포도 가능합니다.
댓글