Déployer une API sur une passerelle
Cette page explique comment déployer une API sur API Gateway.
Prérequis
Pour pouvoir déployer une API sur API Gateway, assurez-vous d'avoir effectué les opérations suivantes :
Préparez votre environnement de développement comme décrit dans Configurer votre environnement de développement.
Créez une API si vous utilisez Google Cloud CLI.
Remarque : Lorsque vous utilisez la console Google Cloud , cette étape est effectuée lors du déploiement de l'API, comme décrit ci-dessous.Créez une spécification OpenAPI qui définit votre API.
Créez une configuration d'API à partir de votre définition d'API.
Exigences concernant l'ID de passerelle
La plupart des commandes gcloud CLI présentées ci-dessous nécessitent de spécifier l'ID de la passerelle, au format suivant : GATEWAY_ID. API Gateway applique les exigences suivantes pour l'ID de passerelle :
- Ne doit pas comporter plus de 49 caractères.
- Ne doit contenir que des lettres minuscules, des chiffres ou des tirets.
- Il ne doit pas commencer par un tiret.
- Il ne doit pas contenir de trait de soulignement.
Définir le point de terminaison de la configuration d'API déployée
Lorsque vous déployez une configuration d'API sur une passerelle, API Gateway crée une URL unique pour la passerelle dans le domaine gateway.dev. Vos clients d'API utilisent ensuite une URL au format ci-dessous pour accéder à la configuration d'API déployée :
https://GATEWAY_ID-HASH.REGION_CODE.gateway.dev
où GATEWAY_ID est le nom de la passerelle, HASH est le code de hachage unique généré lors du déploiement de l'API et REGION_CODE est le code de la zone Cloud dans laquelle vous avez déployé la passerelle.
Exemple :
https://my-gateway-a12bcd345e67f89g0h.uc.gateway.dev
Déployer une API sur une passerelle
Pour déployer une API sur une passerelle :
Console Google Cloud
Dans la console Google Cloud , accédez à la page API Gateway.
- Cliquez sur Créer une passerelle.
La page Créer une passerelle s'affiche.
- Dans le champ Sélectionner une API, sélectionnez Créer une API.
- Dans le champ Nom à afficher, saisissez le nom à afficher de l'API.
- Dans le champ ID de l'API, saisissez l'ID de l'API. Consultez les exigences concernant les ID d'API pour connaître les consignes de dénomination des API.
- (Facultatif) Ajoutez des libellés pour votre API.
- Dans la section Configuration d'API, sélectionnez Créer une configuration d'API dans le champ Sélectionner une configuration.
- Dans le champ Importer une spécification d'API, importez un fichier
.yamlou.json. Consultez les formats de fichier OpenAPI 2.0 et OpenAPI 3.x pour la définition d'API. - Dans le champ Nom à afficher, saisissez le nom à afficher de la configuration de l'API.
- Dans la liste Sélectionner un compte de service, sélectionnez le compte de service requis. Ce compte de service sera utilisé par API Gateway comme identité.
- (Facultatif) Ajoutez des libellés pour votre configuration d'API.
- Dans la section Détails de la passerelle, saisissez un nom à afficher pour votre passerelle.
- Dans le champ Emplacement, sélectionnez la région Google Cloud dans laquelle vous souhaitez déployer votre passerelle.
- (Facultatif) Ajoutez des libellés pour votre API Gateway.
- Cliquez sur Créer une passerelle.
La nouvelle API est visible sur la page d'accueil API Gateway.
Google Cloud CLI
Validez l'ID de projet renvoyé par la commande suivante, afin de vous assurer que la passerelle est créée dans le projet correct.
gcloud config list project
Si vous devez changer le projet par défaut, exécutez la commande suivante et remplacez PROJECT_ID par l'ID du projet Google Cloud dans lequel vous souhaitez créer le service :
gcloud config set project PROJECT_ID
Affichez l'aide de la commande
gateway create:gcloud api-gateway gateways create --help
Exécutez la commande suivante pour déployer la configuration de l'API sur la passerelle :
gcloud api-gateway gateways create GATEWAY_ID \ --api=API_ID --api-config=CONFIG_ID \ --location=GCP_REGION
où :
- GATEWAY_ID spécifie l'ID de la nouvelle passerelle. Si la passerelle n'existe pas encore, cette commande la crée.
- API_ID spécifie l'ID de l'API API Gateway associée à cette passerelle.
- CONFIG_ID spécifie l'ID de la configuration d'API déployée sur la passerelle. Vous devez spécifier une configuration d'API lorsque vous créez une passerelle.
- GCP_REGION spécifie l'emplacement Cloud de la passerelle déployée.
Lors de la création de la passerelle, gcloud CLI envoie des informations au terminal.
Si l'opération réussit, vous pouvez utiliser la commande suivante pour afficher les détails de la passerelle :
gcloud api-gateway gateways describe GATEWAY_ID \ --location=GCP_REGION
Cette commande renvoie les éléments suivants :
apiConfig: projects/PROJECT_ID/locations/global/apis/API_ID/configs/CONFIG_ID createTime: '2020-02-05T13:44:12.997862831Z' defaultHostname: my-gateway-a12bcd345e67f89g0h.uc.gateway.dev displayName: GATEWAY_ID name: projects/PROJECT_ID/locations/GCP_REGION/gateways/GATEWAY_ID serviceAccount: email: gateway-111111@222222-tp.iam.gserviceaccount.com state: ACTIVE updateTime: '2020-02-05T13:45:00.844705087Z'
Notez la valeur de la propriété
defaultHostname. Il s'agit de la partie nom d'hôte de l'URL de la passerelle. Pour accéder à une configuration d'API déployée sur cette passerelle, vous utilisez une URL au format suivant :https://my-gateway-a12bcd345e67f89g0h.uc.gateway.dev
La gcloud CLI accepte de nombreuses options, y compris celles décrites dans la documentation de référence de gcloud. De plus, pour API Gateway, vous pouvez définir les options suivantes lorsque vous créez une passerelle :
--async: rend le contrôle immédiatement au terminal, sans attendre la fin de l'opération.--display-name=NAME: spécifie le nom à afficher de la passerelle, c'est-à-dire le nom affiché dans l'UI. N'utilisez pas d'espaces dans le nom. Utilisez plutôt des traits d'union et des traits de soulignement. La valeur par défaut est GATEWAY_ID.--labels=KEY1=VALUE1,KEY2=VALUE2,...: spécifie les libellés associés à la passerelle.
Répertorier les passerelles
Cette section explique comment afficher la liste de toutes les passerelles API déployées dans votre projet Google Cloud .
Console Google Cloud
Dans la console Google Cloud , accédez à la page API Gateway > Passerelles.
Google Cloud CLI
Pour répertorier les passerelles d'un projet spécifique, procédez comme suit :
gcloud api-gateway gateways list
Cette commande renvoie un résultat au format suivant :
GATEWAY_ID LOCATION DISPLAY_NAME STATE CREATE_TIME UPDATE_TIME my-gateway us-central1 my-gateway ACTIVE 2021-01-07T00:04:19 2022-05-21T00:33:46
Pour répertorier les passerelles d'un projet et d'une région spécifiques, procédez comme suit :
gcloud api-gateway gateways list --location=GCP_REGION
Utilisez une expression filter pour répertorier les passerelles associées à une API spécifique :
gcloud api-gateway gateways list \ --filter="apiConfig:projects/PROJECT_ID/locations/global/apis/API_ID/*" \
Vous pouvez également utiliser cette filter pour répertorier les passerelles pour une configuration d'API spécifique :
gcloud api-gateway gateways list \ --filter="apiConfig:projects/PROJECT_ID/locations/global/apis/API_ID/configs/CONFIG_ID" \ --project=PROJECT_ID
Utilisez les ID de région et de passerelle pour obtenir des informations détaillées sur la passerelle, y compris l'identité de la configuration d'API déployée sur la passerelle :
gcloud api-gateway gateways describe GATEWAY_ID \ --location=GCP_REGION
Mettre à jour une passerelle
Mettez à jour une passerelle pour :
- Déployer une autre configuration d'API sur la passerelle
- Modifier le nom à afficher
Mettre à jour les étiquettes.
Console Google Cloud
Pour mettre à jour les informations de la passerelle API, procédez comme suit :
Dans la console Google Cloud , accédez à la page API Gateway.
- Cliquez sur l'API requise.
- Cliquez sur l'onglet Passerelles.
- Cliquez sur la passerelle requise.
- Cliquez sur Modifier Modifier.
- Modifiez le Nom à afficher ou les Libellés.
- Sélectionnez la configuration d'API requise ou cliquez sur Créer une configuration d'API et créez la configuration comme indiqué ici.
- Cliquez sur Mettre à jour.
- Cliquez sur pour revenir à la page de la liste des passerelles.
- Sur la page de la liste des passerelles, vous pouvez afficher la passerelle mise à jour.
Google Cloud CLI
Utilisez la commande gcloud CLI suivante pour mettre à jour une passerelle existante, en remplaçant UPDATE_OPTIONS par le flag et la valeur de l'option de passerelle que vous souhaitez mettre à jour :
gcloud api-gateway gateways update GATEWAY_ID \ UPDATE_OPTIONS --api=API_ID --location=GCP_REGION
Par exemple, pour mettre à jour la configuration d'API déployée sur la passerelle :
gcloud api-gateway gateways update GATEWAY_ID \ --api-config=NEW_CONFIG_ID --api=API_ID --location=GCP_REGION
où NEW_CONFIG_ID spécifie la nouvelle configuration d'API à déployer sur la passerelle.
Pour obtenir la liste complète des indicateurs et arguments de mise à jour disponibles, consultez la documentation de référence sur gcloud api-gateway gateways update ou utilisez la commande suivante pour afficher toutes les options de mise à jour :
gcloud api-gateway gateways update --help
Supprimer une passerelle
Cette section explique comment supprimer une passerelle API existante. Suivez ces étapes pour supprimer définitivement une passerelle et sa configuration associée de votre projet Google Cloud .
Console Google Cloud
-
Dans la console Google Cloud , accédez à la page API Gateway > Passerelles.
- Cliquez sur Plus , puis sur Supprimer pour supprimer la passerelle API choisie.
Google Cloud CLI
Utilisez la commande gcloud CLI suivante pour supprimer une passerelle existante :
gcloud api-gateway gateways delete GATEWAY_ID \ --location=GCP_REGION