Frame Work/FastAPI

FastAPI에서 사용하는 Makefile CheetSheet

j4ko 2024. 11. 9. 15:30
728x90
반응형

목차

     

    개요 

    FastAPI에서 Makfile을 사용하다 보니 꽤나 자주 사용하는 명령어들의 모음이 생겼다. 언젠가 정리해둬야겠다 싶었는데 이번 기회에 정리해보고자 한다.


     

    1. ". env"를 사용할 수 있게 만들기

    ". env" 파일 프로젝트 코드 베이스 실행 간 필요한 환경변수들의 모음을 정의해 놓은 곳이다. Makefile에서도 이 환경변수를 참조해야 하는 경우가 있는데. 그럴 때 Makefile의 제일 상단에 다음과 같은 라인을 추가해 놓자.

    # .env 파일이 존재할 경우 환경변수로 가져오기
    ifneq (,$(wildcard .env))
        include .env
        export $(shell sed 's/=.*//' .env)
    endif

     


    2. uvicorn 실행하기

    개인적인 스타일에 따라 명령어를 어떤 식으로 정의할 정도의 차이겠지만 필자는 보통 Makefile을 통해 FastAPI 프로젝트를 실행하도록 명령어를 셋업 해둔다. 

    # makefile
    
    app.local:
    	 uvicorn src.main:application --host 0.0.0.0 --port 8080 --reload

     

    uvicorn 실행 시 특정 옵션을 사용하는 경우라면 다음과 같이 따로 정의해 둔다. 

    ...
    
    run.local.worker4:
    	uvicorn src:main.application --workers 4 --timeout-keep-alive 10  --log-config ./log.ini --reload

     

     


    3.  gunicorn 실행하기

    gunicorn 도 마찬가지다.

    run.gunicorn:
    	gunicorn src:main.application --worker-class uvicorn.workers.UvicornWorker -w 11 --keep-alive 60 --preload --bind 0.0.0.0:8000

    4. docker 실행하기

    docker 정도는 그냥 쉘에서 명령어로 실행하면 되지 않겠냐라고 할 수 있겠지만 Makefile을 통해서 명시적으로 드러내는 방법이 훨씬 더 낫다고 생각한다.

    run.docker.infra:
    	sudo docker-compose -f ./.docker/docker-compose-infra.yml up -d --remove-orphans

    5.  SQLAlchemy를 사용한다면 sqlacodegen 

    SQLAlchmey의 ORM 클래스를 자동으로 생성해 주는 sqlacodegen도 makefile에 정의해 두자.

    orm:
    	sqlacodegen mysql+pymysql://root:1234@localhost:9501/db > ./config/orm.py

     


     

    6. 테스트 실행하기

    locust를 이용해 로드테스트를 진행한다면 이 또한 포함이다.

    load.test:
    	locust -f ./load-test/locustfile-issue-v1.py --host=http://127.0.0.1:8000 --processes 3

    마치며

    기타 다른 예제로 Linting이나 Formatting 도구도 makefile에 두는 것이 좋은 선택일 수 있다. makefile에 명령어를 기술하는 방법은 프로젝트 수행 간 필요한 명령어를 공유하자라는 용도로 사용할 것을 추천하는 바이다. 

    728x90
    반응형