분류 전체보기
-
[Kafka] acks=all 일 때 min.insync.replicas=2 설정을 권장하는 이유DevOps/Kafka 2022. 10. 14. 01:05
acks=all 일 때 min.insync.replicas=2로 설정해야 하는 이유는 무엇일까? acks=all : 리더는 ISR의 팔로워로부터 데이터에 대한 ack를 기다리고, 하나의 팔로워가 있는 한 데이터는 손실되지 않으며 데이터 무손실에 대해 가장 강력하게 보장 ISR: In Sync Replica의 약어로 현재 리플리케이션이 되고 있는 리플리케이션 그룹(replication group)을 의미 min.insync.replicas: 최소 리플리케이션 팩터를 지정하는 옵션 Replication Factor 는 토픽의 파티션의 복제본을 몇 개를 생성할 지에 대한 설정 본 내용에 들어가기 전에 카프카 용어에 대해 간략하게 정리하면 위와 같습니다. 여기서 이번 글에서는 min.insync.replicas..
-
[Spring] 멀티 모듈에서 모듈별 yml 파일 관리하는 법Server/Spring 2022. 10. 4. 00:18
Multi module에서 yml 파일 관리하는 법 이번 글에서는 Multi-Module을 사용할 때 모듈 별 yml 파일 관리하는 법에 대해서 정리해보려 합니다. api 모듈 application.yml domain 모듈 application.yml 만약에 위와 같이 2개의 모듈이 있을 때, 각 모듈마다 application.yml을 가지고 있을 것입니다. 그런데 지금까지 Multi-Module로 프로젝트를 할 때는 모듈별로 yml 파일을 분리하지 않고 api 모듈 하나에 모든 설정들을 다 넣었습니다. yml이 잘 분리가 되었다면 api 모듈의 yml에서는 api와 관련된 설정(ex: Swagger)들이 있을 것이고 domain 모듈의 yml에는 대표적으로 DB 접근 정보 및 JPA 설정들이 존재할 것..
-
[Spring] Security WebSecurityConfigurerAdapter Deprecated 해결하기Server/Spring 2022. 6. 29. 00:06
WebSecurityConfigurerAdapter Deprecated 해결하기 최근에 Spring Security를 설정해보려고 WebSecurityConfigurerAdapter를 사용하려 보니 Deprecated가 되어 있었는데요. @RequiredArgsConstructor @EnableWebSecurity public class WebSecurityConfig extends WebSecurityConfigurerAdapter { private final ObjectMapper objectMapper; private final JwtAuthenticationFilter jwtAuthenticationFilter; @Override public void configure(WebSecurity web..
-
[Spring] Multi-Module에서 Domain 모듈 테스트 실행하는 법Server/Spring 2022. 6. 23. 01:21
Multi Module Domain 모듈에서 테스트 코드 실행하는 법 위와 같이 main 클래스를 가지는 api 모듈과 domain 모듈로 2개가 분리되어 있습니다. api 모듈에서 domain 모듈을 사용할 때 위와 같이 참조해서 사용하는데요. 즉, api 모듈에서 Domain 모듈을 import해서 사용한다고 생각하면 됩니다. Domain 모듈에서 테스트 코드를 실행해보자. 그러면 이제 Domain 모듈에서 통합 테스트 코드를 간단하게 작성하여 실행해보면 위와 같은 아리송한 에러 메세지를 볼 수 있습니다. 에러가 발생하는 이유를 생각해보면 Domain 모듈에서 통합 테스트 코드를 작성한다면 @SpringBootTest 어노테이션을 사용해서 진행할 것인데요. @SpringBootTest 어노테이션은 S..
-
[JPA] @OneToOne 관계에서 N + 1 발생하는 이유가 무엇일까?Server/Spring 2022. 6. 4. 00:38
@OneToOne 관계에서 N + 1이 발생하는 이유가 무엇일까? 이번 글에서는 @OneToOne 관계에서 N + 1 문제가 발생하는 원인이 무엇인지 해결하기 위해서는 어떤 대안들이 있는지 정리해보겠습니다. OneToOne 관계의 예시를 들기 위해서 File - Thumbnail_Image로 예시를 들어 정리해보겠습니다. 하나의 File에는 Thumbnail_Image 하나만 존재할 수 있는 상황입니다. 그리고 File이 생성된 후에 Thumbnail Image가 생성될 수 있습니다.(File이 없다면 Thumbnail_Image는 존재할 수 없습니다.) 위와 같은 조건이 있기 때문에 File - Thumbnail_Image 사이는 @OneToOne 관계입니다. @OneToOne 관계는 어떤 테이블에서 ..
-
2년 동안의 1일 1커밋을 그만 두며..Retrospect 2022. 3. 9. 11:07
2년 동안의 1일 1커밋을 그만두며.. 2021년 7월에 1일 1커밋을 1년 7개월 동안 하면서 느낀점 이라는 제목으로 가볍게 중간 회고를 작성한 적이 있었는데요. 이번 글에서는 2년 동안 진행해왔던 1일 1커밋을 그만두면서 라는 제목으로 1일 1커밋 마지막 회고를 진행해보려 합니다. 1일 1커밋을 시작한 이유는? 2019년 까지의 저는 학교 수업은 열심히 듣는 학생이었기에, 학교 수업 외에 개인 적인 공부를 하지는 않아서 웹/앱 개발을 해본 경험이 전혀 없었고 Git, Github도 사용해본 적이 없었습니다. 그러다 보니 2019년 2학기가 되었을 때 더 이상 학교 공부만 해서는 안되겠다는 생각에 외부 활동들을 조금씩 알아보게 되었는데요. 이 때 간단한 외부 활동을 하면서 만났던 한 분이 있는데, 이 ..
-
개발자를 꿈꾸는 대학생의 2021년 회고Retrospect 2022. 1. 4. 00:18
2021년 회고 회고를 쓰는 이유는 내가 2021년에 어떻게 살았는지를 되돌아보고, 2022년에는 어떤 목표를 가지고 시작할지에 대한 정리를 하기 위해서다. 그리고 2020년 에 비해 올해는 얼마나 달라졌는지도 정리하기 위해서이다. 겨울 방학 2021년이 되었을 때 나는 재수를 했기에 4학년이 되었고, 나도 이제 취준 시작이라는 마음에 설렘과 걱정을 가지고 겨울 방학을 보냈던 것 같다. 가장 먼저 2020년 까지는 SOPT IT 동아리를 하면서 JavaScript, NodeJS, Express로 백엔드 개발을 했다. 하지만 2021년에는 Spring을 공부해서 프로젝트를 해보고 싶었다. 그래서 겨울 방학동안 JAVA의 동작 원리를 깊게 공부해보려 노력했다. 방학 동안 자바, 알고리즘 공부만 하다 보니 자..
-
[Spring] Spring Security, React를 사용하면서 CORS 허용하는 방법Server/Spring 2021. 12. 23. 20:26
Spring에서 CORS 해결하는 법 이번 글에서는 개인적인 프로젝트를 하면서 겪었던 SOP 문제를 CORS를 허용해주면서 해결했던 과정에 대해서 공유해보려 합니다. (이 글에서는 CORS가 무엇인지에 대해서는 자세히 다루지 않겠습니다.) 참고로 프로젝트에서 백엔드는 Spring Boot, 프론트엔드는 React를 사용하였습니다. CORS란 무엇일까? CORS가 무엇인지 간단하게 알아보겠습니다. CORS(Cross-Origin Resource Sharing)는 교차 출처 리소스 공유라고 합니다. 여기서 교차 출처라고 하는 것은 다른 출처를 의미하는 것입니다. 즉, 브라우저에서 막고 있기 때문에 CORS를 허용해주어야 접근이 가능합니다. 출처(Origin)은 무엇일까? 위의 보이는 것처럼 도메인에서 Pro..