Créer et déployer une fonction Cloud Run HTTP à l'aide de Python (1re génération)

Ce guide vous accompagne tout au long du processus d'écriture d'une fonction Cloud Run à l'aide de l'environnement d'exécution Python. Il existe deux types de fonctions Cloud Run :

  • Les fonctions HTTP, que vous appelez à partir des requêtes HTTP standards.
  • Les fonctions déclenchées par des événements, qui vous permettent de gérer les événements depuis votre infrastructure cloud tels que les messages sur un sujet Pub/Sub ou les modifications apportées à un bucket Cloud Storage.

L'exemple montre comment créer une fonction HTTP simple.

Avant de commencer

  1. Sign in to your Google Cloud account. If you're new to Google Cloud, create an account to evaluate how our products perform in real-world scenarios. New customers also get $300 in free credits to run, test, and deploy workloads.
  2. In the Google Cloud console, on the project selector page, select or create a Google Cloud project.

    Go to project selector

  3. Make sure that billing is enabled for your Google Cloud project.

  4. Enable the Cloud Functions and Cloud Build APIs.

    Enable the APIs

  5. In the Google Cloud console, on the project selector page, select or create a Google Cloud project.

    Go to project selector

  6. Make sure that billing is enabled for your Google Cloud project.

  7. Enable the Cloud Functions and Cloud Build APIs.

    Enable the APIs

  8. Installez et initialisez gcloud CLI.
  9. Mettez à jour et installez les composants gcloud :
    gcloud components update
  10. Préparez votre environnement de développement.

    Accéder au guide de configuration Python

  11. Créer une fonction

    1. Créez un répertoire sur votre système local pour le code de fonction :

      Linux ou Mac OS X

      mkdir ~/helloworld
      cd ~/helloworld
      

      Windows

      mkdir %HOMEPATH%\helloworld
      cd %HOMEPATH%\helloworld
      
    2. Créez un fichier main.py dans le répertoire helloworld avec le contenu suivant :

      
      import functions_framework
      
      
      from markupsafe import escape
      
      @functions_framework.http
      def hello_http(request):
          """HTTP Cloud Function.
          Args:
              request (flask.Request): The request object.
              <https://flask.palletsprojects.com/en/1.1.x/api/#incoming-request-data>
          Returns:
              The response text, or any set of values that can be turned into a
              Response object using `make_response`
              <https://flask.palletsprojects.com/en/1.1.x/api/#flask.make_response>.
          """
          request_json = request.get_json(silent=True)
          request_args = request.args
      
          if request_json and "name" in request_json:
              name = request_json["name"]
          elif request_args and "name" in request_args:
              name = request_args["name"]
          else:
              name = "World"
          return f"Hello {escape(name)}!"
      
      

      Cet exemple de fonction utilise un nom fourni dans la requête HTTP et renvoie un message d'accueil. Lorsqu'aucun nom n'est fourni, il renvoie le message "Hello World!".

    Spécifier des dépendances

    Dans Python, les dépendances sont gérées avec pip et exprimées dans un fichier de métadonnées appelé requirements.txt. Ce fichier doit se trouver dans le même répertoire que le fichier main.py qui contient le code de votre fonction.

    Vous n'avez pas besoin de créer de fichier requirements.txt pour exécuter cet exemple, mais supposons que vous souhaitiez ajouter vos propres dépendances. Voici la procédure à suivre :

    1. Créez un fichier requirements.txt dans le répertoire helloworld.

    2. Ajoutez la dépendance de la fonction à votre fichier requirements.txt, par exemple :

      # An example requirements file, add your dependencies below
      sampleproject==2.0.0
      

    Déployer la fonction

    Pour déployer la fonction avec un déclencheur HTTP, exécutez la commande suivante dans le répertoire helloworld :

    gcloud functions deploy hello_http --no-gen2 --runtime python312 --trigger-http --allow-unauthenticated

    L'option --allow-unauthenticated vous permet d'accéder à la fonction sans authentification. Pour exiger une authentification, omettez cette option.

    Tester la fonction

    1. Une fois le déploiement de la fonction terminé, notez la propriété httpsTrigger.url ou recherchez-la à l'aide de la commande suivante :

      gcloud functions describe hello_http
      

      Elle devrait se présenter comme ceci :

      https://GCP_REGION-PROJECT_ID.cloudfunctions.net/hello_http
    2. Accédez à cette URL dans votre navigateur. Un message de type "Hello World!" doit s'afficher.

      Essayez de transmettre un nom dans la requête HTTP, par exemple à l'aide de l'URL suivante :

      https://GCP_REGION-PROJECT_ID.cloudfunctions.net/hello_http?name=NAME

      Le message "Hello NAME!" doit s'afficher.

    Afficher les journaux

    Les journaux Cloud Run Functions sont visibles à l'aide de Google Cloud CLI et de l'interface utilisateur de Cloud Logging.

    Utiliser l'outil de ligne de commande

    Pour afficher les journaux de votre fonction à l'aide de gcloud CLI, exécutez la commande logs read suivie du nom de la fonction :

    gcloud functions logs read hello_http

    Le résultat doit ressembler à ceci :

    LEVEL  NAME        EXECUTION_ID  TIME_UTC                 LOG
    D      hello_http  pdb5ys2t022n  2019-09-18 23:29:09.791  Function execution started
    D      hello_http  pdb5ys2t022n  2019-09-18 23:29:09.798  Function execution took 7 ms, finished with status code: 200

    Utiliser le tableau de bord Logging

    Vous pouvez également consulter les journaux Cloud Run Functions depuis la consoleGoogle Cloud .