Notice
Recent Posts
Recent Comments
Link
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | ||||||
2 | 3 | 4 | 5 | 6 | 7 | 8 |
9 | 10 | 11 | 12 | 13 | 14 | 15 |
16 | 17 | 18 | 19 | 20 | 21 | 22 |
23 | 24 | 25 | 26 | 27 | 28 |
Tags
- exception
- 관점지향프로그래밍
- 객체지향프로그래밍
- 스프링 시큐리티
- git
- 자바
- Redis
- OOP
- 트랜잭션
- response
- 스프링부트
- http
- MYSQL
- request
- java
- RestControllerAdvice
- aop
- proxy pattern
- network
- mybatis
- Filter
- Spring
- aspect
- 인터셉터
- 디자인패턴
- SQL
- spring boot
- Interceptor
- 스프링
- Spring Security
Archives
- Today
- Total
목록분산락 (1)
장쫄깃 기술블로그

분산락(Distributed Lock)의 필요성분산락(Distributed Lock)은 분산 시스템에서 여러 노드 또는 프로세스가 동시에 공유 자원에 접근하려 할 때, 충돌을 방지하고 자원의 일관성을 유지하기 위해 사용하는 기술이다. 이를 통해 여러 컴퓨터 또는 서버가 동시에 동일한 자원에 접근할 때 발생할 수 있는 문제를 해결할 수 있다. Redis는 기본적으로 싱글 스레드로 동작하므로, 단일 Redis 노드를 사용해도 동시성 문제는 발생하지 않는다. 따라서 리소스에 값을 설정하여, 값이 설정된 경우에는 다른 클라이언트의 접근을 차단할 수 있다. 필자는 분산 환경에서 선착순 신청 기능을 개발하면서, 처음에는 DB에 직접 락을 거는 비관적 락을 사용했다. 그러나 Deadlock이 자주 발생하자, 분산락으..
Spring Framework/Spring Boot
2024. 10. 18. 15:44