


Ich habe kürzlich zwei Stunden damit verbracht, eine einfache LlamaIndex-App für die Ausführung auf AWS Lambda zu entwickeln. Während die Funktion selbst nur aus wenigen Zeilen Python-Code besteht (wie unten gezeigt), kann die Verwaltung von Abhängigkeiten und die Bereitstellung schwierig sein.
import json from llama_index.llms.openai import OpenAI llm=OpenAI(model="gpt-4o-mini") def lambda_handler(event, context): response = llm.complete("What public transportation might be available in a city?") return { 'statusCode': 200, 'body': str(response), }
Hier sind einige wichtige Tipps, die mir geholfen haben:
Installieren Sie zunächst Pakete für die richtige Plattform. Es ist wichtig, alle Pakete für die Zielplattform „manylinux2014_x86_64“ zu installieren. Andernfalls sind bestimmte Pakete möglicherweise nicht mit der AWS Lambda-Laufzeitumgebung kompatibel. Um die Kompatibilität sicherzustellen, installieren Sie Abhängigkeiten mit dem folgenden Befehl:
pip install -r requirements.txt --platform manylinux2014_x86_64 --target ./deps --only-binary=:all:
Zweitens hat Lambda ein Limit von 250 MB für die Gesamtgröße des Codepakets, was schnell zu einem Problem werden kann, wenn Sie LlamaIndex oder andere große Abhängigkeiten verwenden. Wenn Ihr Paket diese Grenze überschreitet, überprüfen Sie die größten Dateien in Ihrem Abhängigkeitsordner:
du -h -d 2 | sort -hr | head -n20
In meinem Fall stellte ich fest, dass das Verzeichnis pandas/tests etwa 35 MB Speicherplatz beanspruchte, was für meine Funktion unnötig war, also habe ich es entfernt, um die Paketgröße wieder innerhalb des Grenzwerts zu halten.
rm -r deps/pandas/tests
Dann alles komprimieren und über S3 hochladen. Nachdem Sie unnötige Dateien entfernt haben, erstellen Sie ein ZIP-Archiv, das sowohl Ihren Code als auch die Abhängigkeiten enthält. Da die Webkonsole von Lambda ein Upload-Limit von 50 MB hat, müssen Sie größere ZIP-Dateien in einen S3-Bucket hochladen und den S3-URI verwenden, um die Funktion bereitzustellen.
zip -r test_lambda.zip data/ lambda_function.py cd deps/ zip -r ../test_lambda.zip .
Passen Sie abschließend Ihre Lambda-Einstellungen vor der Bereitstellung an. Standardmäßig werden Lambda-Funktionen nur 128 MB Speicher und ein Timeout von 3 Sekunden zugewiesen, was für viele KI-Anwendungen mit großen Abhängigkeiten und dem Aufruf von LLMs nicht ausreicht. Ich würde den Speicher auf 512 MB erhöhen und das Timeout auf 30 Sekunden verlängern. Vergessen Sie außerdem nicht, wichtige Umgebungsvariablen wie Ihren OpenAI-API-Schlüssel festzulegen.
Ich habe einige Versuche gebraucht, um herauszufinden, wie man Pakete richtig installiert und alles für Lambda bündelt. AWS Lambda ist für einfache Skripte benutzerfreundlich, aber sobald Sie größere Abhängigkeiten hinzufügen, werden die Dinge komplizierter.
Hier ist die letzte Schrittfolge:
# Install dependencies pip install -r requirements.txt --platform manylinux2014_x86_64 --target ./deps --only-binary=:all: # Create a zip file for code and data zip -r test_lambda.zip data/ lambda_function.py # Include dependencies in the zip file, while removing large unused files cd deps/ rm -r pandas/tests zip -r ../test_lambda.zip .
P.s.: Ich habe auch versucht, eine ähnliche Funktion in der DBOS Cloud bereitzustellen, und es war nur ein einziger Befehl erforderlich:
dbos-cloud app deploy
In DBOS wurde die Abhängigkeitsverwaltung automatisch über die Datei „requirements.txt“ abgewickelt und Umgebungsvariablen wurden in dbos-config.yaml festgelegt. Ich bin vielleicht voreingenommen, aber mir gefällt die Einfachheit des Bereitstellungsprozesses von DBOS Cloud.
Das obige ist der detaillierte Inhalt vonSo stellen Sie eine KI-App (mit großen Deps) in AWS Lambda bereit. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Ist es genug, um Python für zwei Stunden am Tag zu lernen? Es hängt von Ihren Zielen und Lernmethoden ab. 1) Entwickeln Sie einen klaren Lernplan, 2) Wählen Sie geeignete Lernressourcen und -methoden aus, 3) praktizieren und prüfen und konsolidieren Sie praktische Praxis und Überprüfung und konsolidieren Sie und Sie können die Grundkenntnisse und die erweiterten Funktionen von Python während dieser Zeit nach und nach beherrschen.

Zu den wichtigsten Anwendungen von Python in der Webentwicklung gehören die Verwendung von Django- und Flask -Frameworks, API -Entwicklung, Datenanalyse und Visualisierung, maschinelles Lernen und KI sowie Leistungsoptimierung. 1. Django und Flask Framework: Django eignet sich für die schnelle Entwicklung komplexer Anwendungen, und Flask eignet sich für kleine oder hochmobile Projekte. 2. API -Entwicklung: Verwenden Sie Flask oder Djangorestframework, um RESTFUFFUPI zu erstellen. 3. Datenanalyse und Visualisierung: Verwenden Sie Python, um Daten zu verarbeiten und über die Webschnittstelle anzuzeigen. 4. Maschinelles Lernen und KI: Python wird verwendet, um intelligente Webanwendungen zu erstellen. 5. Leistungsoptimierung: optimiert durch asynchrones Programmieren, Caching und Code

Python ist in der Entwicklungseffizienz besser als C, aber C ist in der Ausführungsleistung höher. 1. Pythons prägnante Syntax und reiche Bibliotheken verbessern die Entwicklungseffizienz. 2. Die Kompilierungsmerkmale von Compilation und die Hardwarekontrolle verbessern die Ausführungsleistung. Bei einer Auswahl müssen Sie die Entwicklungsgeschwindigkeit und die Ausführungseffizienz basierend auf den Projektanforderungen abwägen.

Zu den realen Anwendungen von Python gehören Datenanalysen, Webentwicklung, künstliche Intelligenz und Automatisierung. 1) In der Datenanalyse verwendet Python Pandas und Matplotlib, um Daten zu verarbeiten und zu visualisieren. 2) In der Webentwicklung vereinfachen Django und Flask Frameworks die Erstellung von Webanwendungen. 3) Auf dem Gebiet der künstlichen Intelligenz werden Tensorflow und Pytorch verwendet, um Modelle zu bauen und zu trainieren. 4) In Bezug auf die Automatisierung können Python -Skripte für Aufgaben wie das Kopieren von Dateien verwendet werden.

Python wird häufig in den Bereichen Data Science, Web Development und Automation Scripting verwendet. 1) In der Datenwissenschaft vereinfacht Python die Datenverarbeitung und -analyse durch Bibliotheken wie Numpy und Pandas. 2) In der Webentwicklung ermöglichen die Django- und Flask -Frameworks Entwicklern, Anwendungen schnell zu erstellen. 3) In automatisierten Skripten machen Pythons Einfachheit und Standardbibliothek es ideal.

Die Flexibilität von Python spiegelt sich in Multi-Paradigm-Unterstützung und dynamischen Typsystemen wider, während eine einfache Syntax und eine reichhaltige Standardbibliothek stammt. 1. Flexibilität: Unterstützt objektorientierte, funktionale und prozedurale Programmierung und dynamische Typsysteme verbessern die Entwicklungseffizienz. 2. Benutzerfreundlichkeit: Die Grammatik liegt nahe an der natürlichen Sprache, die Standardbibliothek deckt eine breite Palette von Funktionen ab und vereinfacht den Entwicklungsprozess.

Python ist für seine Einfachheit und Kraft sehr beliebt, geeignet für alle Anforderungen von Anfängern bis hin zu fortgeschrittenen Entwicklern. Seine Vielseitigkeit spiegelt sich in: 1) leicht zu erlernen und benutzten, einfachen Syntax; 2) Reiche Bibliotheken und Frameworks wie Numpy, Pandas usw.; 3) plattformübergreifende Unterstützung, die auf einer Vielzahl von Betriebssystemen betrieben werden kann; 4) Geeignet für Skript- und Automatisierungsaufgaben zur Verbesserung der Arbeitseffizienz.

Ja, lernen Sie Python in zwei Stunden am Tag. 1. Entwickeln Sie einen angemessenen Studienplan, 2. Wählen Sie die richtigen Lernressourcen aus, 3. Konsolidieren Sie das durch die Praxis erlernte Wissen. Diese Schritte können Ihnen helfen, Python in kurzer Zeit zu meistern.


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

AI Hentai Generator
Erstellen Sie kostenlos Ai Hentai.

Heißer Artikel

Heiße Werkzeuge

MinGW – Minimalistisches GNU für Windows
Dieses Projekt wird derzeit auf osdn.net/projects/mingw migriert. Sie können uns dort weiterhin folgen. MinGW: Eine native Windows-Portierung der GNU Compiler Collection (GCC), frei verteilbare Importbibliotheken und Header-Dateien zum Erstellen nativer Windows-Anwendungen, einschließlich Erweiterungen der MSVC-Laufzeit zur Unterstützung der C99-Funktionalität. Die gesamte MinGW-Software kann auf 64-Bit-Windows-Plattformen ausgeführt werden.

Dreamweaver CS6
Visuelle Webentwicklungstools

WebStorm-Mac-Version
Nützliche JavaScript-Entwicklungstools

ZendStudio 13.5.1 Mac
Leistungsstarke integrierte PHP-Entwicklungsumgebung

Notepad++7.3.1
Einfach zu bedienender und kostenloser Code-Editor