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 | 29 | 30 |
Tags
- iterm2 shortcuts
- 컨테이너
- terraform 문법
- DynamoDB
- 파이썬
- 도커
- terraform
- test
- Shell
- 도커컴포즈
- iterm2 단축키
- customize
- minikube mac 설치
- nosql
- 테라폼 기본 문법
- BIG-O NOTATION
- server
- python
- minikube 설치 방법
- docker
- 테라폼 문법
- Django
- zshrc
- sftp란
- 빅오노테이션
- Bash
- AWS
- linux
- docker-compose
- zsh
Archives
- Today
- Total
목록SQL (1)
sklass의 s-class 프로그래밍 blog
[Django] select_for_update()를 활용한 동시성 제어
django의 sql 데이터베이스를 사용하다보면 트래픽이 적은곳에서는 잘 작동하는데, 트래픽이 몰리는 경우, 데이터를 update를 하는 과정에서 동시적으로 update가 발생해서 데이터가 유실되는 상황이 속출하게 된다. 이러한 문제를 해결하려면 select_for_update()라는 django의 내장함수를 사용해서 sql에 data를 업데이트 할 때 row lock을 걸어서 동시성을 제어합니다. select_for_update()의 파라미터로 nowait과 skip_locked라는게 있는데, 이 둘의 기본값은 False로 세팅되어 있습니다. nowait=False 인 경우, 조회하고자 하는 데이터에 row lock이 걸려있다면 해당 lock이 풀릴 때까지 대기를 합니다. True일 경우, 에러를 발생..
django
2021. 8. 24. 12:43