전체 글
-
Spring AOP를 Kotlin으로 개선해보기! (feat. 카카오페이 테크블로그)📖 개발 공부/kotlin 2024. 3. 17. 12:56
이번 글에서는 Spring AOP의 아쉬운 점과 함께 Kotlin의 Trailing Lambda 문법을 통해 개선하는 방법을 알아보려고 한다!카카오페이 테크블로그의 "Kotlin으로 Spring AOP 극복하기!" 글을 보고 해결한 내용이다. AOP 간단 설명AOP는 관점 지향 프로그래밍(Aspected Oriented Programming)으로 로깅, 트랜잭션과 같은 공통으로 실행되어야하는 부분을 비즈니스 로직에서 떼어내어 모듈화하여 재사용하는 것을 의미한다.AOP를 사용하여 비즈니스 로직을 작성하는 데에 집중할 수 있게 해준다. 이때 트랜잭션 로직과 같이 삽입되는 로직을 Advice, 그리고 로직이 삽입될 함수를 JoinPoint라고 정의한다. Spring AOP 아쉬운 점 살펴보기나는 Spri..
-
JPA N+1 문제 해결 일지 - 답은 JPQL에 있었다.📖 개발 공부 2024. 3. 3. 11:22
프로젝트 개발하면서 JPA에서 N+1 문제를 발견하여 원인과 해결한 방법들을 공유하고자 한다! 다음과 같은 Candidate 엔티티가 존재한다. @Entity @Table(name = "candidate") class CandidateEntity( @Id @GeneratedValue(strategy = GenerationType.IDENTITY) var id: Long? = null, @Enumerated(EnumType.STRING) var sourceType: SourceType, // 출처 소스 타입 var sourceId: String, // 출처 소스의 id var createdAt: LocalDateTime, // 생성일 @OneToOne(cascade = [CascadeType.ALL]) @..
-
Line | 오픈채팅 시스템 설계📖 개발 공부 2024. 2. 18. 02:24
“LINE 오픈챗 서버가 100배 급증하는 트래픽을 다루는 방법”을 보면서 오픈 채팅 시스템 설계를 정리한 내용이다! 오픈 채팅 시스템의 아키텍처는 다음과 같다. 채팅의 다양한 이벤트(메시지 전송, 메시지 반응, 메시지 읽음 등)들을 채팅 서버에 보낸다.해당 이벤트들을 모두 스토리지에 저장한다.그리고 Kafka에 해당 이벤트들을 발행한다.푸시 서버는 해당 이벤트들을 소비하여, 사용자들에게 해당 이벤트가 발생했다고 알린다.사용자는 해당 이벤트를 조회한다. 이때 스토리지에 접근하여, 새 메시지를 화면에 추가하는 액션을 실행한다. 이 아키텍처에서 트래픽이 급증할 수 있는 패턴들을 살펴보자.Hot Pattern 1: 수십개의 메시지를 주고받는 핫 챗만약 한 채팅에 5천명 이상의 사용자가 있다고 해보자.이때 [..
-
Toss | null return은 코드 복잡성을 만든다.📖 개발 공부 2024. 2. 17. 01:02
토스 테크블로그를 읽고 쓰는 글입니다.https://toss.tech/article/engineering-note-2 개발자 고객을 위한 코드 복잡성 관리! ☑️ 체크리스트ㄴ 코드 한줄을 바꾸기 위해 바꿔야할 코드가 많다?ㄴ 메서드 인자에 값을 추가하기 위해 지나가는 모든 메서드 인자 값을 추가한 적이 있다?ㄴ ... 하나라도 체크를 했다면, 코드 복잡성을 경험해본 것이다! 직접 겪어보고 크게 공감되었던 두개의 체크리스트만 가져와보았다. 코드를 바꿔야할 때 위의 경험들에 대해 고민을 해왔던 적이 종종 있었다. 과연 이게 올바른 방향일까? 라는 의문과 함께. “코드를 읽는 사람 입장에서 null은 복잡성을 만든다.” 예시를 보자.val user: User? = userRepository.findByNam..
-
Kotest 예제와 함께 테스트 코드 살펴보기📖 개발 공부/kotlin 2024. 2. 4. 16:09
테스트 코드를 작성하는 이유 나는 크게 세가지 이유로 테스트 코드를 작성한다. 내가 개발한 기능들이 제대로 잘 동작하는지 확인하기 위함. 코드에 변경이 생겼을 때, 기존 기능에 영향을 주는지 여부를 확인하기 위함. 이를 통해 예상하지 못한 버그 발생을 사전에 찾아내고, 배포 시의 불안함을 줄일 수 있다. 테스트 코드를 통해 실제 코드의 작동 방식을 더 빠르게 이해시키기 위함. 정적인 문서는 쉽게 방치될 수 있다. (유경험자..) 따라서 테스트 코드는 변경된 기능들을 최신화할 수 밖에 없는! 유일(?)한 방법이라고 생각한다. 또한 문서라고 하믄, 가독성이 충분히 있어야 한다. 가독성 있는 테스트 코드는 정말 도움되는 문서라고 할 수 있다. 테스트 코드 용어 살펴보기 sut System Under Test ..
-
빌드 관리 도구, 예제와 함께 Gradle 알아보기📖 개발 공부 2024. 1. 21. 11:00
프로젝트에서 gradle이 어떻게 돌아가는지 이해도를 높이기 위해 글을 작성해보겠다. 일단, 공식 문서 내용이 너무 많아서 🥲 프로젝트에 적용했던 설정들을 토대로 정리해보려고 한다. Gradle 이란? gradle은 오픈소스 빌드 자동화 툴이다. 어떤 플랫폼에서든 소프트웨어를 구축, 테스트, 게시 및 배포하는 경우 gradle은 코드 컴파일 및 패키징부터 웹 사이트 게시까지 전체 개발 수명주기를 지원할 수 있는 유연한 모델을 제공한다. 컴파일(Compile): Gradle은 Java 파일을 바이트코드로 컴파일하는 과정을 자동화한다. 테스트(Test): 어플리케이션이 예상대로 정상 작동하는지 확인하는 자동화된 테스트를 수행한다. 패키징(Packaging): JAR 또는 WAR 파일과 같은 배포 가능한 형태..
-
2023 회고 | 시간 왤케 빨라카테고리 없음 2024. 1. 6. 16:29
지나간 2023을 회고하는 글!2023년 감상평을 한줄로 써보자면 “시간 왤케 빨라” 이다 ㅎㅎ.나 1년동안 뭐했지?라고 생각했을 때 기억나는 활동이 크게 많지 않았다. 그만큼 내가 올해에 회사 일에만 몰두했나?란 생각을 했다. 그래서 일기 / 올렸던 PR들 / 기록했던 공부들을 보며 정리하는 시간을 가졌다. 생각만큼 활동을 안한 건 아니었다. (다행 ㅎㅎ) 1-2월#사내스터디 사내에서 “가상 면접 사례로 배우는 대규모 시스템 설계 기초” 스터디를 진행했다. 스터디 진행방식은 한 챕터씩 읽어 오고, 읽으면서 들었던 질문들에 대해 얘기하는 시간을 가졌다. 그리고 회사 내에서는 어떻게 시스템을 구축하고 있는지 함께 공유하기도 하였다. 대규모 시스템 설계를 해본 경험이 많이 없는 나에게는, 경험 있으신 분들..
-
늦게나마 올리는 GDSC 홈커밍데이 연사발표 회고카테고리 없음 2024. 1. 6. 16:10
2023.11.15에 GDSC 홈커밍데이 연사발표를 하였다! 나는 발표 경험이 거의 없었다. 사람들 앞에서 발표하는 것에 대해 굳이 나서지 않아서 거의 해본 적이 없다. 하지만 나는 학부 시절 이러한 경험을 못해본 것이 조금 아쉬웠다. 경험이란 것은 소중한데.. 무섭다고 외면해서 결국 나의 단점이 되어버린 듯한? 그래서 발표를 해보고 싶은 마음이 가슴한켠에 남아있었다. 그러던 어느날, GDSC 현재 기수 운영진을 하고 있는 친구가 연락이 왔다! 너 혹시 올 수 있으면 강연할래? 사실 직장을 다니고 있는 평일 저녁에 홈커밍데이를 진행하여서 80% 못가겠다 생각하고 있었다. 하지만 친구의 제안을 듣고 !!!헉!!! 내가 해보고 싶었던 연사의 기회가! 하고 눈이 커졌다. 그래서 조오금 고민하다가 바로 하겠다고..