본문 바로가기

Project Trouble Shooting/[EATceed] 몸무게 증량 어플26

Spring Event와 @Aysnc를 사용해 회원가입 개선 이번 포스팅에서는 기존에 회원가입 코드를 Spring Event와 @Async를 사용해서 개선하는 과정을 포스팅하려합니다.  필요성 - Event 저희 서비스의 회원가입 기능안에는 해당 회원이 회원가입을 할 수 있는 유저인가 확인, 특정 이메일로 인증 메일 보내기 그리고 회원 정보 생성으로 이루어져있습니다. 위와 같이 코드를 작성하게 되면, "메일 보내기"와 "회원가입"의 의존성이 강해집니다.의존성이 강해진다는 것은 재사용성이 낮아지고 단위 테스트가 어려워집니다. 특히, 이메일 보내기는 여러 도메인에서 사용될 가능성이 높은 경우이기 때문에 Event를 사용해서 회원가입 서비스에서 이메일 서비스에대한 의존성을 제거하여 재사용성을 높인다는 것이 큰 이점이라 판단했습니다. 필요성 - 비동기 처리비동기 처리 전.. 2024. 6. 9.
Request Time Out이 발생하는 이유 - ALB Connection idle timeout 프로젝트를 진행하며 배포 직후 회원 가입 요청에서 request time out이 몇 번이고 발생하였습니다.(몇 번 요청한 이후에는 발생하지 않았다.) 이에 대한 원인은 무엇일까?배포 직후라는 점에서 JVM의 동작 방식과 관련이 있을 수 있습니다. 또한, 제가 작성한 코드 안에서 병목 지점이 있을 수 있습니다.그것도 아니라면, 인프라상에 문제가 있을 수도 있습니다. 이번 포스팅에서는 Request Time Out 문제를 해결하기 위해 인프라에서 시도한 것들에 대해서 이야기하겠습니다.  현재 인프라에서 Request Time Out 응답이 오는 케이스를 생각해보면, 아래와 같을 것입니다. 첫 번째, 애플리케이션에서 해당 API 처리가 지연된 경우 해당 서버의 TimeOut 시간을 초과해 애플리케이션에서 A.. 2024. 6. 3.
전략 패턴을 이용해서 요구사항 대응하기 프로젝트를 진행하다가 요구사항이 변경되었다. 기존 요구사항은 "식사 등록시 한 식사에 대해 인 분(multiple)이란 단위만을 사용하는 것이었다." 요구사항은 "식사 등록시 각 음식에 대해 인 분(multiple) 또는 g(무게) 단위를 사용하는 것"으로 바뀌었다.식사를 등록할 때 단위는 얼마든지 바뀌거나 수정될 수 있다. 문제는 바뀐 요구사항에의해 음식의 영양소를 분석하는 기존 로직을 수정해야한다는 것이었다.이는 OSP(Open Closed Principle)에 위배된다. 따라서, 전략 패턴을 사용해 새로운 "단위"가 도입되더라도 변경이 최소화되도록 코드를 개선하였다. 전략 패턴 전략 패턴은 실행 중에 알고리즘 전략을 선택하여 객체 동작을 실시간으로 바뀌도록 할 수 있게 해주는 디자인 패턴이다. 전략.. 2024. 6. 1.
CI/CD 파이프라인 구축 이번 학기 캡스톤 프로젝트에서 CI/CD 파이프라인 구축을 해보아서, 이번에도 비슷하게 하면 되겠지 라는 마음으로 임하였다가 꼬박 몇 시간 동안 파이프라인 작업만 하였습니다..  개발집에서는 GitHub Actions를 사용해 파이프라인을 구축하였습니다.GitHub Actions를 사용한 이유는 아래와 같습니다.GitHub과 하나로 통합된 환경인 만큼 친숙하다.친숙한 문법인 YAML 파일을 사용하여 파이프라인 구축이 가능하다.다음으로, 파이프라인의 흐름을 살펴보겠습니다. 전체적인 흐름docker image를 build 후 push 한 후 EC2 서버내에서 해당 이미지들을 Pull해와 docker-compose로 컨테이너들을 작동시키는 것이다.그리고, docker-compose할 때 필요한 설정 파일들은 .. 2024. 5. 26.
EC2 용량 부족 이슈 해결 모니터링 서비스에 접속하니 "페이지가 작동하지 않고, 리다이렉션 횟수가 너무 많다 ~ " 이런 페이지가 나오며 접속이 되지 않고 있었습니다.뭐가 문제지 이것저것 찾아보던 디스크의 용량을 확인하게 되었습니다.디스크의 용량을 확인해보니..?? dh -h   디스크의 용량이 꽉 차있었습니다.더 자세한 원인을 확인해보기 위해서 아래와 같이 디스크 용량을 많이 차지하는 순서대로 조회를 해보았습니다.   확인 해보니, docker container에서 디스크의 용량을 대부분 차지하고 있는 것으로 확인이 되었습니다.  참고 : docker 미사용 리소스 삭제하여 디스크 용량 줄이기도커를 사용하며, 사용하지 않는 임시 파일이나 이미지 컨테이너 파일이 누적되면 용량이 커지는 문제가 발생한다.이 때 아래 명령어를 사용하며.. 2024. 5. 13.
@ColumnDefault에 대한 오해 필자는 @ColumnDefault를 사용하는 것이 Insert 쿼리와 관련이 있는 것인 줄 알고 있었으나, 공부해보니 그것이 아니었다.@ColumnDefault는 ddl-auto와 관련이 있는 것으로 ddl이 시작될 때 해당 어노테이션이 사용되는 것이었다.(간단하게 생각하면, 엔티티에 맞는 스키마가 만들어질 때 적용)운영환경에서는 ddl-auto가 validate나 none이기때문에 사실상 해당 애노테이션은 운영환경에서 작동을 하지 않는다.따라서, 본래 목표인 Insert 쿼리를 날렸을 때 해당 컬럼이 default값이 설정되게끔 만들려면 추가적인 설정이 필요하다.@Builder.Default우리가 해야할 추가적인 설정 첫 번째는 @Builder.Default이다.@Builder는 객체의 생성을 쉽고 간.. 2024. 5. 7.
728x90