LOCK

· Spring Boot
0. 서론 동시성을 제어하는 방법은 각 상황에 따라 여러 가지가 존재합니다. 1. Java Application Level Synchronized Atomic ReentrantLock ConcurrentHashMap 2. Database Level Pessismistic Lock Optimistic Lock Named Lock 3. 분산 시스템 Redis Zookeeper 이번 글에서는 Database Level 의 Lock을 Spring JPA 환경에서 어떻게 사용할 수 있는지 알아보도록 하겠습니다. 들어가기에 앞서 공통으로 사용될 코드들을 먼저 작성해 보겠습니다. 재고의 정보를 저장할 간단한 Entity 입니다. 재고의 양을 quantity에 저장하고 있으며, decre..
· Java
1. 동시성(Concurrency)이란? 동시성은 여러 스레드가 동시에 실행될 때 발생합니다. 각 스레드는 독립적으로 작업을 수행하지만, 때때로 공유 자원(예: 데이터베이스)에 접근할 필요가 있습니다. 이때, 올바른 동시성 관리 없이 여러 스레드가 동시에 같은 자원에 접근하면 데이터 무결성을 위협하고 예측 불가능한 결과를 초래할 수 있습니다. 동시성 문제를 해결하지 못하면 데이터 불일치, 교착 상태(Deadlock), 성능 저하 등의 문제가 발생할 수 있습니다. 정확하고 효율적인 데이터 처리를 위해 이러한 문제들을 관리하는 것이 필요합니다. 2. 원자성과 가시성 1) 원자성(Atomicity) 원자성은 어떤 작업이 '전부 아니면 전혀'의 상태로만 존재한다는 원칙입니다. 은행 계좌에서 돈을 이체할 때로 예..