본문 바로가기

프로젝트44

[Key Word 개발기] maria db 대소문자 문제 우리 프로젝트에 mariadb를 사용했는데 로컬에서 어플리케이션을 실행해보니 갑자기 테이블이 없다고.. 오류가 나왔다... 뿐만 아니라 배포한 상태에서도 아래의 오류가 나왔다. Error querying database. Cause: com.mysql.jdbc.exceptions.jdbc4.MySQLSyntaxErrorException: Table [테이블 명] 문제상황 그래서 찾아보니 리눅스 환경의 경우 db에서 대솝문자를 구분하게 설정하여 설치되어 있을 수도 있다고 한다. 처음 들어보는 이야기다... 그냥 항상 잘되서 아무 문제 없을 줄 알았는데... 그래서 다음 명령어를 통해 대소문자를 구분하는 지 확인 하였다 show variables like 'lower_case_table_name'; Valu.. 2024. 1. 25.
[Key Word 개발기] 스프링 이벤트 적용하기 갑자기 배포를 해야해서 이 기능은 적용한지 좀 오래됬는데 지금에서야 쓰는 나... 스프링 이벤트..?? 협업프로젝트를 진행하면서 S3를 이용해서 프로필 이미지를 저장하고, 삭제, 수정하는 기능을 도입했다. 이미지 삭제의 경우 수정할때 사용하는데 과연 삭제와 수정이 같은 트랜젝션안에 있어야하는 가에 대해 고민하게되었다. 내 생각의 경우 다른 트랜젝션이라고 생각했다. 그 이유는 s3에서 이미지 삭제 실패했다고 해서 핵심 로직에 큰 영향을 주지 않기 때문이다. 이미지 수정에만 성공하면 s3쪽에 이미지가 저장되고 db의 내용도 잘 변경된다. 그렇다면 이미지 삭제에 에러가 났다고 롤백하는게 좋은 방향일까?? 라고 질문을 던졌을때 좋은 방향은 아닌것같았다. 그래서 도입하게된 스프링 이벤트! 스프링 이벤트를 도입하게.. 2024. 1. 21.
[Key Word 개발기] 젠킨스 파이프라인 스크립트 형상관리 현재 파이프라인 스크립트를 젠킨스 쪽에서 수정하고 배포하고 있다. 그러다보니 수정이 필요할때마다 젠킨스에 들어가야하고 변경사항에 대해서 매번 따로 기록해야하는 번거로움이 생겼다. 그래서 파이프라인도 형상관리를 할 수 없을까 고민하게되었다. 젠킨스 형상관리 젠킨스쪽에서 구성에서 가면 pipeline script scm이라는 부분이 있다. 여기서 scm이란?? GIT처럼 변경사항을 추적하고 통제하는 것을 말한다. 젠킨스는 pipeline script scm을 통해 파이프라인 스크립트를 형상관리를 지원하고 있었다. 형상관리를 통해 젠킨스 서버와 독립적으로 깃에서 파이프라인 스크립트를 관리할 수 잇었다. 따라서 스크립트에 문제가 발생한다면 이전 스크립트를 사용할 수 있게 할 수 있다. 깃 레포지토리 파이프라인 .. 2024. 1. 21.
[Key Word 개발기] Git submodule + 배포 적용기 앞서 submodule에 대해서 간단하게 설명하였다. 그래서 프로젝트에 적용한 과정과 만났던 에러들을 기록하고자 한다. 서브모듈 레포를 만들었다는 가정하에 진행한다. git submodule 연결 일단 git submodule 적용할 레포에서 터미널을 킨다. git submodule add -b {서브모듈 브랜치} {서브모듈 git url} src/main/resources/config src/main/resources/config의 경우 슈퍼 레포에서 어느 디렉토리에 등록할지 정하는 것이다. 우리 팀의 경우 resources폴더안에 config라는 폴더로 등록하기로 하였다. (config 폴더의 경우 미리 생성하지 않아도 저 명령어를 통해 폴더가 생서되면 서브모듈이 등록된다) 이후 잘 적용되었다면 .g.. 2024. 1. 21.
[Key Word 개발기] ec2 스프링부트 에러로그 slack으로 전송 우리 팀의 경우 ec2에 배포했는데 로그관련해서는 이렇게 설정해놨다. (일부분만 보여드린겁니다!) LOG_DIR=/home/ubuntu/logs LOG_FILE=$LOG_DIR/keyword.log # 로그 디렉토리 생성 (없는 경우) mkdir -p $LOG_DIR echo "🌈 SpringBoot 애플리케이션을 실행합니다" JAR_NAME=$(ls | grep .jar | head -n 1) sudo -E nohup java -jar -Dserver.port=8080 /home/ubuntu/$JAR_NAME >> $LOG_FILE 2>&1 & 스크립트가 실행될때 logs폴더안에 keyword.log안에 쌓이도록 해놨다. 그러다보니 문제점이... 첫번째 에러로그를 일일히 찾아야하는 점... 마치 인텔리.. 2024. 1. 20.
[Key Word 개발기] Git submodule 배포하면서 개발을 하다보면 yml에 추가해야하는 설정들이 있다. 공개해도 되는 값이면 괜찮지만 공개하면 안되는 값들은 datasource: url: jdbc:mariadb://${DB_HOST}:${DB_PORT}/${DB_DATABASE} 이런 형식으로 작성후 쉘스크립트에서 export하여 넣어주고 있다. 이러다보니 매번 쉘스크립트를 수정하는 것이 귀찮았다... 그래서 더 나은 방법이 없을까?? 찾아보니 git submodule이라는 방법이 있었다. 서브 모듈?? Git 레포지토리 내에 다른 Git레포지토리를 포함하는 방법이다. 상위 레포를 슈퍼 프로젝트, 하위 레포를 서브 모듈이라고 부른다. 서브모듈을 이용하면 어느 Git 레포에 하위 디렉토리로 사용가능하다. 보통 서브모듈의 경우 공통으로 사용되는 .. 2024. 1. 19.
728x90