본문 바로가기

분류 전체보기362

[ETC 5편] git feature branch 내용을 develop release 둘다 반영해야하는 경우 목차는 ETC 목차 에 있습니다. [ETC 5편] git feature branch 내용을 develop release 둘다 반영해야하는 경우 나중에 볼려고 정리했습니다. 상황 git 에서 feature branch 에서 작업하고 있는데 develop, release 에 둘다 반영해야하는 경우가 생길 수 있습니다. feature branch 는 develop branch 를 기준으로 만들어진거라 feature branch -> develop branch 로 pr 을 날려서 merge 하면 문제 없습니다. (feature branch 변경사항만 반영됨) 문제는 feature branch 를 release 에 반영할 때인데, feature branch 가 develop 을 기준으로 만들어진거라 release.. 2023. 6. 24.
[상품 주문 4편] 동시성 테스트 source 는 Github 에 있습니다. 목차는 상품 주문 에 있습니다. [상품 주문 4편] 동시성 테스트 Webflux, 코틀린, Redis, 분산락 공부를 위해 작성했습니다. 테스트 데이터 데이터를 아래와 같이 미리 만들었습니다. (Spring - schema.sql) Application 이 실행될 때, 아래 데이터가 INSERT 됩니다. id 는 productId, name 은 product_name, stock 은 재고입니다. insert into product (id, name, stock) values ('product1001', 'Product A', 1000), ('product1002', 'Product B', 2000), ('product1003', 'Product C', 3000).. 2023. 5. 8.
[상품 주문 3편] Redis 설명 source 는 Github 에 있습니다. 목차는 상품 주문 에 있습니다. [상품 주문 3편] Redis 설명 Webflux, 코틀린, Redis, 분산락 공부를 위해 작성했습니다. Redis 분산락 로직 설명 메소드를 실행 하기 전에 lock 을 획득하고, 메소드를 실행합니다. 메소드 실행이 끝나면 lock release 가 이루어집니다. 로직 개선 사항 jointPoint.proceed 부분이 비즈니스 로직을 실행하는 부분입니다. 해당 부분은 별도 트랜잭션으로 분리를 해야하는데, 비동기 + kotlin 환경에서 트랜잭션을 분리하는 방법을 찾지 못해 숙제로 남겨놨습니다. 트랜잭션을 별도로 분리해야하는 이유는 lock 을 거는 부분이 비즈니스 로직과 하나의 트랜잭션으로 묶여서 처리되면 안되기 때문입니다... 2023. 5. 8.
[상품 주문 2편] 비즈니스 로직 API 설명 source 는 Github 에 있습니다. 목차는 상품 주문 에 있습니다. [상품 주문 2편] 비즈니스 로직 API 설명 Webflux, 코틀린, Redis, 분산락 공부를 위해 작성했습니다. 비즈니스 로직 API 설명 상품 주문 API 를 호출 시, 재고 감소와 상품 주문 데이터가 생성됩니다. 상품 주문 (POST) 상품을 주문하는 API 입니다. 비즈니스 로직 설명 상품의 재고를 감소시킨 후에, 상품 주문 테이블에 INSERT 를 하는 로직입니다. 하나의 트랜잭션으로 처리됩니다. 또한, 동시성 이슈를 해결하기 위해 메소드 시작 전에 productId 를 기준으로 redis lock 을 잡고, 메소드가 끝날 때, lock 이 release 됩니다. Custom annotation (@Distribute.. 2023. 5. 8.