이슈와해결30 엔티티가 연장되는 속성을 가진 경우 효율적인 참조 관계 맺기 개요 댓글에 댓글처럼 어떤 엔티티가 줄을 타고 이어지는 경우가 있다. 사내에서 도메인 서비스를 개발하면서 비슷한 케이스가 있어서 고민해보았었다. 예시 서비스는 사용자에게 특정 기능의 연장 기능을 제공한다. 사용자는 해당 기능이 만료되기 일정 기간 전부터 연장을 신청할 수 있으며, 연장 신청 시 새로운 인스턴스가 생성된다. 이 과정에서 새 인스턴스와 이전 연장의 이력 관리가 중요하다. 따라서, 이 서비스에 대한 엔티티 설계에서 연장 이력의 연속성을 관리하는 방안에 대한 효율성을 탐구해야 한다. 사실 엄청 별거 아니지만 그때 고민한 내용과 생각해보았던 내용들을 간단하게 기록해보았다. 실제 용어와 코드는 컨셉으로 대체하였습니다. 목차 개요 현재 방식과 문제점 참조 관계를 개선하기 다른 방식은 없을까 결론 현재.. 2023. 12. 14. 리팩토링 회고 - QueryDsl 검색 로직을 좀 더 클린하게 만들어보기 0. 목차 목차 개요 첫 번째 구현 및 문제점 두 번째 구현 및 문제점 세 번째 구현 및 문제점 네 번째 구현 및 문제점 결론 1. 개요 사내 한 도메인 서비스에 새로운 API 를 추가 개발해야 하는 업무가 있었다. 검색 api를 제공해야 하는 부분에서 queryDsl을 사용면서 좀 더 클린한 방식의 코드 작성을 고민해보았다. *실제 코드가 아닌 컨셉 코드로 대체하였습니다. 2. 첫 번째 구현 및 문제점 구현 @RequiredArgsConstructor @Component public class DomainRepositoryImpl implements DomainCustomRepository { private final JPAQueryFactory queryFactory; @Override public .. 2023. 12. 13. 마이크로서비스 아키텍처에서 하나의 도메인 서비스에 다른 도메인이 필요하다면 ? 이 글의 탄생 배경 회사에서 작은 회의를 하다가 패키지 구조에 대한 이야기를 한 적이 있다. 패키지 구조 설정에 있어서 "도메인 위주로 할 것이냐 레이어 위주로 할 것이냐"에 대한 논의였다. 그 중, 한 프로젝트 내에서 다른 도메인으로 구분되는 경우, 각 도메인들은 어떻게 통신을 해야하느냐 부분에서 열띤 토론을 한 경험이 있다. 회사의 아키텍처는 마이크로서비스 아키텍처 기반의 사가 패턴이 기본 기조이다. 따라서 서비스는 크게 도메인 서비스와 오케스트레이션 서비스로 나뉘어 움직인다. 이 말인 즉슨... 핵심이 되는 도메인 별로 서비스가 개별 프로젝트로 나뉘고 따라서 도메인 서비스는 일반적으로 패키지 구조가 하나의 응집력 있는 계층 구조를 형성한다. 그렇기 때문에 도메인 서비스에 다른 도메인이 있다? 조금 .. 2023. 12. 13. 자동화 경험 공유 - 코드 생성 도구 JavaPoet을 이용한 클래스 복사, 커스터마이징, 컴파일, 로딩 0. 개요 이 글에서는 자동 코드 생성을 위해 사용해 본 JavaPoet 라이브러리 활용 경험을 공유한다. 이 라이브러리를 사용하여 공통 모델 클래스를 특정 도메인에서 복제하고 자동화 한 과정을 설명한다. 자바 포엣 라이브러리의 기본적인 소개와 간단한 사용 방법에 대해서도 다룬다. 예시 코드는 실제 코드가 아닌 컨셉 코드로 대체하였습니다. 1. 목차 개요 목차 배경 복사 자동화하기 JavaPoet 소개 사용방법 및 예제 코드 구현 결과 컴파일 자동화하기 컴파일과 로딩 과정 효과 및 고려사항 결론 2. 배경 사내에서 개발 프로세스 개선을 위한 자동화 툴을 개발하면서 두가지 추가 요구사항이 발생했다. 첫째, 기존에 A 도메인에서 사용되던 프로세스 검증 자동화 Tool이 B 도메인에서도 활용될 수 있도록 확장.. 2023. 12. 13. 리팩토링 회고 - 검증이라는 관심사의 분리와 복잡성 해결을 위한 노력 0. 개요 한 프로젝트의 취약점을 분석하고 Hotfix를 해야하는 상황이 있었습니다. 그 프로젝트의 코드의 복잡도가 너무 심하다고 느껴 잘못 건드렸다가 더 큰 오류를 낼 것 같을 정도로 고칠 엄두가 나지 않았는데요. 여러 부분에서 리팩토링이 필요했습니다. 본 글에서는 여러 리팩토링 방식 중 검증 방식을 분리하여 단순화하는 내용을 다룹니다. 개선점을 도출하고 이를 해결하는 방안으로서 시도한 과정 및 결과를 소개합니다. 예시 코드는 실제 코드가 아닌 컨셉 코드로 대체하였고 기타 네이밍도 추상화하여 작성하였습니다. 1. 목차 개요 목차 배경 기존 코드 개선점 도출 해결 아이디어 1차 변경 → 애노테이션 방식 2차 변경 → Optional을 이용한 방식 결론 2. 배경 데이터 처리 서비스의 DataHandler.. 2023. 12. 12. 이전 1 2 3 4 5 6 다음