1.Pydantic사용법
Pydantic
이라는 이름은 Python 기반의 타입 힌트 및 데이터 검증 라이브러리로서, “엄격하고 꼼꼼한 데이터 검증”이라는 컨셉을 “Pedantic”에서 가져와 “Py”와 결합시킨 합성어
Pydantic은 데이터 유효성 검증을 위해 주로 사용되며, 타입 힌트를 통해 안전하게 데이터를 핸들링합니다.
1.1 Pydantic 소개&기능
- DataValidation/SettingsManagement라이브러리
- TypeHint를 런타임에서 강제해 안전하게 데이터핸들링
data:image/s3,"s3://crabby-images/45306/45306688e317be283de0208bc251c6906de1604f" alt=""
- 머신러닝 FeatureDataValidation으로도 활용가능
data:image/s3,"s3://crabby-images/c4a08/c4a0820141f092ec4d626a697fe51d842c476cce" alt=""
pydantic은 validation 및 config 관리를 하는데 이 두가지 기능에 대해서 배워보자.
1.2 Validation
Machine LearningModel Input Validation
일반 Python class 활용
data:image/s3,"s3://crabby-images/1a848/1a848f7fa3c369a12b661ff2af472858fa921966" alt=""
data:image/s3,"s3://crabby-images/881ce/881ce91933ef4371871985775b650d3645653071" alt=""
- PythonClass로InputDefinition및Validation=>의미없는코드가많아짐
- 복잡한 검증 로직엔 ClassMethod가 복잡해지기쉬움
- ExceptionHandling을 어떻게할지등 커스텀하게 제어할 수 있는 있지만 메인로직(Input을받아서Inference를수행하는)에집중하기어려워짐
DataClass 활용
data:image/s3,"s3://crabby-images/16802/168023f914645a44e38b9b9ba17c017bb90d39bc" alt=""
- dataclass decorator 사용으로init_method를 작성필요x
data:image/s3,"s3://crabby-images/708d0/708d08065f96daa9ad2f6defdfa51eb7206bcee9" alt=""
- 인스턴스 생성시점에서 Validation을 수행하기쉬움
- 여전히 Validation로직들을 직접 작성해야함
- Validation 로직을 따로 작성하지 않으면,런타임에서 typechecking을 지원하지 않음
Pydantic활용
data:image/s3,"s3://crabby-images/b0f81/b0f813e26c7afe218a668abb273c394cb91687a9" alt=""
data:image/s3,"s3://crabby-images/f93bc/f93bcf9821e0084b573596a8ca18428c75517721" alt=""
- 훨씬 간결해 진코드(6라인) (vs52라인PythonClass,vs 50라인dataclass)
- 주로 쓰이는 타입들(httpurl,dburl,enum등)에대한 Validation이 만들어져 있음
- 런타임에서 TypeHint에 따라서 ValidationError발생
- CustomType에 대한 Validation도 쉽게 사용가능
data:image/s3,"s3://crabby-images/1a550/1a55093c18988a41062a5619de90130219742622" alt=""
pydantic을 활용하면 위 이미지 처럼 어디서 에러가 발생했는지 알려준다.
1.3 Config
앱을 기동하기 위해,사용자가 설정해야 하는 일련의정보:Config
Config관리-1) 코드 내 상수로 관리
가장간단하지만,보안정보(Secret)들이 코드에 그대로 노출->이슈
-> 따라서 보안정보들을 다루지 않는 경우나, 테스트 환경같이 임시환경에서만 사용하기 적합.
data:image/s3,"s3://crabby-images/af514/af514eba111b8ba7ae1bd485b599e7ca9d0f46bd" alt=""
Config관리-2) yaml등과 같은 파일로 관리
data:image/s3,"s3://crabby-images/942e5/942e5d5af4705f93f323639016ab72ff2fff8e66" alt=""
data:image/s3,"s3://crabby-images/c546f/c546f13547498f5f707324ed8aa4c982bfb91366" alt=""
별도의 파일에서 관리후,실행할때 파일을 지정해서 Config클래스에 주입하는방법
- 배포환경별로 파일을생성(dev_config.yaml,prod_config.yaml)
- 보안정보가 여전히 파일에 노출되므로,배포환경별로 파일이 노출되지 않게 관리필요
Config관리-3) 환경변수(+Pydantic.BaseSettings)로관리
환경변수에 설정 값을 저장한뒤,코드에서는 환경변수를 읽어오는방법
- Validation처럼 Pydantic은 BaseSettings를상속한 클래스에서TypeHint로 주입된 설정 데이터를 검증할 수 있음
- Field 클래스의 env인자:환경변수를해당필드로 오버라이딩
- yaml,ini파일들을 추가적으로 만들지않고,.env파일들을 환경별로 만들어두거나,실행환경에서 유연하게 오버라이딩
- 보통 환경변수는 배포할때주입
- 코드나 파일에 보안정보가 노출되지 않음
data:image/s3,"s3://crabby-images/2f52a/2f52af87fc6e0a884d37a14f147adcf7d1ce5387" alt=""
특히 FastAPI를쓴다면 Pydantic.BaseSettings를통해 Config를 관리하는것을 추천
2.FastAPI 확장기능
2.1 Lifespan function
FastAPI앱을 실행할때와 종료할때,로직을 넣고 싶은경우
data:image/s3,"s3://crabby-images/c4808/c4808281e0200f143ce698d602a82744aae77c3c" alt=""
asyncdeflifespan(app:FastAPI)정의
- yield를 기점으로
- yield 이전라인은 앱시작전
- yield 이후라인은 앱종료전
FastAPI 인스턴스 생성시 lifespan 파라미터에 위 함수를 전달
- FastAPI(lifespan=lifespan)
data:image/s3,"s3://crabby-images/58704/58704fcfea2de09df6248262e6467a60c3b1d304" alt=""
2.2 API Router
API Router'는 API 엔드포인트를 모듈화하고 효율적으로 관리하는 데 사용됩니다. 이를 통해 코드의 구조를 개선하고 유지 보수를 용이하게 할 수 있습니다.
API엔드포인트가 점점많아져서, @app.get,@app.post
와 같은 코드를 하나의 모듈에서 관리하기가 어려워질 수 있음
APIRouter는 MiniFastAPI로 여러API를 연결해서 활용
- userRouter,orderRouter2개생성
- app에연결(include_router)
- 실제활용한다면 하나의 파일에 저장하지 않고 각각 저장
(user.py,order.py
)
data:image/s3,"s3://crabby-images/3773c/3773ccf73b7189c73b218be65a6811245c39157d" alt=""
2.3 Project structure
data:image/s3,"s3://crabby-images/7f70b/7f70b20e784a02607c0e1e9782b3c52143efcbbf" alt=""
data:image/s3,"s3://crabby-images/13ea6/13ea6342ed3a98132be3c2e98b762a27f36fd881" alt=""
2.4 Error Handler
ErrorHandling
은 웹서버를 안정적으로 운영하기 위해 반드시 필요한 주제
- 서버에서 Error가 발생한경우,어떤Error가 발생했는지 알아야하고 요청한 클라이언트에 해당정보를 전달해 대응할 수 있어야함
- 서버개발자는 모니터링도구를 사용해 ErrorLog를 수집해야함
- 발생하고 있는 오류를 빠르게 수정할수있도록 예외처리를 잘 만들 필요가 있음
HTTPException
클래스는 FastAPI에서 오류 처리를 위해 사용됩니다. 이를 통해 클라이언트에게 보다 상세한 에러 메시지를 제공할 수 있습니다.
에러핸들링 없는 경우
data:image/s3,"s3://crabby-images/08a80/08a808bec5903b217c503d2c2b1357c1ba546dc2" alt=""
- item_id가5일경우
InternalServerError500Return
- 이렇게되면 클라이언트는 어떤 에러가 난 것인지 정보를 얻을수 없고,자세한 에러를 보려면 서버에 직접 접근해서 로그를 확인
- 에러핸들링을 더 잘하려면 에러메시지와 에러의이유 등을 클라이언트에 전달하도록 코드를 작성
에러핸들링 있는 경우
data:image/s3,"s3://crabby-images/49c30/49c306cb324308c4548e46bb6758bafd54552997" alt=""
2.5 Background Tasks
FastAPI의 기능중 BackgroundTasks 기능은 오래걸리는 작업들을 background에서 실행함-> 클라이언트에게 비동기로 처리하도록 하고 싶은 경우인 것임.
Background 사용하지 않는 작업 예시
data:image/s3,"s3://crabby-images/f3710/f3710782e526ff82238cbbd38cbf1f9fa5a22851" alt=""
Background 사용하는 작업 예시
Background 사용한 태스크는 바로 실행
data:image/s3,"s3://crabby-images/e3ca7/e3ca787f9a2c0fa554075f9556f4110b9582f56e" alt=""
작업 결과물을 조회할때는 Task를 어딘가에 저장해두고,GET요청을통해 Task가 완료됐는지확인
data:image/s3,"s3://crabby-images/740e5/740e538a99b34e87dfc990b8379ec832bdca570b" alt=""
3.FastAPI가 어렵다면
3.1 FastAPI가 어려운이유
프로젝트 구조 어떻게 잡아야하지?, 백엔드 프로그래밍이 처음
3.2 프로젝트구조-Cookiecutter
쿠키를 만들때 사용하는 Cookiecutter -> 많은 사람들이 프로젝트 구조에 대해서 고민하여 템플렛 공유.
https://github.com/cookiecutter/cookiecutter
Cookiecutter Data Science
https://github.com/drivendataorg/cookiecutter-data-science
data:image/s3,"s3://crabby-images/aaf3a/aaf3a33605a863e9a2aa55f832d6b80a9615ab1a" alt=""
cookitcutter-fastapi
https://github.com/arthurhenrique/cookiecutter-fastapi
data:image/s3,"s3://crabby-images/97ac6/97ac659ec99212aa286e4e93c16fc18e22c483f3" alt=""
3.3 객체지향
- 객체지향프로그래밍은 코드의 중복을 최소화해서 재사용성을 증가시킴
- 복잡한 로직이 들어갈수록 점점 빛을 발휘함
3.4 Try&Error
목표를설정하고(무엇을만들겠다)=>기능을정의=>하나씩구현
- 막연히FastAPI를학습해야지보다는, 프로젝트를FastAPI백엔드로구현!등으로 목표설정