Heim > Backend-Entwicklung > Python-Tutorial > GCP veröffentlicht Python-Paket in der Produktion

GCP veröffentlicht Python-Paket in der Produktion

Mary-Kate Olsen
Freigeben: 2024-11-20 12:29:13
Original
604 Leute haben es durchsucht

GCP publish python package in production

GCP: Python-Paket in der Produktion veröffentlichen

In dieser Anleitung wird erläutert, wie Sie mit Google Artifact Registry gemeinsam genutzten Python-Code als Paket verwalten. Dieser Ansatz eliminiert die Codeduplizierung zwischen Ihren Cloud-Funktionen und dem Server.


Schritt 1: Strukturieren Sie Ihren gemeinsamen Code

Erstellen Sie ein neues Python-Paket für Ihre gemeinsame Logik (z. B. common_logic).

common_logic/
├── setup.py
├── common_logic/
│   ├── __init__.py
Nach dem Login kopieren
Nach dem Login kopieren

Schritt 2: Erstellen Sie setup.py

Definieren Sie Ihre Paketkonfiguration in einer setup.py-Datei:

common_logic/
├── setup.py
├── common_logic/
│   ├── __init__.py
Nach dem Login kopieren
Nach dem Login kopieren

Schritt 3: Richten Sie Google Artifact Registry ein

  1. Aktivieren Sie die Artifact Registry API:
from setuptools import setup, find_packages

setup(
    name="common_logic",
    version="0.1.0",
    packages=find_packages(),
    install_requires=[
        "pandas>=1.3.0",
    ],
    author="Your Name",
    author_email="your.email@example.com",
    description="Common logic for app",
)
Nach dem Login kopieren
  1. Erstellen Sie ein Python-Repository:
   gcloud services enable artifactregistry.googleapis.com
Nach dem Login kopieren

Schritt 4: Authentifizierung konfigurieren

  1. Erstellen Sie ein Dienstkonto:
   gcloud artifacts repositories create python-packages \
       --repository-format=python \
       --location=us-central1 \
       --description="Python packages repository"
Nach dem Login kopieren
  1. Erteilen Sie die erforderlichen Berechtigungen:
   gcloud iam service-accounts create artifact-publisher \
       --description="Service account for publishing to Artifact Registry"
Nach dem Login kopieren
  1. Erstellen Sie einen Schlüssel und laden Sie ihn herunter:
   gcloud artifacts repositories add-iam-policy-binding python-packages \
       --location=us-central1 \
       --member="serviceAccount:artifact-publisher@${PROJECT_ID}.iam.gserviceaccount.com" \
       --role="roles/artifactregistry.writer"
Nach dem Login kopieren

Schritt 5: Paket erstellen und hochladen

  1. Build-Tools installieren:
   gcloud iam service-accounts keys create key.json \
       --iam-account=artifact-publisher@${PROJECT_ID}.iam.gserviceaccount.com
Nach dem Login kopieren
  1. Erstellen Sie das Paket:
   pip install build twine
Nach dem Login kopieren
  1. Binden für Artifact Registry konfigurieren:
   python -m build
Nach dem Login kopieren
  1. Laden Sie das Paket hoch:
   cat > ~/.pypirc << EOL
   [distutils]
   index-servers = common-logic-repo
   [common-logic-repo]
   repository: https://us-central1-python.pkg.dev/${PROJECT_ID}/python-packages/
   username: _json_key_base64
   password: $(base64 -w0 key.json)
   EOL
Nach dem Login kopieren

Schritt 6: Verwenden Sie das Paket

In Cloud-Funktionen

  1. Erstellen Sie eine „requirements.txt“-Datei:
   twine upload --repository common-logic-repo dist/*
Nach dem Login kopieren
  1. Verwenden Sie das Paket in Ihrer Cloud-Funktion:
   --index-url https://pypi.org/simple
   --extra-index-url https://oauth2accesstoken:${ARTIFACT_REGISTRY_TOKEN}@us-central1-python.pkg.dev/${PROJECT_ID}/python-packages/simple/
   common-logic==0.1.0
Nach dem Login kopieren
Nach dem Login kopieren

Im Servercode

  1. Fügen Sie die Datei „Anforderungen Ihres Servers“ hinzu:
   from common_logic import ...

   def cloud_function(request):
       # Your cloud function code using the imported functions
       pass
Nach dem Login kopieren
  1. Verwenden Sie es in Ihrem Servercode:
   --index-url https://pypi.org/simple
   --extra-index-url https://oauth2accesstoken:${ARTIFACT_REGISTRY_TOKEN}@us-central1-python.pkg.dev/${PROJECT_ID}/python-packages/simple/
   common-logic==0.1.0
Nach dem Login kopieren
Nach dem Login kopieren

Schritt 7: CI/CD-Integration

  1. Fügen Sie den Dienstkontoschlüssel als Geheimnis in Ihrem GitHub-Repository hinzu.
  2. Aktualisieren Sie Ihre Cloud Build-Konfiguration:
   from common_logic import ...
   # Your server code using the imported functions
Nach dem Login kopieren

Schritt 8: Versionsverwaltung

  1. Aktualisieren Sie die Version in setup.py.
  2. Erstellen und laden Sie die neue Version hoch.
  3. Anforderungen.txt sowohl in Cloud Functions als auch im Servercode aktualisieren.
  4. Stellen Sie beide Komponenten bereit.

Best Practices

  • Verwenden Sie semantische Versionierung für Ihr Paket.
  • Bestimmte Versionen in „requirements.txt“ anpinnen.
  • Testen Sie neue Versionen gründlich, bevor Sie sie bereitstellen.
  • Führen Sie ein Änderungsprotokoll über Versionsänderungen.
  • Verwenden Sie Umgebungsvariablen für PROJECT_ID und LOCATION.
  • Fügen Sie Ihrem Paket eine umfassende Dokumentation bei.

Häufige Probleme und Lösungen

Authentifizierungsfehler

  • Überprüfen Sie die Dienstkontoberechtigungen.
  • Stellen Sie sicher, dass key.json ordnungsgemäß codiert ist.
  • Überprüfen Sie die .pypirc-Konfiguration.

Paket nicht gefunden

  • Repository-URL-Format überprüfen.
  • Überprüfen Sie, ob das Paket erfolgreich hochgeladen wurde.
  • Stellen Sie sicher, dass „requirements.txt“ das richtige URL-Format verwendet.

Versionskonflikte

  • Bestimmte Versionen von Abhängigkeiten anpinnen.
  • Verwenden Sie virtuelle Umgebungen zum Testen.
  • Abhängigkeitsanforderungen klar dokumentieren.

Das obige ist der detaillierte Inhalt vonGCP veröffentlicht Python-Paket in der Produktion. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Quelle:dev.to
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Neueste Artikel des Autors
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage