서버에 신경쓰고 싶지 않을 때,
비동기작업을 하고 싶을 때
혹은 perdioc task 를 하고 싶다면
아래의 절차를 따라보세요.
Django + Celery + Elasticache 조합을 Elasticbeanstalk으로 띄우는 것은정말 검색해도 안나오는,머리 아픈 일입니다.
제 1장. Django + Celery + Elasticache
조합 갖추기
celery-beat패키지를 설치해 manage.py migrate django_celery_beat로 Django ORM을 이용해 Periodic task를 제어
celery_result_backend=django_db로 result를 orm으로 즉시 확인할 수 있게 한다
1. Project app은 실행된다.
djecommerce/init.py
from .celery import app as celery_app
all = ('celery_app',)
2. Project app에서 celery.py를 설정한다
from ____future____ import absolute_import
import os
from decouple import config
from celery import Celery
from celery.schedules import crontab
from django.conf import settings
DEBUG = config('DEBUG', cast=bool)
if DEBUG:
os.environ.setdefault('DJANGO_SETTINGS_MODULE', 'djecommerce.settings.development')
else:
os.environ.setdefault('DJANGO_SETTINGS_MODULE', 'djecommerce.settings.production')
app = Celery('djecommerce')
app.config_from_object('django.conf:settings', namespace='CELERY')
app.autodiscover_tasks()
djecommerce라는 name으로 Celery class 생성
settings에 지정되어있는 config 가져오기
@app.task(bind=True)
def dj_debug(self):
print('Request: {0!r}'.format(self.request))
3. autodiscover_tasks는
registered app/tasks.py 를 찾는다
user/tasks.py
auction/tasks.py
core/tasks.py
@app.task
Celery Class가 필요하다
@shared_task
가장 최근에 선언된 Celery Class를 가져다 쓴다(재사용성이 높은 앱에 쓰면 좋겠다)
@shared_task
def Phone_SMS_Send(phone, content):
pass
4. auction/views.py
Phone_SMS_Send.apply_async( args=[phone, content], ignore_result=False)
result = AsyncResult(task_id)
if result.ready():
result.result
>
#Tips
Phone_SMS_Send.apply_async(kwargs={'foo':'bar'})
>
core/tasks.py
Phone_SMS_Send.apply(**kwargs):
foo=kwargs['foo']
5. djecommerce/settings/base.py
CELERY SETTING(broker_url, result_backend)
CACHE SETTING(Elasticache endpoint) & security group은 콘솔에서 직접
django_celery_results
django_celery_beat -> django orm에서 (python manage.py migrate django_celery_beat django_celery_result)
#CELERY
DJANGO_CELERY_BEAT_TZ_AWARE = False
REDIS_LOCATION_PRIMARY=config('REDIS_LOCATION_PRIMARY')
REDIS_LOCATION_REPLICA=config('REDIS_LOCATION_REPLICA')
CELERY_ALWAYS_EAGER = True
CELERY_BROKER_URL = f"redis://{REDIS_LOCATION_PRIMARY}"
# CELERY_BROKER_URL = "redis://127.0.0.1:6379/"
CELERY_RESULT_BACKEND = "django-db"
CELERY_ACCEPT_CONTENT = ['application/json']
CELERY_TASK_SERIALIZER = 'json'
CELERY_RESULT_SERIALIZER = 'json'
CELERY_TIMEZONE = "Asia/Seoul"
>
CACHES = {
"default": {
"BACKEND": "django_redis.cache.RedisCache",
"LOCATION": [ REDIS_LOCATION_PRIMARY, REDIS_LOCATION_REPLICA, ],
"OPTIONS": {
"CLIENT_CLASS": "django_redis.client.DefaultClient",
"MASTER_CACHE": REDIS_LOCATION_PRIMARY,
},
}
}
>
INSTALLED_APPS={
'django_celery_beat',
'django_celery_results',
}
제2장. Elasticbeanstalk으로 띄우기
6. elasticbeanstalk Procfile에서 celery 설정
단 세줄로 끝냈습니다.
백그라운드 프로세서를 돌리고 싶은데,
Elasticbeanstalk 를 worker (워커)로 돌릴 수 있는 instance가 있습니다. <-- 너무 무거움
라이트한 것을 원할 때는 : 백그라운드 워커 = 백그라운드 프로세스
procfile을 override시켜주면 됩니다.
elasticbeanstalk을 배포할 때마다,
procfile에 있는 script을 읽어서 실행시키게 됩니다
그러면 background processor가 실행됩니다.
세번째 줄 celery_beat는 scheduler
web: gunicorn --bind :8000 djecommerce.wsgi:application
celery_worker: celery -A djecommerce.celery.app worker --concurrency=1 --loglevel=INFO -n worker.%%h
celery_beat: celery -A djecommerce.celery.app beat --scheduler django_celery_beat.schedulers:DatabaseScheduler --loglevel=INFO
7. Elasticache instance 만들기
- security group에 EB Security group추가
- EC2 inbound rule에 6379 port로 상기 EB security group추가
셀러리 참고 내용 다큐먼트 링크
https://docs.celeryq.dev/en/latest/userguide/calling.html?highlight=apply_async#basics
'Reviews > Daily Stuff' 카테고리의 다른 글
젤리추천| 젤리 덕후 분들에게 추천합니다. 젤리를 추천해주는 곳 발견! (0) | 2023.02.15 |
---|---|
운전면허| 우당탕탕 면허따기 1탄 : 교육부터 필기시험까지 (0) | 2023.02.08 |
선물추천| 아이브릭 눈 마사지기 제스파(ZESPA) 선물받은 후기 (0) | 2023.01.04 |
건강검진후기| 인구보건복지협회 국가건강검진 (feat. 위내시경. 수면없이.) (0) | 2023.01.04 |
[네이버 웹툰 추천] 주인공이 세고 똑똑한, 하드캐리하는 웹툰 추천 (2) | 2022.12.17 |