분류 전체보기277 Petory) JPQL을 이용한 DB 조회 성능 개선 (feat. N + 1 문제 해결 포함) 일정 목록을 조회하는 API를 구현함에 있어서 정말 복잡하게 테이블을 조회해야하는 일이 생겼다. 전체 ERD 중 일정 생성에 연관된 테이블은 다음과 같다. 일정 목록 조회를 위해서는 다음과 같은 조회 쿼리가 필요하다. 그에 대한 이유도 각각 아래 서술한 것과 같다. 1. 로그인한 사용자가 만든 일정 조회 -> 반려동물이 없는 일정도 조회하기 위함 2. 로그인한 사용자가 돌보미로 등록된 반려동물의 일정 조회 3. 로그인한 사용자가 소유한 반려동물의 일정 조회 -> 자신의 반려동물이지만 돌보미로 등록된 다른 사용자가 만든 일정 정보 획득 이렇게 조회를 한 후 중복을 제거하면 관련된 모든 일정에 대해 조회가 가능하다. 시도해봤던 로직 1. 로그인한 사용자가 만든 일정 + 로그인한 사용자가 돌보미로 .. 2025. 1. 23. N + 1 문제와 해결 방법 Fetch Join, Batch Size, Entity Graph DB에서 정말 빈번하게 발생하는 N + 1문제를 인식하고 (드디어) 이해를 해서 포스팅을 해보려고 한다. N + 1 문제란 ?ORM (Object Relational Mapping)을 사용할 때 발생할 수 있는 비효율적인 데이터베이스 쿼리 문제를 말한다.연관관계에 있는 엔티티에서 하나의 엔티티를 조회할 때 관련된 엔티티를 조회하기 위해 추가적인 쿼리가 반복적으로 실행되는 상황을 말한다. 연관관계 (1 : N, N : 1) 의 엔티티를 조회할 때 조회된 데이터 갯수 (n) 만큼 연관관계의 조회 쿼리가 추가로 발생하여 데이터를 읽어오게 된다. 즉, 1번의 쿼리를 날렸을 때 의도하지 않은 N번의 쿼리가 추가적으로 실행되는 것이다. 처음에 오해한 생각 : 내가 로그인이 필요한 모든 메소드에서 MemberAd.. 2025. 1. 10. ElasticSearch로 사용자 검색 구현 + EC2 서버에 Elasticsearch 배포 Elastic Search란 ?역색인(역인덱스) 구조로 검색 시 속도를 빠르게 처리할 수 있음 1. 인덱스 생성2. 데이터 저장3. 검색 API 요청 구현 과정1. 의존성 추가implementation 'org.springframework.boot:spring-boot-starter-data-elasticsearch' 2. yml 설정3. config 작성 기존에 상속받아서 첫 번째 사진처럼 사용했던 AbstracElasticsearchConfiguration이 Deprecated 되었다.https://docs.spring.io/spring-data/elasticsearch/docs/5.1.9/api/org/springframework/data/elasticsearch/client/erhlc/Abstra.. 2024. 11. 22. AWS를 위한 기초 용어 와닿지 않으면 암기라도 하자.... VPC (Virtural Private Cloud) 가상 사설 네트워크.AWS를 사용하는 회사라면 100% 사용하고 있으며 이를 통해 클라우드에서 가상의 네트워크 환경을 정의하고 제어할 수 있다. 필요에 따라 네트워크를 만들어서 Public subnet, Private subnet라는 하위 네트워크를 구분하여 사용할 수 있다. * network : 2개 이상의 컴퓨터나 장치가 서로 데이터를 주고 받을 수 있도록 연결된 시스템 Public subnet vs Private Subnet - Public subnet : 인터넷 게이트웨이와 직접 연결된 서브넷. 이 서브넷에 있는 EC2 인스턴스는 인터넷에 직접 접근할 수 있다. 일반적으로 웹 서버, 로드 밸런.. 2024. 11. 8. SpringBoot에 Flyway적용해서 DB 형상 관리 하기 + JPA 옵션, flyway 옵션 정리 Flyway란 ?DB 형상관리 툴이다. == DB 변경 관리 툴 * 형상관리 : sw의 변경사항을 체계적으로 추적하고 통제하는 것. Git은 소스코드 형상관리 툴이고 Flyway는 DB 형상관리 툴이다. 어떤 상황에서 ?개발 도중 스키마가 변경 될 때1. spring:jpa:hibernate:ddl-auto: create or update를 주로 사용한다. 문제점 -> create는 이전 데이터를 다 날려버리므로 배포 환경에서 사용할 수 없음이 명확하고 update는 테이블을 수정하지 않고 부족한 부분을 수정한다. 2. 각 배포 환경을 돌아다니면서 직접 schema 변경 문제점 -> 확인하는 것도 일이고 실수가 나기 쉽다. 이런 DB 가 변경될 상황들에서 변경 관리 이력을 추적하고 관리하기 위해 Flyw.. 2024. 8. 26. AWS S3 이용하여 이미지 업로드 구현하기 S3 이미지 업로드 개념 1. Spring Boot Project에서 클라이언트에게 MultipartFile로 이미지 파일을 받는다. 2. 이 파일을 S3에 업로드하고 S3에 어디서나 접근 가능한 public url을 반환한다. 3. public url을 통해 이미지에 어디서나 접근/다운이 가능하다. 4. url을 DB에 저장하여 필요할 때 url로 이미지 데이터를 사용할 수 있다. 구현과정1. S3 버킷 생성* 퍼블릭 액세스 차단을 해제 해야함 나머지는 기본 설정으로 두고 버킷 생성 버킷 정책 설정이 작업을 안 해주면 추후 URL이 나왔을 때 들어가보려고 하면 아래와 같은 오류가 난다. 생성한 버킷 - 권한 - 버킷 정책 편집 아래와 같이 작성해준다.{ "Version": "2012-10-17",.. 2024. 8. 24. Spring Boot) 백 & 프론트 카카오 로그인 API 구현하기 카카오 공식문서에 있는 로그인 과정이다.처음부터 보고 로직 이해를 하면 구현이 한결 쉬워진다. 공식문서의 위력을 다시 한 번 느꼈다. 간단하게 정리해보면 다음과 같다.1. 카카오 로그인 완료 후 Redirect URI로 인가 코드 발급됨.2. 인가 코드를 통해 카카오 서버로 토큰 요청.3. 토큰을 통해 카카오 로그인 한 사용자 정보를 받아올 수 있음.4. 해당 사용자 정보를 이용해 회원가입 or 로그인 처리. 로직을 토대로 우리 프로젝트에서 적용한 플로우는 다음과 같다.1. 프론트-> 카카오 kakao.Auth.Authorize()이용해 카카오 로그인 화면 요청 2. 카카오-> 백 로그인 완료되면 code와 함께 자동으로 백 리다이렉트 url로 넘어감 (~~/oauth/kakao/callback?cod.. 2024. 8. 24. Spring Security + JWT 인증 인가 구현하기(로그인 API, 인증이 필요한 API) 1. 로그인 구현비밀번호가 일치하면 토큰을 생성해서 내려준다. 구현해야할 것- 로그인 컨트롤러- 로그인 서비스- JwtUtils 클래스에 token 생성 로직 컨트롤러@PostMapping("/login") public ResponseEntity signIn( @RequestBody @Valid SignIn.Request request) { return ResponseEntity.ok(memberService.signIn(request)); } 서비스public SignIn.Response signIn(SignIn.Request request) { Member member = getMemberByEmail(request.getEmail()); .. 2024. 8. 16. Spring Boot 3.x 버전에서 Spring Security 적용기 * 스프링 시큐리티 버전확인하기 Gradle - Dependencies - 'security' 검색하여 확인할 수 있다. 6.3.1 버전으로 확인된다. 스프링 시큐리티 5.7버전 이상부터는 더이상 WebSecurityConfigurerAdapter가 사용되지 않는다고 한다.이전 프로젝트는 5.7.11 버전이었고 WebSecurityConfigurerAdapter를 상속받아 SecurityConfig를 구성했었었는데 더이상 그대로 제작할 수 없게 되었다.(5.7.11버전에서 저렇게 줄이 그어져있긴 하지만 사용할 수는 있었다.)GiftFunding) Spring Security를 이용한 로그인 구현 (tistory.com) GiftFunding) Spring Security를 이용한 로그인 구현Spring .. 2024. 8. 13. 이전 1 2 3 4 ··· 31 다음 728x90