Kasa에서 2022-11-30에 잔행한 Handling Concurrent request in Django를 주제로 진행한 세미나를 정리한다.


Index

  1. Intro: 네? 저보고 세미나를 진행하라구요?
  2. 세미나 - Handling Concurrent Request in Django
  3. 세미나 회고
  4. 참고 자료

Intro: 네? 저보고 세미나를 진행하라구요?

얼마 전부터 회사에서 주니어들이 돌아가면서 세미나를 진행하고 있었다. 내 차례가 올 것이라 의심조차 하지 않고 즐거운 마음으로 세미나를 참석하기를 여러 번, 결국 CTO님께 다음 세미나 발표자는 나라는 슬랙을 받았다. 그렇게 나는 20명 정도 되는 사내 엔지니어들 앞에서 세미나를 진행하게 되었다.


주제 선정

주제를 선정할 때는 내가 실무를 하면서 마주했던 경험일 것과 백엔드 개발자가 General하게 마주할 수 있는 경험일 것을 중심으로 고려했다. 이렇게 추려보니 총 5개 정도의 후보가 나왔다.


후보

  1. API에 동시 요청이 왔을 경우 처리 방법
  2. Kasa Singapore에서 청약이 종료되고, 안분비례를 이용하여 DABS를 분배/발행/상장 하는 과정
  3. PKI와 Digital Certificate
  4. Oauth Client 만들기 with Singpass
  5. 데이터 마이그레이션

모두 다 좋은 주제였지만 가장 최근에 만난 문제가 API에 동시 요청이 왔을 경우 처리 방법 이고, 다른 발표 주제들은 조금 더 구체적인 만큼 백엔드에 General하지 못한 거 같아 1번을 주제로 디벨롭 하기로 했다. 주제를 어나운스 하기 위해 멋진 타이틀을 만들었어야 했는데 결국 고심 끝에 Handling Concurrent Request in Django로 결정했다. in Django 인 이유는 회사에서 쓰고 있는 백엔드 프레임워크가 Django이기 때문이다.


[Picture 1] 슬랙 어나운스

발표 흐름

주제 선정 후, 어떻게 자연스러우면서 일관성이 있는 발표를 할 수 있을까 고민을 하다가 아래의 흐름과 같이 발표를 진행하기로 했다.


[Picture 2] 발표 순서

관련 자료를 수집하면서 주제 선정과 발표 흐름을 정하는 게 시간이 오래 걸렸는데 앞의 두 개가 정해지니 준비에 속도가 붙어 발표 자료를 만드는 것과 대본 작성은 비교적 빠른 시간 안에 끝낼 수 있었다. 앞으로는 실제로 어떤 내용으로, 어떻게 발표를 했는지 다뤄보겠다.


세미나 - Handling Concurrent Request in Django

발표 영상



세미나에 참석한 동료분이 감사하게도 발표 영상을 찍어주셨다. 발표 중에는 앞을 보려고 엄청 많이 노력을 했다고 생각했는데, 막상 영상을 보니 생각보다 앞을 보는 시간이 짧았다. 아마도 긴장을 해서 대본을 까먹을지도 모른다는 마음에 나도 모르게 PPT 화면을 더 많이 본 거 같다.

테크 회사에서 외부의 큰 세미나를 주최할 때 발표자들의 세션 영상이 올라오는 걸 봤었는데, 큰 세미나는 아니지만 나도 발표자로 참석한 세션 영상이 생겨 낯설기도 하면서 뿌듯하다.


Handling Concurrent Request in Django

발표 떄 한 말들을 상세하게 블로그에 정리할까 싶었지만, 이미 PPT에 많은 말을 써두었기 때문에 블로그에는 PPT를 올리고, 간략하게 몇 가지 코멘트를 추가하기만 하겠다.

목차

[Picture 3] 목차

서론

[Picture 4] Concurrent Request란?

[Picture 5] Race Condition

[Picture 6] Race Condition 예시

[Picture 7] 내가 만난 이슈

API 요청을 Serialize 하는 방법

[Picture 8] 이번 장에서 다룰 것들

[Picture 9] 하나의 큐에 모아서 처리

[Picture 10] 지금 API 환경

[Picture 11] Transaction이란?

[Picture 12] DB lock approach

Django Transaction Atomicity

[Picture 13] Django ORM

[Picture 14] DB lock

Deal Finalize 오류 해결 방법 with select_for_update
[Picture 15] 기존 코드

[Picture 16] select_for_update 1차 시도

[Picture 17] select_for_update 2차 시도

[Picture 18] select_for_update 3차 시도: 성공

[Picture 19] select_for_update 주의점: dead lock

[Picture 20] select_for_update 주의점: lazy loading

Deal Finalize 오류 해결 방법 with Compare-and-swaps
[Picture 21] Compare-and-swaps

청약 최대 갯수 검증 오동작 오류 해결 방법 with select_for_update
[Picture 22] 이력 관리 구조

[Picture 23] DB lock 없이 Exception Rasing으로 해결

[Picture 24] 이력 관리 구조에서 select_for_update 쓰기 위한 선 작업

[Picture 25] select_for_update

청약 최대 갯수 검증 오동작 오류 해결 방법 with redis lock
[Picture 26] redis lock

Django Transaction Test & Durability

[Picture 27] Django Transaction Test

Django Durability

Atomicity를 다루다가 Durability 를 언급하여 주제가 조금 튀면 어쩌지 고민을 했지만, 이번 발표를 준비하면서 Durability 도 비즈니스 로직에서 충분히 쓸 여지가 많아보여 추가했다.


[Picture 28] ACID

[Picture 29] Transaction 단위를 잘 묶었을 경우

[Picture 30] Transaction 단위를 잘못 묶었을 경우

[Picture 31] Django Durability를 사용해서 해결

[Picture 32] 3.2 미만에서는 어떻게 하나...?

[Picture 33] Transaction 단위 잘못 묶는 것을 방지하는 방법

결론

[Picture 34] 장고의 고수

[Picture 35] 결론

Q&A

결국 Handling Concurrent Request in Django는 3가지 방법이 있음을 발표 중에 다뤘다.

  1. Message Queue를 사용하기
  2. Exception Rasing 해서 Rollback 하기
  3. DB lock 사용하기

질문이 들어왔던 부분은 1번이었다. 발표에서는 지금의 멀티 파드 구조에서 하나의 큐를 사용하면 멀티 파드의 이점을 살릴 수 없어서 선택하지 않았다고 말씀드렸으나, 사실은 아직 카프카 등의 메세지 큐에 대해 자세히 알지 못한 부분도 있었기에 바로 질문이 들어왔던 거 같다. 앞으로 메세지 큐에 대해서 공부를 해야 함을 느꼈다.

또 Exception Rasing Rollback과 DB lock 사용에서 어떤 것을 선택하는 것이 더 이점인지에 대해 질문이 들어왔다. 실제로 문제를 해결한 방안은 Exception Rasing Rollback 방식이라고 답변을 드렸었는데 정확히 언제 Exception Rasing Rollback을 사용하고, 언제 DB lock을 사용하는 게 이점인지 뚜렷하게 알았다면 더 좋은 답변을 드렸을 거 같다.


세미나 회고

처음에 CTO님이 세미나를 준비하라고 하셨을 때는 많이 당황스러웠다. 부끄럽지만 퇴근 하고 발표 자료를 준비할 때는 정말 하기 싫어서 미룬 적도 많았다. 하지만 하기 싫은 마음을 추스려 발표를 준비하고, 발표를 마치고 나니 오히려 배운 점이 많았던 것 같다.

잘한 점

  • 발표 순서를 선정할 때 흐름이 자연스러울 수 있도록 단계적으로 배치를 했다.
  • 중간에 집중력이 흐트러 지는 것을 방지하기 위해 앞으로 다룰 내용을 정리하는 페이지들을 넣었다.
  • 주제를 선정할 때, 내가 경험했던 문제를 선택했다. 자연스럽게 다른 사람들의 해결 방법을 들을 수 있었다.
  • 애플의 Keynote 기능을 사용해 맥북과 아이패드를 연결해 스크린을 조작했다. 때문에 흐름이 끊기지 않게 스크린을 조작했다.

부족한 점

이번 발표에서 부족하다 생각하는 부분을 추려봤다. 처음으로 진행하는 세미나에, 20명 정도 되는 엔지니어들이 참석한다고 하니 긴장을 많이 했는데 긴장한 것에 비해서 준비를 조금 모자라게 한 것 같아 아쉬운 마음이 많이 든다. 다음 번에 더 잘하자!

  • PPT 화면이 아니라 앞을 보도록 의식적으로 노력하자.
  • 대본을 2일 정도 전에 작성해서, 숙지하는 시간을 더 가지도록 하자.
  • Q&A에서 당황하지 말자. 질문이 들어올 부분을 미리 예상해 준비하자.
  • 발표 내용에서 내가 확신이 없는 부분은 없어야 한다, 충분히 준비했다고 만족하지 말고 거듭 준비하자!

참고 자료

Main 자료


Sub 자료