트러블슈팅

liquibase의 changelog인 schema.xml과 data.xml을 생성해주는 ShellScript 만들기

MJ.Lee 2024. 1. 9. 21:27

liquibase changelog인 schema.xml과 data.xml을 생성하기 위해 아래와 같이 Shell Script를 만들 수 있다.

 

Shell Script 만들기

liquibase로 schema.xml을 만드는 명령어는 아래와 같다.

JDBC_DRIVER_HOME=${HOME}/.m2/repository/mysql/mysql-connector-java
JDBC_DRIVER_VERSION=8.0.12
CLASSPATH=${JDBC_DRIVER_HOME}/${JDBC_DRIVER_VERSION}/mysql-connector-java-${JDBC_DRIVER_VERSION}.jar

DRIVER=com.mysql.cj.jdbc.Driver

URL="jdbc:mysql://database 호스트명:20306/db 저장소명?useSSL=false"
USERNAME=db 유저명
PASSWORD=db password

AUTHOR=팀 명 혹은 프로젝트명

DATE_TIME=$(date +%Y%m%d%H%M%S)
CHANGELOG_SCHEMA=src/main/resources/config/liquibase/changelog/${DATE_TIME}_schema.xml
CHANGELOG_DATA=src/main/resources/config/liquibase/changelog/${DATE_TIME}_data.xml

liquibase --classpath=${CLASSPATH} \
          --driver=${DRIVER} \
          --url=${URL} \
          --username=${USERNAME} \
          --password=${PASSWORD} \
          --changeSetAuthor=${AUTHOR} \
          --changeLogFile=${CHANGELOG_SCHEMA} \
          generateChangeLog

 

data.xml을 만드는 명령어는 아래와 같다.

JDBC_DRIVER_HOME=${HOME}/.m2/repository/mysql/mysql-connector-java
JDBC_DRIVER_VERSION=8.0.12
CLASSPATH=${JDBC_DRIVER_HOME}/${JDBC_DRIVER_VERSION}/mysql-connector-java-${JDBC_DRIVER_VERSION}.jar

DRIVER=com.mysql.cj.jdbc.Driver

URL="jdbc:mysql://database 호스트명:20306/db 저장소명?useSSL=false"
USERNAME=db 유저명
PASSWORD=db password

AUTHOR=팀 명 혹은 프로젝트명

DATE_TIME=$(date +%Y%m%d%H%M%S)
CHANGELOG_SCHEMA=src/main/resources/config/liquibase/changelog/${DATE_TIME}_schema.xml
CHANGELOG_DATA=src/main/resources/config/liquibase/changelog/${DATE_TIME}_data.xml

EXCLUDE_OBJECTS="빼고싶은 테이블1, 빼고싶은 테이블2. 필요하면 넣고 아니면 안넣어도 된다."

liquibase --classpath=${CLASSPATH} \
          --driver=${DRIVER} \
          --url=${URL} \
          --username=${USERNAME} \
          --password=${PASSWORD} \
          --changeSetAuthor=${AUTHOR} \
          --changeLogFile=${CHANGELOG_DATA} \
          --diffTypes=data \
          --excludeObjects=${EXCLUDE_OBJECTS} \
          generateChangeLog \

 

아래와 같이 "&&"을 이용해 schema.xml과 data.xml을 합쳐서 명령할 수 있다.

JDBC_DRIVER_HOME=${HOME}/.m2/repository/mysql/mysql-connector-java
JDBC_DRIVER_VERSION=8.0.12
CLASSPATH=${JDBC_DRIVER_HOME}/${JDBC_DRIVER_VERSION}/mysql-connector-java-${JDBC_DRIVER_VERSION}.jar

DRIVER=com.mysql.cj.jdbc.Driver

URL="jdbc:mysql://database 호스트명:20306/db 저장소명?useSSL=false"
USERNAME=db 유저명
PASSWORD=db password

AUTHOR=팀 명 혹은 프로젝트명

DATE_TIME=$(date +%Y%m%d%H%M%S)
CHANGELOG_SCHEMA=src/main/resources/config/liquibase/changelog/${DATE_TIME}_schema.xml
CHANGELOG_DATA=src/main/resources/config/liquibase/changelog/${DATE_TIME}_data.xml

EXCLUDE_OBJECTS="빼고싶은 테이블1, 빼고싶은 테이블2. 필요하면 넣고 아니면 안넣어도 된다."

liquibase --classpath=${CLASSPATH} \
          --driver=${DRIVER} \
          --url=${URL} \
          --username=${USERNAME} \
          --password=${PASSWORD} \
          --changeSetAuthor=${AUTHOR} \
          --changeLogFile=${CHANGELOG_SCHEMA} \
          generateChangeLog &&
liquibase --classpath=${CLASSPATH} \
          --driver=${DRIVER} \
          --url=${URL} \
          --username=${USERNAME} \
          --password=${PASSWORD} \
          --changeSetAuthor=${AUTHOR} \
          --changeLogFile=${CHANGELOG_DATA} \
          --diffTypes=data \
          --excludeObjects=${EXCLUDE_OBJECTS} \
          generateChangeLog \

 

 

ShellScript를 생성해서 프로젝트 안에 넣어두면 된다.

쉘 스크립트 실행 방법

프로젝트 터미널에서 db2changelog.sh가 있는 곳으로 가서, ./db2changelog.sh를 실행시켜준다.

Liquibaese가 콘솔에 뜨면 성공이다. 참고로 작성한 db2changelog.sh에는 schema.xml과 data.xml 둘다 생성되도록 했다.

 

 

생성에 오랜 시간이 걸릴 수 있으므로 기다리면 아래와 같이 schema.xml과 data.xml이 생성 완료되었다는 것을 알 수 있다.

 

Project 내 changelog 폴더에 생성된 schema.xml과 data.xml이 추가된 것을 볼 수 있다.