Spring
-
Redis에서의 KEYS와 SCAN 명령어 비교Spring 2024. 4. 16. 07:10
Redis는 효율적인 키-값 저장소로 널리 사용되고 있으며, 데이터를 조회하는 두 가지 주요 명령어인 KEYS와 SCAN에 대해 자세히 알아보고, 어떤 상황에서 각각을 사용하는 것이 적합한지 살펴보겠습니다. KEYS 명령의 이해 KEYS 명령은 지정된 패턴에 일치하는 모든 키를 한 번의 호출로 반환합니다. 예를 들어, KEYS user:*는 'user:'로 시작하는 모든 키를 찾아 리스트로 반환합니다. 이 방식은 간단하고 직관적이지만, 큰 데이터베이스에서는 몇 가지 문제점을 유발할 수 있습니다. 장점 사용이 간단하며 작은 데이터 세트에서 빠르게 결과를 제공합니다. 단점 대규모 데이터 세트에서 사용할 경우, 서버를 블로킹하여 다른 모든 연산이 중단될 수 있습니다. 매우 CPU 및 메모리 집약적이어서 서버의..
-
Amazon SQS 에 대해 알아보자AWS 2024. 4. 12. 11:16
이번에는 SQS의 내용에 대해 자세히 다뤄보도록 하겠습니다. SQS 큐의 종류 1. Standard Queue 스탠다드 큐는 메시지 순서가 중요하지 않고, 높은 처리량을 필요로 하는 애플리케이션에 적합합니다. 예를 들어, 대량의 이벤트 데이터를 처리하거나, 로깅 시스템에서 다수의 메시지를 신속하게 처리해야 할 때 사용됩니다. 성능 고처리량: 스탠다드 큐는 초당 수십만 개의 메시지를 처리할 수 있습니다. 비순차적 배달: 메시지가 전송된 순서와 다를 수 있습니다. 즉, 가끔씩 메시지 순서가 바뀔 수 있습니다. 비용 SQS는 전송된 메시지 수에 따라 요금을 부과합니다. 스탠다드 큐는 FIFO 큐에 비해 단가가 낮습니다. 2. FIFO Queue FIFO 큐는 순서를 유지하면서 메시지를 처리해야 하는 애플리케이..
-
엔티티의 생성 및 수정 시간 자동화하기Spring 2024. 4. 9. 17:47
Spring Data JPA의 Auditing 기능을 사용하여 엔티티의 생성 시간과 수정 시간을 자동으로 기록하는 방법은 개발자로 하여금 반복적인 작업에서 벗어나게 하고, 코드의 간결성을 유지할 수 있게 합니다. 코드 예시 @Getter @MappedSuperclass @EntityListeners(AuditingEntityListener.class) public class BaseTimeEntity { @CreatedDate private LocalDateTime dateCreated; @LastModifiedDate private LocalDateTime dateUpdated; } Annotation 설명 @Getter Lombok 라이브러리의 어노테이션으로, 이 클래스의 모든 필드에 대한 gette..
-
프로젝트 회고 - 수업 스케줄 일괄 변경 배치 처리Spring 2024. 4. 8. 08:30
프로젝트 개요 각 센터마다 스케줄을 생성할 수 있습니다. 이에 대한 일괄 변경 기능을 제공하는 것인데요. 성능최적화를 통해 빠른 응답시간을 제공하는 것이 목표입니다. 해당 프로젝트에서 다른 주제는 다음과 같습니다. - 적정 ThreadPool Size 조정 - 적정 BatchSize 조정 - JMeter 성능 테스트 요구사항 - 자동공개 설정의 일괄 변경 기능 제공 - ASIS와 같이 실시간 처리 기능 제공 분석 - 기존 일괄변경 기능 UI에 들어가게 되는데, 저장 건수에 대한 LIMIT이 존재하지 않음 - 3만건 정도 조회하면 UI가 뻗는 현상 구현 제목이 일괄변경 배치 처리라고 해서, SpringBatch를 사용한 것은 아닙니다. Legacy 이다 보니, SpringBoot가 아닌 SpringFram..
-
프로젝트 회고 - 스케줄 자동 공개 성능 최적화Spring 2024. 4. 4. 00:44
이번 프로젝트는, 모든 센터의 수업스케줄을 자동으로 특정 시간에 공개해주는 기능 개선 작업이 있었습니다. 제가 맡은 부분은, 수업 스케줄에 대한 자동공개 설정을 그룹핑해서 연결해주는 알고리즘을 개발하는 부분이었습니다. 그런데..!! 배포 후에 다른 개발자가 개발한 부분에 문제가 발생했고, 해당 개발자가 갑작스레 부재중이 되어서 제가 넘겨 받아 빠르게 문제를 해결하게 되는 상황이 발생했습니다. 장애 상황 문제는, 사용자가 자동공개로 지정한 시간, 예를들어 다음과 같이 자동공개 시간을 설정한 경우 - 자동공개 시간 : 10시 30분 - 실제 자동공개 시간 : 10시 30분 위 처럼 되어야 하는데, - 자동공개 시간 : 10시 30분 - 실제 자동공개 시간 : 10시 33분 위와 같이 제시간에 공개되지 않고 ..
-
Spring Version에 맞는 h2Database 설치Spring 2023. 4. 16. 12:05
현재 내가 개발하고 있는 SpringBoot Version에 맞는 h2database 설치하기 의존성 관리 툴로는 Gradle을 사용했습니다. 제가 프로젝트를 실행하려고 하는 build.gradle 파일 입니다. plugins { id 'java' id 'org.springframework.boot' version '2.7.10' id 'io.spring.dependency-management' version '1.1.0' } group = 'junseok.snr' version = '0.0.1-SNAPSHOT' sourceCompatibility = '11' repositories { mavenCentral() } dependencies { implementation 'org.springframewor..
-
HikariCP 설정 일부분 들여다 보기Database 2023. 2. 26. 15:41
이번 글에서는 HikariCP를 설정하면서, 각 설정이 어떤 영향을 미치는지 확인해 보도록 하겠습니다. https://github.com/brettwooldridge/HikariCP HikariCP 공식 문서에 가보면, 설정들에 대해 자세한 코멘트가 되어 있습니다. 여기서 확인해 볼 HikariCP 설정 목록 connectionTimeout validationTimeout connectionTestQuery 참고로, 아래 4개 항목은 내용 정리만 되었습니다. minimumIdle maximumPoolSize idleTimeout maxLifetime 전체 코드 우선 전체 코드를 한번 보면 좋을 것 같네요. 보시는데 무리만 없을 정도로 정리 했습니다. 그리고, 중간중간 이해되지 않는 코드가 몇 줄 있을 수..
-
AsyncRestTemplate PATCH 메서드 유효하지 않은 요청JAVA 2022. 12. 30. 13:00
외부 API 연동 중 PATCH 메서드를 사용해서 통신해야 하는 일이 생겼다. 응답 결과가 중요하지 않았기 때문에, 응답을 기다리기 보다는,비동기 호출을 하기로 결정했다. 어떤 API를 활용할까 하다가 우리가 현재 쓰고 있는 버전이 Spring 4.x 버전이다보니, AsyncRestTemplate을 사용하기로 했다. 참고로, AsyncRestTemplate은 Spring5.0부터 Deprecated 되었다. https://docs.spring.io/spring-framework/docs/5.0.15.RELEASE/javadoc-api/deprecated-list.html https://docs.spring.io/spring-framework/docs/5.0.15.RELEASE/javadoc-api/org..