- Elasticsearch
- Kibana
- Logstash
- MongoDB
- PostgreSQL
- Redis
- Celery
- Docker
- RabbitMQ
- Locust
- ...
# 프로덕션 시 설정
DJANGO_SETTINGS_MODULE=config.settings.development
# django secret
SECRET_KEY=시크릿키
# database
DB_NAME=postgres
DB_USER=postgres
DB_PASSWORD=1234
DB_HOST=my_postgres_container
DB_PORT=5432
# grafana
GRAFANA_USER=admin
GRAFANA_PASSWORD=1234
# elasticsearch // 유저네임 elastic
ELASTIC_USER=elastic
ELASTIC_PASSWORD=1234
# redis
REDIS_PASSWORD=1234
# mongo
MONGO_DB_NAME=dts
MONGO_HOST=mongodb # Docker Compose 서비스 이름
MONGO_PORT=27017 # Docker Compose 포트
MONGO_USER=mongo
MONGO_PASSWORD=1234
# rabbitmq
RABBITMQ_USER=rabbitmq
RABBITMQ_PASSWORD=1234
docker-compose build --no-cache
docker-compose --env-file .env up -d
- JWT 방식을 이용한 로그인 기능을 적용, 로그아웃 시에는 리프레시 토큰을 블랙리스트에 등록하는 방식
- JWT 토큰은 기본적으로 쿠키에 저장되며, iOS의 경우 쿠키를 지원하지 않아 헤더에서 토큰을 읽는 방식도 함께 적용
- tests.py 작성 중...
- 게시물 api에 transaction.atomic을 사용하여 낙관적 동시성 제어를 적용
- 게시물을 title과 content 필드를 기준으로 elasticsearch를 적용하여 검색 가능
- 게시물 작성 시 게시물 작성자에게 알람이 가도록 구현함
- 게시물에 댓글 작성 시 게시물 작성자, 댓글 작성자, 게시물에 댓글을 작성한 모든 유저에게 알림이 가도록 구현함
- 재귀방식을 이용하여 1depth의 대댓글 기능 구현
- soft delete 방식으로 삭제 처리
- 광고 조회 시 조회한 광고의 아이디, 유저의 id, ip주소, 조회한 시간을 MongoDB에 저장
- 광고 클릭 시 클릭한 광고의 아이디, 유저의 id, ip주소, 클릭한 시간을 MongoDB에 저장
- 광고에 캐싱을 적용하여 조회 시 성능 최적화
- 저장된 데이터를 celery(beat)를 사용하여 주기적으로 집계하여 PostgreSQL에 저장
광고 클릭 -> 클릭 로그 저장 -> MongoDB -> PostgreSQL -> Logstash -> elasticsearch -> Kibana -> [광고주 | 마케터 | 관리자]
- prometheus
- kafka
- 부하테스트