


Von Docker zu Lambda: Die Reise eines AWS-Administrators in Python-Anwendungen
Von Python-Skripten zu serverlosem AWS: Meine Investment-Portfolio-Reise
Ich begann mit einfachen Python-Skripten für die AWS-Automatisierung und entwickelte mich nach und nach zu einem komplexeren Projekt. Vor drei Monaten verstand ich Metaklassen kaum; Jetzt habe ich einen vollwertigen Anlageportfoliomanager aufgebaut.
Meine Reise
Die jahrelange Verwendung von Python für die AWS-Automatisierung (einschließlich des berüchtigten „Alles-macht“-Skripts) hat mich dazu gebracht, eine richtige Anwendung zu erstellen. Durch die Nutzung meiner früheren Skripte, Stack Overflow und Claudes KI-Unterstützung habe ich endlich die Prinzipien der Softwareentwicklung verstanden.
App-Screenshot (Startdaten, keine tatsächlichen Investitionen).
Ich hatte keine Lust mehr auf manuelle Excel-Tabellenaktualisierungen für meine Anlageportfolios und habe den Prozess automatisiert. Diese Python-Anwendung verwaltet Portfolios, verfolgt Transaktionen, verarbeitet Dividenden und aktualisiert sogar Preise automatisch. Anfangs lief es wunderbar in Docker auf meinem Heimserver (Flask-Backend, React-Frontend, SQLite-Datenbank).
Das Rätsel „Hobby wird zum Job“
Die Ausführung auf meinem Heimserver fühlte sich ineffizient an. Als AWS-Experte erschien mir die Verwaltung von Containern auf meiner Hardware kontraintuitiv. Die Lösung schien offensichtlich: ECS. Ich hatte bereits die docker-compose
-Datei:
<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>
Die Sichtweise eines AWS-Architekten (und der Preisrechner) deuteten jedoch auf einen serverlosen Ansatz hin:
- Tägliche Preisaktualisierungen und seltener Zugriff empfehlen, 24/7-Container zu vermeiden.
- Statische Frontend-Dateien waren ideal für das S3-Website-Hosting.
- API Gateway und Lambda würden API-Aufrufe verarbeiten.
- Aurora Serverless eignete sich für die relationalen Daten.
- DynamoDB konnte den Preisverlauf speichern (obwohl ich dieses Stadium noch nicht erreicht habe).
Das führte mich in das serverlose Kaninchenloch. Ich hatte bereits Erfahrung ohne Server – ein Temperaturverfolgungsprojekt mit meiner Frau, bei dem ich KNMI-Daten verwendete und eine farbcodierte Tabelle für ein Bastelprojekt erstellte.
<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>
Dieses Projekt lief lokal oder über Lambda/API Gateway unter Verwendung von Datumsparametern. Die Skalierung auf eine vollständige Flask-Anwendung mit SQLAlchemy, Hintergrundjobs und komplexen Beziehungen erwies sich als Herausforderung.
Der serverlose Reiz
Meine Containeranwendung funktionierte gut, aber die Anziehungskraft serverloser Dienste war groß. Das Potenzial für automatische Skalierung und die Eliminierung der Containerverwaltung waren verlockend.
Also habe ich meine Anwendung für eine serverlose Umgebung umgestaltet. Das ursprüngliche Projekt dauerte zwei Monate; Das wäre ein Kinderspiel... zumindest dachte ich das.
Die Datenbankentscheidung
Die Einschränkungen von SQLite mit Lambda veranlassten mich, PostgreSQL Aurora Serverless in Betracht zu ziehen, um die Kompatibilität mit meinen SQLAlchemy-Kenntnissen aufrechtzuerhalten. Ich habe einen Dual-Handler erstellt:
<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>
Die Lambda-Lernkurve
Die Konvertierung meiner Flask-Anwendung in Lambda-Funktionen war komplexer als erwartet. Mein erster Versuch war ungeschickt:
<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>
Um die Wartbarkeit zu verbessern, habe ich einen Dekorator erstellt:
<code>@contextmanager def db_session(): # ... (code for environment-aware database session management) ...</code>
Diese verbesserte Lambda-Funktionsstruktur:
<code># ... (initial, inefficient Lambda handler code) ...</code>
Dadurch wurden jedoch die ursprünglichen Flask-Routen unterbrochen. Ein neuer Dekorator ermöglichte eine doppelte Funktionalität:
<code>def lambda_response(func): # ... (decorator for cleaner Lambda responses) ...</code>
Unterstützende Funktionen stellten konsistente Antworten sicher:
<code>@lambda_response def get_portfolios(event, context): # ... (simplified Lambda function) ...</code>
Dies ermöglichte die Verwendung derselben Routen für Flask und Lambda:
<code>def dual_handler(route_path, methods=None): # ... (decorator for both Flask routes and Lambda handlers) ...</code>
Frontend-Einfachheit
Das Frontend war unkompliziert. Das statische S3-Website-Hosting und CloudFront sorgten für eine einfache Bereitstellung. Ein einfaches Skript hat das Frontend auf S3 hochgeladen und den CloudFront-Cache ungültig gemacht:
<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>
Das Ergebnis
Nach wochenlanger Arbeit war meine Anwendung serverlos. Obwohl ich es aus Sicherheitsgründen nicht online halte, habe ich wertvolle Lektionen gelernt:
- Pythons Fähigkeiten gehen über die Skripterstellung hinaus.
- Das kostenlose AWS-Kontingent ist für die Entwicklung von unschätzbarem Wert.
- CloudWatch-Protokolle sind für das Debuggen unerlässlich.
- Der „richtige“ Weg ist nicht immer der AWS-Weg.
Würde ich das wiederholen? Wahrscheinlich nicht. Aber die Reise hat sich gelohnt und mir etwas über Python und die Dual-Stack-Entwicklung beigebracht. Mein Anlageportfoliomanager läuft jetzt sicher in meinem privaten Netzwerk.
Das obige ist der detaillierte Inhalt vonVon Docker zu Lambda: Die Reise eines AWS-Administrators in Python-Anwendungen. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Es gibt viele Methoden, um zwei Listen in Python zu verbinden: 1. Verwenden Sie Operatoren, die in großen Listen einfach, aber ineffizient sind; 2. Verwenden Sie die Erweiterungsmethode, die effizient ist, die ursprüngliche Liste jedoch ändert. 3.. Verwenden Sie den operator =, der sowohl effizient als auch lesbar ist; 4. Verwenden Sie die Funktion iterertools.chain, die Speichereffizient ist, aber zusätzlichen Import erfordert. 5. Verwenden Sie List Parsing, die elegant ist, aber zu komplex sein kann. Die Auswahlmethode sollte auf dem Codekontext und den Anforderungen basieren.

Es gibt viele Möglichkeiten, Python -Listen zusammenzuführen: 1. Verwenden von Operatoren, die einfach, aber nicht für große Listen effizient sind; 2. Verwenden Sie die Erweiterungsmethode, die effizient ist, die ursprüngliche Liste jedoch ändert. 3. Verwenden Sie iTertools.chain, das für große Datensätze geeignet ist. 4. Verwenden Sie * Operator, fusionieren Sie kleine bis mittelgroße Listen in einer Codezeile. 5. Verwenden Sie Numpy.concatenate, das für große Datensätze und Szenarien mit hohen Leistungsanforderungen geeignet ist. 6. Verwenden Sie die Append -Methode, die für kleine Listen geeignet ist, aber ineffizient ist. Bei der Auswahl einer Methode müssen Sie die Listengröße und die Anwendungsszenarien berücksichtigen.

CompiledLanguageOfferSpeedandSecurity, während interpretedLanguagesProvideaseofuseAnDportabilität.1) kompiledlanguageslikec areFasterandSecurebuthavelongerDevelopmentCyclesandplatformDependency.2) InterpretedLanguages -pythonareaToReAndoreAndorePortab

In Python wird eine für die Schleife verwendet, um iterable Objekte zu durchqueren, und eine WHHE -Schleife wird verwendet, um Operationen wiederholt durchzuführen, wenn die Bedingung erfüllt ist. 1) Beispiel für Schleifen: Überqueren Sie die Liste und drucken Sie die Elemente. 2) Während des Schleifens Beispiel: Erraten Sie das Zahlenspiel, bis Sie es richtig erraten. Mastering -Zyklusprinzipien und Optimierungstechniken können die Code -Effizienz und -zuverlässigkeit verbessern.

Um eine Liste in eine Zeichenfolge zu verkettet, ist die Verwendung der join () -Methode in Python die beste Wahl. 1) Verwenden Sie die monjoy () -Methode, um die Listelemente in eine Zeichenfolge wie "" .Join (my_list) zu verkettet. 2) Für eine Liste, die Zahlen enthält, konvertieren Sie die Karte (STR, Zahlen) in eine Zeichenfolge, bevor Sie verkettet werden. 3) Sie können Generatorausdrücke für komplexe Formatierung verwenden, wie z. 4) Verwenden Sie bei der Verarbeitung von Mischdatentypen MAP (STR, MIXED_LIST), um sicherzustellen, dass alle Elemente in Zeichenfolgen konvertiert werden können. 5) Verwenden Sie für große Listen '' .Join (large_li

Pythonusesahybridapproach, kombinierte CompilationTobyteCodeAnDinterpretation.1) codiscompiledtoplatform-unintenpendentBytecode.2) BytecodeIsinterpretedBythepythonvirtualMachine, EnhancingEfficiency und Portablabilität.

Die Keedifferzences -zwischen Pythons "für" und "während" Loopsare: 1) "für" LoopsareideAlForiteratingOvercesorknownowniterations, während 2) "LoopsarebetterForContiningUtilAconditionismethoutnredefineditInations.un

In Python können Sie Listen anschließen und doppelte Elemente mit einer Vielzahl von Methoden verwalten: 1) Verwenden von Operatoren oder erweitert (), um alle doppelten Elemente beizubehalten; 2) Konvertieren in Sets und kehren Sie dann zu Listen zurück, um alle doppelten Elemente zu entfernen. Die ursprüngliche Bestellung geht jedoch verloren. 3) Verwenden Sie Schleifen oder listen Sie Verständnisse auf, um Sätze zu kombinieren, um doppelte Elemente zu entfernen und die ursprüngliche Reihenfolge zu verwalten.


Heiße KI -Werkzeuge

Undresser.AI Undress
KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover
Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool
Ausziehbilder kostenlos

Clothoff.io
KI-Kleiderentferner

Video Face Swap
Tauschen Sie Gesichter in jedem Video mühelos mit unserem völlig kostenlosen KI-Gesichtstausch-Tool aus!

Heißer Artikel

Heiße Werkzeuge

Sicherer Prüfungsbrowser
Safe Exam Browser ist eine sichere Browserumgebung für die sichere Teilnahme an Online-Prüfungen. Diese Software verwandelt jeden Computer in einen sicheren Arbeitsplatz. Es kontrolliert den Zugriff auf alle Dienstprogramme und verhindert, dass Schüler nicht autorisierte Ressourcen nutzen.

PHPStorm Mac-Version
Das neueste (2018.2.1) professionelle, integrierte PHP-Entwicklungstool

SecLists
SecLists ist der ultimative Begleiter für Sicherheitstester. Dabei handelt es sich um eine Sammlung verschiedener Arten von Listen, die häufig bei Sicherheitsbewertungen verwendet werden, an einem Ort. SecLists trägt dazu bei, Sicherheitstests effizienter und produktiver zu gestalten, indem es bequem alle Listen bereitstellt, die ein Sicherheitstester benötigen könnte. Zu den Listentypen gehören Benutzernamen, Passwörter, URLs, Fuzzing-Payloads, Muster für vertrauliche Daten, Web-Shells und mehr. Der Tester kann dieses Repository einfach auf einen neuen Testcomputer übertragen und hat dann Zugriff auf alle Arten von Listen, die er benötigt.

Senden Sie Studio 13.0.1
Leistungsstarke integrierte PHP-Entwicklungsumgebung

SublimeText3 Englische Version
Empfohlen: Win-Version, unterstützt Code-Eingabeaufforderungen!
