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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

ArraysareBetterForElement-WiseOperationsDuetOfasterAcccessandoptimizedimmentations.1) ArraysHaveCecontIguousMemoryFordirectAccess, 향상

Numpy에서 전체 배열의 수학적 작업은 벡터화 된 작업을 통해 효율적으로 구현 될 수 있습니다. 1) 추가 (ARR 2)와 같은 간단한 연산자를 사용하여 배열에서 작업을 수행하십시오. 2) Numpy는 기본 C 언어 라이브러리를 사용하여 컴퓨팅 속도를 향상시킵니다. 3) 곱셈, 분할 및 지수와 같은 복잡한 작업을 수행 할 수 있습니다. 4) 배열 모양이 호환되도록 방송 작업에주의를 기울이십시오. 5) NP.Sum ()과 같은 Numpy 함수를 사용하면 성능을 크게 향상시킬 수 있습니다.

Python에는 요소를 목록에 삽입하는 두 가지 주요 방법이 있습니다. 1) 삽입 (인덱스, 값) 메소드를 사용하여 지정된 인덱스에 요소를 삽입 할 수 있지만 큰 목록의 시작 부분에서 삽입하는 것은 비효율적입니다. 2) Append (value) 메소드를 사용하여 목록 끝에 요소를 추가하여 매우 효율적입니다. 대형 목록의 경우 Append ()를 사용하거나 Deque 또는 Numpy Array를 사용하여 성능을 최적화하는 것이 좋습니다.

TomakeApythonscriptexecutableonBothunixandwindows : 1) addashebangline (#!/usr/bin/envpython3) andusechmod xtomakeitexecutableonix.2) onwindows, inristpythonisinstalledandassociatedwith.pybattfile (run.bat) torunthescrest.

"CommandNotFound"오류가 발생하면 다음 사항을 확인해야합니다. 1. 스크립트가 존재하고 경로가 올바른지 확인하십시오. 2. 파일 권한을 확인하고 CHMOD를 사용하여 필요한 경우 실행 권한을 추가하십시오. 3. 스크립트 인터프리터가 설치되었는지 확인하십시오. 4. 스크립트 시작시 셰 잔 라인이 올바른지 확인하십시오. 그렇게하면 스크립트 작업 문제를 효과적으로 해결하고 코딩 프로세스가 원활하게 보장 할 수 있습니다.

ArraysareGenerallyMorememory- 효율적 인 thanlistsortingnumericaldataduetotheirfixed-sizenatureanddirectmemoryAccess.1) ArraysStoreElementsInacontiguousBlock, retoneverHead-fompointerSormetAdata.2) 목록, 종종 implementededymamamicArraysorlinkedStruct

ToconvertapyThonlisttoAnarray, usethearraymodule : 1) importThearrayModule, 2) CreateAlist, 3) Usearray (typecode, list) toconvertit, thetypecodelike'i'forintegers

Python 목록은 다양한 유형의 데이터를 저장할 수 있습니다. 예제 목록에는 정수, 문자열, 부동 소수점 번호, 부울, 중첩 목록 및 사전이 포함되어 있습니다. 목록 유연성은 데이터 처리 및 프로토 타이핑에서 가치가 있지만 코드의 가독성과 유지 관리를 보장하기 위해주의해서 사용해야합니다.


핫 AI 도구

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

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

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

Clothoff.io
AI 옷 제거제

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

인기 기사

뜨거운 도구

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

DVWA
DVWA(Damn Vulnerable Web App)는 매우 취약한 PHP/MySQL 웹 애플리케이션입니다. 주요 목표는 보안 전문가가 법적 환경에서 자신의 기술과 도구를 테스트하고, 웹 개발자가 웹 응용 프로그램 보안 프로세스를 더 잘 이해할 수 있도록 돕고, 교사/학생이 교실 환경 웹 응용 프로그램에서 가르치고 배울 수 있도록 돕는 것입니다. 보안. DVWA의 목표는 다양한 난이도의 간단하고 간단한 인터페이스를 통해 가장 일반적인 웹 취약점 중 일부를 연습하는 것입니다. 이 소프트웨어는

WebStorm Mac 버전
유용한 JavaScript 개발 도구

SublimeText3 영어 버전
권장 사항: Win 버전, 코드 프롬프트 지원!

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