25 lines
3.5 KiB
Markdown
25 lines
3.5 KiB
Markdown
---
|
|
category: Backend
|
|
tags: [auto-wikified, technical-documentation, backend]
|
|
title: Django Signals
|
|
description: "Django 시그널(Signals)은 모델 저장과 같은 특정 이벤트가 발생할 때 암시적으로 지정된 동작을 실행하게 해주는 기능이다 [1]."
|
|
last_updated: 2026-05-04
|
|
---
|
|
|
|
# Django Signals
|
|
|
|
## 📌 Brief Summary
|
|
Django 시그널(Signals)은 모델 저장과 같은 특정 이벤트가 발생할 때 암시적으로 지정된 동작을 실행하게 해주는 기능이다 [1]. 데이터베이스 모델 매핑 외의 부가적인 로직이나 기술적 관심사를 처리하기 위해 사용되기도 하지만, 많은 실무 개발자들에게 기피해야 할 요소로 간주된다 [2-4]. 특히 대규모 시스템에서는 코드의 실행 흐름을 파악하기 어렵게 만들기 때문에 실무에서 가장 경계해야 할 안티 패턴(Anti-pattern) 중 하나로 평가받는다 [1, 3].
|
|
|
|
## 📖 Core Content
|
|
* **로직의 분리와 이동 수단:** Django 프레임워크에서 데이터베이스 스키마 매핑 이상의 로직을 모델에 전부 집중시키는 것(Active Record 패턴)을 피하기 위해, 비즈니스 로직이나 부가 작업을 매니저(managers)나 시그널 핸들러로 이동시키는 방식이 활용되기도 한다 [2, 3].
|
|
* **제한적인 기술적 관심사 처리:** 데이터 통합이나 인덱스 재구성(reindexation)을 트리거하는 등의 특정한 기술적 관심사를 처리하는 데에는 시그널이 유용한 접근법이 될 수 있다 [3]. 주의를 기울여 제한적으로 사용한다면 개발에 도움이 될 수 있다는 일부 의견도 존재한다 [5].
|
|
* **명시적 서비스 패턴으로의 대체 추세:** 현대 Django 아키텍처에서는 모델과 비즈니스 로직을 분리하기 위해 시그널보다는 '서비스 레이어(Service Layer)'나 '리포지토리(Repository)' 패턴을 사용하는 방향으로 나아가고 있다 [1, 3]. 시그널 대신 명시적인 서비스 함수 호출을 통해 로직을 관리하는 것이 기술 부채를 줄이는 대규모 시스템의 정석으로 여겨진다 [1].
|
|
|
|
## ⚖️ Trade-offs & Caveats
|
|
* **실행 흐름의 불투명성과 부수 효과(Side-effects):** 시그널 도입의 가장 치명적인 부작용은 '보이지 않는 부수 효과(Invisible side-effects)'를 만들어낸다는 점이다 [4]. 동작이 이벤트에 암시적으로 연결되므로 전체적인 코드의 실행 흐름을 불투명하게 만들며, 이는 시스템에 예상치 못한 오류를 유발하는 원인이 된다 [1].
|
|
* **비즈니스 로직의 오염 통제 불가:** 시그널은 단순한 데이터 처리나 기술적 목적을 넘어 비즈니스 로직이 침투(creeping in)하기 시작할 때 가장 큰 문제를 낳는다 [3]. 로직이 여러 시그널에 흩어지게 되면 결국 시스템의 동작을 추적할 수 없는 통제 불능(out of hands) 상태에 빠지게 된다 [3].
|
|
* **명시적 호출을 통한 제약 극복:** 이러한 제약 사항 때문에 시그널은 전염병처럼 피해야 할(avoid them like the plague) 최악의 아이디어로 꼽히기도 한다 [4]. 이를 해결하기 위한 기술적 최적화 방향은, 모델 인스턴스를 생성하거나 업데이트하는 방식을 코드베이스 전반에서 단일화하고, 저장 전후(pre-/post-save)의 로직과 유효성 검사 로직을 외부로 분리하여 명시적으로 호출(call out)하는 것이다 [1, 4].
|
|
|
|
---
|
|
*Last updated: 2026-05-03* |