반응형

mysql 10

Query 분석 및 DB Index 설계

조회를 할 때 데이터가 얼마 없을 때는 상관없지만, 데이터가 수천, 수만 건의 경우 인덱스가 있냐 없냐의 따라 성능 차이가 엄청 크다고 한다.보통 인덱스는 카디널리티가 높은(중복도가 낮은) 컬럼으로 설정한다고 한다. (참고로 pk는 기본으로 인덱스로 설정되어 있음)예를 들어 주민등록번호의 경우 카디널리티가 높다고 할 수 있다.(Unique 하기 때문에)지금 나의 시나리오(콘서트 대기열)에서 인덱스 추가를 통해 성능을 개선할 수 있는 부분이 있는지 알아보자. 문제콘서트 예약 가능한 좌석을 조회하는 API 의 경우, 실제로 하나의 콘서트장에 5만명이 앉을 수 있는 대형 장소에서 하는 경우가 많다. 콘서트가 1만개만 있어도, 콘서트 좌석 조회하는 데이터는 5억개의 자리의 데이터가 들어가 있을 것이다. 원인테스..

캐시 및 Redis를 통한 성능 개선

캐시란?캐시는 자주 액세스하거나 계산 비용이 많이 드는 데이터를 일시적으로 저장하는 데 사용된다. 데이터에 액세스하는 데 걸리는 시간을 줄이고, 느린 리소스나 시스템의 로드를 줄여 성능을 향상시키는 데 도움이 된다.그럼 캐시를 사용하기 위한 적절한 데이터의 판단 기준은 무엇일까?데이터가 변경에 민감한지?데이터의 연산에 드는 비용이 비싼지?데이터의 변경이 전파가 되는지?→ 요약하자면, “잘 바뀌지 않으면서 접근할 일이 많은 데이터, 변경되더라도 다른 서비스에 큰 영향을 미치지 않는 데이터” 가 캐시에 저장하여 활용하기 적절하다.그럼 DB에서 계산 비용이 많이 드는(쿼리를 날렸을 때 시간이 오래 걸리는) 경우는 어떤 경우들이 있을까?조인이 복잡할 경우복잡한 조인 조건이 있는 여러 테이블과 관련된 쿼리, 특히..

대기열 서비스 구현(+Redis)

제가 콘서트 예약시스템에서 구현한 대기열에 대한 설계에 대해서 얘기해보겠습니다. 대기열이란?대기열 시스템은 많은 사용자들이 동시에 접근하는 상황에서, 시스템의 안정성과 성능을 보장하기 위해 필수적인 요소입니다. 특히, 티켓 예매, 상품 구매, 서비스 예약 등과 같은 상황에서 대기열 시스템이 중요한 역할을 합니다.만약 1000명의 유저가 동시에 좌석 예약을 위해 요청을 보낸다면, 정해진 선착순 100명만 예약이 가능하게 하고, 나머지는 대기열에서 대기하게 됩니다.이렇게 하면 트레픽의 유량을 제어할 수 있기 때문에 서버의 부하를 줄일 수 있습니다. 대기열에 있는 유저는 일정 시간이 지나면 좌석 예약이 가능하게 되어 콘서트 좌석을 예약할 수 있습니다. 대기열 구현 방법전통적으로? 대기열을 구현하는 방식에는 크..

Mysql 기반 선착순 쿠폰 발급 기능 개발 (5)

동시성 이슈를 해결하기 위해 다음과 같은 방식으로 순차적으로 적용해보겠다.synchronizedredis lockmysql lock각 방식을 적용함으로써 장단점도 같이 알아보겠다. 동시성 이슈 해결 - synchronized 들어가기 앞서 synchronized 가 무엇인지 알아보자.스레드 동기화란?스레드 동기화는 멀티스레드 환경에서 여러 스레드가 하나의 공유자원에 동시에 접근하지 못하도록 막는것을 말한다.공유데이터가 사용 되어 동기화가 필요한 부분을 임계영역(critical section)이라고 부르며, 자바에서는 이 임계영역에 synchronized 키워드를 사용하여 여러 스레드가 동시에 접근하는 것을 금지함으로써 동기화를 할 수 있다.  synchronized 사용 방법1) 메소드에 synchron..

Mysql 기반 선착순 쿠폰 발급 기능 개발 (4)

성능테스트에 앞서 미리 알고 있으면 좋은 것들에 대해서 설명하겠다. 성능 테스트에서 서비스가 빠른지 느린지에 대한 기준은 다음과 같이 크게 2가지로 판단할 수 있다.ThroughputLatency Throughput Throughput이란 시간당 처리량을 의미한다.TPS(Transaction Per Second), RPS(Request Per Second) 등으로도 불리며, '1초에 처리하는 단위 작업의 수' 혹은 '1초에 처리하는 HTTP 요청 수' 등으로 해석할 수 있다. 즉, 1초에 최대한 많은 작업을 처리할 수 있는 서비스가 성능 측면에서 좋은 서비스라고 볼 수 있다. 예를 들어, A 서비스는 1초에 1000개의 작업을 처리하고, B 서비스는 1초에 2000개의 작업을 처리할 수 있는 능력을 가졌..

Mysql 기반 선착순 쿠폰 발급 기능 개발 (3)

이제부터 만든 서비스를 호출하기 위해 presentation Layer 설계를 해보자. 그전까지는 다른곳에서 가져다 쓸 mycoupon-core 에서 작업하였고, 지금은 mycore-api에서 작업을 진행하겠다. CouponIssueController // mycouponapi/controller/CouponIssueController.java package com.example.mycouponapi.controller; import com.example.mycouponapi.dto.CouponIssueRequestDto; import com.example.mycouponapi.dto.CouponIssueResponseDto; import com.example.mycouponapi.service.Coup..

Mysql 기반 선착순 쿠폰 발급 기능 개발 (2)

쿠폰 엔터티 발급 기능 이제부터 본격적으로 coupon 엔터티에 기능을 추가해보자. 서비스에 기능을 추가할 수 있지만, DDD 관점에서 설정을 한다면 도메인과 관련된 기능은 도메인에 넣어주는 것이 좋다. Coupon // mycouponcore/model/Coupon.java package com.example.mycouponcore.model; import jakarta.persistence.*; import lombok.AllArgsConstructor; import lombok.Builder; import lombok.Getter; import lombok.NoArgsConstructor; import java.time.LocalDateTime; @Entity @Builder @NoArgsConst..

Mysql 기반 선착순 쿠폰 발급 기능 개발 (1)

mysql, redis 설정 먼저 mysql과 redis를 도커 컨테이너로 띄우기 위해 docker-compose를 작성해 주자. //docker-compose.yml version: '3.7' services: redis: container_name: coupon-redis image: redis:7.2-alpine command: redis-server --port 6380 labels: - "name=redis" - "mode=standalone" ports: - 6380:6380 mysql: container_name: coupon-mysql image: ubuntu/mysql:edge command: mysqld --character-set-server=utf8mb4 --collation-ser..

2. 프로젝트 환경 설정

멀티모듈 구성 좀 더 효율적인 관리를 위해 멀티모듈로 구성해 볼 예정이다. dependecy는 필요할 때 그때 추가하기로 한다. create를 누르면 다음과 같이 프로젝트가 생성될 것이다. 제일 바깥의 디렉토리는 src 폴더가 필요없으니 삭제해주도록 하자. 루트 디렉토리(mycoupon)에서 우클릭 > new > Module… 선택하면 새로운 모듈을 만들 수 있다. 위의 타이틀에 New Module을 꼭 확인하자!! 아까와 동일하게 dependency를 나중에 넣어줄 예정이기에 그냥 바로 craete를 해주자. 총 3가지 모듈로 구성될 것이다. mycoupon-api mycoupon-consumer mycoupon-core 보통 멀티모듈로 구성할 때는 공통으로 가져다 쓰는 모듈을 core로 두고, 나머지..

1. 요구사항 분석 및 도메인 설계

선착순 쿠폰 발급 시스템이란? 한정된 수량의 쿠폰을 먼저 신청한 사용자에게 제공하는 시스템을 말합니다. 선착순 쿠폰 이벤트 요구사항 특정 기간(ex) 2024-04-01 오후 3시 ~ 2024-04-07 오후 8시)에 발급해야 한다. 한 유저당 한번의 쿠폰이 발급되어야 한다. 선착순 쿠폰의 최대 발급 수량이 정해져 있다. 기능 정의서 쿠폰 발급 기능 쿠폰 발급 기간 검증 쿠폰 발급 수량 검증 쿠폰 전체 발급 수량 중복 발급 요청 검증 쿠폰 발급 쿠폰 발급 수량 증가 쿠폰 발급 기록 저장 coupon_id user_id 구현 목표 정확한 발급 수량을 제어합니다.(동시성 이슈 처리) 많은 트레픽이 들어와도 안정적으로 높은 처리량 도메인 크게 2가지 도메인이 있다. 쿠폰 쿠폰 발행 로직에 집중하기 위해 핵심 ..

반응형