Docker에서 Lambda까지: Python 애플리케이션을 향한 AWS 관리자의 여정
Python 스크립트에서 서버리스 AWS로: 나의 투자 포트폴리오 여정
AWS 자동화를 위한 간단한 Python 스크립트로 시작하여 점차 더 복잡한 프로젝트로 발전했습니다. 3개월 전에는 메타클래스를 거의 이해하지 못했습니다. 이제 본격적인 투자 포트폴리오 매니저를 구축했습니다.
나의 여행
수년간 Python을 사용해 AWS 자동화(악명 높은 "모든 작업 수행" 스크립트 포함)를 통해 적절한 애플리케이션을 구축할 수 있었습니다. 예전 스크립트와 Stack Overflow, Claude의 AI 지원을 활용하여 마침내 소프트웨어 개발 원칙을 파악했습니다.
앱 스크린샷(실제 투자가 아닌 시드 데이터).
투자 포트폴리오에 대한 수동 Excel 스프레드시트 업데이트에 지쳐서 프로세스를 자동화했습니다. 이 Python 애플리케이션은 포트폴리오를 관리하고, 거래를 추적하고, 배당금을 처리하고, 심지어 가격을 자동으로 업데이트합니다. 처음에는 홈 서버(Flask 백엔드, React 프론트엔드, SQLite 데이터베이스)의 Docker에서 훌륭하게 실행되었습니다.
취미가 직업이 되는 수수께끼
이것을 홈 서버에서 실행하는 것은 비효율적이었습니다. AWS 전문가로서 내 하드웨어에서 컨테이너를 관리하는 것은 직관적이지 않은 것처럼 보였습니다. 해결책은 분명해 보였습니다. 바로 ECS입니다. docker-compose
파일이 이미 있습니다:
<code>services: backend: build: ./backend container_name: investment-portfolio-backend environment: - DB_DIR=/data/db - LOG_DIR=/data/logs - DOMAIN=${DOMAIN:-localhost} volumes: - /path/to/your/data:/data networks: - app-network frontend: build: context: ./frontend args: - DOMAIN=${DOMAIN:-localhost} - USE_HTTPS=${USE_HTTPS:-false} container_name: investment-portfolio-frontend environment: - DOMAIN=${DOMAIN:-localhost} - USE_HTTPS=${USE_HTTPS:-false} ports: - "80:80" depends_on: - backend networks: - app-network</code>
그러나 AWS 설계자의 관점(및 가격 계산기)은 서버리스 접근 방식을 제안했습니다.
- 일일 가격 업데이트 및 빈번하지 않은 액세스는 연중무휴 컨테이너를 피하는 것이 좋습니다.
- 정적 프런트엔드 파일은 S3 웹사이트 호스팅에 이상적이었습니다.
- API 게이트웨이와 Lambda가 API 호출을 처리합니다.
- Aurora Serverless는 관계형 데이터에 적합했습니다.
- DynamoDB는 가격 내역을 저장할 수 있습니다(이 단계에는 도달하지 못했지만).
이로 인해 저는 서버리스 토끼굴에 빠지게 되었습니다. 이전에 서버리스 경험이 있었습니다. 아내와 함께 KNMI 데이터를 사용하고 공예 프로젝트를 위한 색상으로 구분된 테이블을 생성하는 온도 추적 프로젝트였습니다.
<code>| Date | Min.Temp | Min.Kleur | Max.Temp | Max.Kleur | ---------------------------------------------------------------- | 2023-03-01 | -4.1°C | darkblue | 7.1°C | lightblue | | 2023-03-02 | 1.3°C | blue | 6.8°C | lightblue | ...</code>
이 프로젝트는 날짜 매개변수를 사용하여 로컬로 또는 Lambda/API 게이트웨이를 통해 실행되었습니다. SQLAlchemy, 백그라운드 작업 및 복잡한 관계를 사용하여 이를 전체 Flask 애플리케이션으로 확장하는 것은 어려운 일이었습니다.
서버리스의 매력
컨테이너화된 애플리케이션은 잘 작동했지만 서버리스 서비스의 매력은 강했습니다. 자동 확장 기능과 컨테이너 관리 제거 기능이 매력적이었습니다.
그래서 저는 서버리스 환경에 맞게 애플리케이션을 다시 설계했습니다. 원래 프로젝트에는 두 달이 걸렸습니다. 이건 쉬울 것 같아요... 아니면 그렇게 생각했어요.
데이터베이스 결정
Lambda에 대한 SQLite의 제한으로 인해 SQLAlchemy 지식과의 호환성을 유지하면서 PostgreSQL Aurora Serverless를 고려하게 되었습니다. 이중 핸들러를 만들었습니다:
<code>services: backend: build: ./backend container_name: investment-portfolio-backend environment: - DB_DIR=/data/db - LOG_DIR=/data/logs - DOMAIN=${DOMAIN:-localhost} volumes: - /path/to/your/data:/data networks: - app-network frontend: build: context: ./frontend args: - DOMAIN=${DOMAIN:-localhost} - USE_HTTPS=${USE_HTTPS:-false} container_name: investment-portfolio-frontend environment: - DOMAIN=${DOMAIN:-localhost} - USE_HTTPS=${USE_HTTPS:-false} ports: - "80:80" depends_on: - backend networks: - app-network</code>
람다 학습 곡선
Flask 애플리케이션을 Lambda 함수로 변환하는 작업은 예상보다 더 복잡했습니다. 나의 초기 시도는 서툴렀습니다:
<code>| Date | Min.Temp | Min.Kleur | Max.Temp | Max.Kleur | ---------------------------------------------------------------- | 2023-03-01 | -4.1°C | darkblue | 7.1°C | lightblue | | 2023-03-02 | 1.3°C | blue | 6.8°C | lightblue | ...</code>
유지관리성을 향상시키기 위해 데코레이터를 만들었습니다.
<code>@contextmanager def db_session(): # ... (code for environment-aware database session management) ...</code>
향상된 Lambda 함수 구조:
<code># ... (initial, inefficient Lambda handler code) ...</code>
그러나 이로 인해 원래 Flask 경로가 중단되었습니다. 새로운 데코레이터로 이중 기능이 가능해졌습니다:
<code>def lambda_response(func): # ... (decorator for cleaner Lambda responses) ...</code>
일관적인 응답을 보장하는 지원 기능:
<code>@lambda_response def get_portfolios(event, context): # ... (simplified Lambda function) ...</code>
이를 통해 Flask와 Lambda 모두에 동일한 경로를 사용할 수 있습니다.
<code>def dual_handler(route_path, methods=None): # ... (decorator for both Flask routes and Lambda handlers) ...</code>
프런트엔드 단순성
프런트엔드는 간단했습니다. S3 정적 웹 사이트 호스팅 및 CloudFront는 간편한 배포를 제공했습니다. 간단한 스크립트가 프런트엔드를 S3에 업로드하고 CloudFront 캐시를 무효화했습니다.
<code>def create_lambda_response(flask_response): # ... (function to convert Flask response to Lambda response format) ... def create_flask_request(event): # ... (function to convert Lambda event to Flask request) ...</code>
결과
몇 주 동안 작업한 후 내 애플리케이션은 서버리스 상태였습니다. 보안 문제로 인해 온라인에 보관하지는 않지만 귀중한 교훈을 얻었습니다.
- Python의 기능은 스크립팅 그 이상입니다.
- AWS 프리 티어는 개발에 매우 중요합니다.
- CloudWatch Logs는 디버깅에 필수적입니다.
- "올바른" 방식이 항상 AWS 방식은 아닙니다.
이것을 반복할까요? 아마도 그렇지 않을 것입니다. 하지만 그 여정은 보람찼고 Python과 듀얼 스택 개발에 대해 가르쳐주었습니다. 이제 내 투자 포트폴리오 관리자가 내 개인 네트워크에서 안전하게 실행됩니다.
위 내용은 Docker에서 Lambda까지: Python 애플리케이션을 향한 AWS 관리자의 여정의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

Video Face Swap
완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)

Python은 데이터 과학, 웹 개발 및 자동화 작업에 적합한 반면 C는 시스템 프로그래밍, 게임 개발 및 임베디드 시스템에 적합합니다. Python은 단순성과 강력한 생태계로 유명하며 C는 고성능 및 기본 제어 기능으로 유명합니다.

Python은 게임 및 GUI 개발에서 탁월합니다. 1) 게임 개발은 Pygame을 사용하여 드로잉, 오디오 및 기타 기능을 제공하며 2D 게임을 만드는 데 적합합니다. 2) GUI 개발은 Tkinter 또는 PYQT를 선택할 수 있습니다. Tkinter는 간단하고 사용하기 쉽고 PYQT는 풍부한 기능을 가지고 있으며 전문 개발에 적합합니다.

2 시간 이내에 Python의 기본 프로그래밍 개념과 기술을 배울 수 있습니다. 1. 변수 및 데이터 유형을 배우기, 2. 마스터 제어 흐름 (조건부 명세서 및 루프), 3. 기능의 정의 및 사용을 이해하십시오. 4. 간단한 예제 및 코드 스 니펫을 통해 Python 프로그래밍을 신속하게 시작하십시오.

2 시간 이내에 파이썬의 기본 사항을 배울 수 있습니다. 1. 변수 및 데이터 유형을 배우십시오. 이를 통해 간단한 파이썬 프로그램 작성을 시작하는 데 도움이됩니다.

Python은 배우고 사용하기 쉽고 C는 더 강력하지만 복잡합니다. 1. Python Syntax는 간결하며 초보자에게 적합합니다. 동적 타이핑 및 자동 메모리 관리를 사용하면 사용하기 쉽지만 런타임 오류가 발생할 수 있습니다. 2.C는 고성능 응용 프로그램에 적합한 저수준 제어 및 고급 기능을 제공하지만 학습 임계 값이 높고 수동 메모리 및 유형 안전 관리가 필요합니다.

제한된 시간에 Python 학습 효율을 극대화하려면 Python의 DateTime, Time 및 Schedule 모듈을 사용할 수 있습니다. 1. DateTime 모듈은 학습 시간을 기록하고 계획하는 데 사용됩니다. 2. 시간 모듈은 학습과 휴식 시간을 설정하는 데 도움이됩니다. 3. 일정 모듈은 주간 학습 작업을 자동으로 배열합니다.

Python은 웹 개발, 데이터 과학, 기계 학습, 자동화 및 스크립팅 분야에서 널리 사용됩니다. 1) 웹 개발에서 Django 및 Flask 프레임 워크는 개발 프로세스를 단순화합니다. 2) 데이터 과학 및 기계 학습 분야에서 Numpy, Pandas, Scikit-Learn 및 Tensorflow 라이브러리는 강력한 지원을 제공합니다. 3) 자동화 및 스크립팅 측면에서 Python은 자동화 된 테스트 및 시스템 관리와 같은 작업에 적합합니다.

파이썬은 자동화, 스크립팅 및 작업 관리가 탁월합니다. 1) 자동화 : 파일 백업은 OS 및 Shutil과 같은 표준 라이브러리를 통해 실현됩니다. 2) 스크립트 쓰기 : PSUTIL 라이브러리를 사용하여 시스템 리소스를 모니터링합니다. 3) 작업 관리 : 일정 라이브러리를 사용하여 작업을 예약하십시오. Python의 사용 편의성과 풍부한 라이브러리 지원으로 인해 이러한 영역에서 선호하는 도구가됩니다.
