Ce document est destiné aux architectes d'entreprise et aux développeurs de logiciels qui souhaitent créer un pipeline d'automatisation pour utiliser Active Assist dans leur organisation Google Cloud. Il fait partie d'une série qui traite des modèles architecturaux que les entreprises peuvent utiliser pour optimiser leur empreinte cloud à grande échelle à l'aide d'Active Assist. Cette série comprend les parties suivantes :
- Schémas d'utilisation d'Active Assist à grande échelle
- Utiliser des pipelines sans serveur avec Active Assist (le présent document)
- Utiliser la chaîne d'outils GKE Enterprise avec Active Assist
Ce tutoriel explique comment utiliser les technologies sans serveur Google Cloud pour créer un pipeline d'automatisation permettant de récupérer et de traiter les recommandations Active Assist. Vous basez les recommandations sur les règles commerciales définies par votre entreprise. Le pipeline d'automatisation que vous configurez dans ce tutoriel vous permet de travailler avec Active Assist à grande échelle tout en conservant un processus de vérification et d'activation mené par l'équipe. Cette approche est utile lorsque votre entreprise souhaite faire évoluer l'utilisation du portefeuille Active Assist tout en gardant le contrôle du processus de vérification et d'activation au sein des équipes. Il offre une alternative à l'utilisation d'un pipeline d'intégration et de livraison continue (CI/CD).
L'architecture présentée dans ce tutoriel est générique et vous pouvez l'étendre pour utiliser d'autres produits sans serveur. Dans ce tutoriel, nous partons du principe que vous connaissez les technologies Google Cloud suivantes :
Pour suivre ce tutoriel, vous devez disposer d'un compte Slack ou d'un outil de gestion de notifications ou de demandes similaire. L'outil doit être configuré sur votre machine et prêt à être utilisé.
Architecture
L'architecture présentée dans ce tutoriel étant modulaire, vous pouvez adapter le composant de notifications pour répondre aux exigences de votre entreprise. Ce tutoriel explique comment générer des notifications et les envoyer à Slack. Vous pouvez également choisir d'envoyer des notifications à Pub/Sub ou à tout autre outil de gestion de notifications ou de demandes.
Le schéma d'architecture suivant présente les composants que vous utilisez dans ce tutoriel :
L'architecture comprend les composants suivants :
- Un service Cloud Run déclenché à intervalles fixes par un planificateur. Le service appelle les API de l'outil de recommandation en lisant les métadonnées (ID de projet et types d'outils de recommandation) définies et conservées dans une collection Firestore.
- Sujet Pub/Sub dans lequel les recommandations Active Assist sont transmises et traitées.
- Un deuxième service Cloud Run qui analyse les recommandations Active Assist. Ce service détermine la manière dont les recommandations sont traitées en fonction des règles métier définies par votre entreprise et stockées dans une collection Firestore.
- Deux collections Firestore pour stocker les métadonnées métier et les règles d'entreprise. Les collections Firestore fonctionnent comme suit :
- La première collection stocke les métadonnées métier pertinentes pour récupérer les recommandations Active Assist. Dans ce tutoriel, les attributs
recommendation type
,Google Cloud project IDs
etlocations
sont utilisés comme métadonnées métier. Ces attributs sont utilisés par le service Cloud Runrecommendation-collector
pour déterminer les types de recommandations qui sont récupérés. - La deuxième collection stocke les règles métier qui sont appliquées lors du traitement des recommandations.
- La première collection stocke les métadonnées métier pertinentes pour récupérer les recommandations Active Assist. Dans ce tutoriel, les attributs
Objectifs
- Créer un exemple de service Cloud Run pour récupérer les recommandations Active Assist d'un exemple de projet et les transférer vers un sujet Pub/Sub
- Créer deux collections Firestore pour stocker les exemples de métadonnées et les règles d'entreprise, respectivement.
- Créer un deuxième service Cloud Run pour traiter les recommandations conformément aux exemples de règles métier que vous définissez dans ce tutoriel.
- Créer un canal Slack auquel le service Cloud Run envoie des exemples de recommandations Active Assist.
- Tester le pipeline de bout en bout avec des exemples de recommandations Active Assist.
Coûts
Dans ce document, vous utilisez les composants facturables suivants de Google Cloud :
Obtenez une estimation des coûts en fonction de votre utilisation prévue à l'aide du simulateur de coût.
Une fois que vous avez terminé les tâches décrites dans ce document, vous pouvez éviter de continuer à payer des frais en supprimant les ressources que vous avez créées. Pour en savoir plus, consultez la section Effectuer un nettoyage.
Avant de commencer
-
In the Google Cloud console, go to the project selector page.
-
Select or create a Google Cloud project.
- Notez l'ID de projet Google Cloud pour le projet de gestionnaire de recommandations. Vous en aurez besoin dans la section suivante pour configurer votre environnement.
-
Enable the Cloud Build, Firestore, App Engine,Pub/Sub, Cloud Run, Cloud Scheduler, and Cloud Source Repositories APIs.
Pour ce tutoriel, vous utilisez les identifiants par défaut de l'application. Si vous êtes invité à créer des identifiants sur la page Ajouter des identifiants à votre projet, cliquez sur Annuler. -
Make sure that billing is enabled for your Google Cloud project.
-
Créez les éléments suivants :
- Un exemple de canal Slack.
- Un exemple d'application Slack et de webhook entrant pour recevoir des notifications générées par un moteur nommé
recommendation-rules-engine
. Vous configurerez le moteur plus tard dans ce tutoriel.
Une fois que vous avez créé une application Slack et une URL de webhook entrant, notez cette URL car vous en aurez besoin plus tard dans ce tutoriel.
Créer le pipeline sans serveur
Dans cette section, vous allez créer les composants dont vous avez besoin pour créer le pipeline sans serveur. La plate-forme génère des recommandations Active Assist basées sur les modèles d'utilisation et les métriques système. En fonction des recommandations générées, chaque catégorie de recommandation peut utiliser une période par défaut différente dans le passé pour analyser les données et les métriques d'utilisation.
Si vous disposez d'un exemple de projet Google Cloud contenant des ressources et des recommandations Active Assist existantes, vous pouvez exécuter le pipeline pour traiter ces recommandations après avoir apporté les modifications appropriées à l'exemple de code fourni.
Créer les collections Firestore
Dans cette section, vous allez créer deux collections Firestore.
La première, la collection activeassist-metadata
, stocke les métadonnées commerciales pertinentes pour la récupération des recommandations Active Assist. La deuxième, la collection activeassist-business-rules
, stocke les règles d'entreprise appliquées lorsque le pipeline traite les recommandations.
Lorsque les recommandations Active Assist sont analysées, en fonction des règles métier de la collection Firestore, une notification est générée et envoyée, ou la recommandation est automatiquement appliquée à la ressource Google Cloud concernée.
Créer la collection activeassist-metadata
Dans Google Cloud Console, accédez à la page Firestore.
Créez une base de données Firestore si vous n'en avez pas déjà une. Si vous disposez déjà d'une base de données Firestore, passez à l'étape suivante.
Créez la base de données :
- Cliquez sur Sélectionner le mode natif pour activer Firestore.
- Sélectionnez un emplacement de région proche de la région dans laquelle vos services Cloud Run s'exécutent.
- Cliquez sur Create Database (Créer une base de données). La configuration prend quelques instants.
Sur la page Firestore, cliquez sur Démarrer la collection.
Dans le champ ID de collection, saisissez les informations suivantes :
activeassist-metadata
.Remplissez les champs comme indiqué dans le tableau suivant. Pour ajouter le champ suivant, cliquez sur Ajouter un champ.
Nom du champ Type de champ Valeur du champ Note project
string
Stub-Project-ID
Ce tutoriel utilise un bouchon (stub) pour la valeur de champ. Si vous souhaitez utiliser les recommandations d'un projet Google Cloud existant, saisissez plutôt l'ID du projet. locations
array
global
Certaines recommandations comme les recommandations de redimensionnement de VM peuvent être spécifiques à une région ou à une zone. Les autres recommandations sont globales, par exemple les recommandations IAM. recommenderType
string
google.iam.policy.Recommender
Non applicable. Lorsque les champs sont renseignés, cliquez sur Enregistrer.
Créer la collection activeassist-business-rules
- Cliquez sur Démarrer la collection.
Dans le champ ID de collection, saisissez la valeur suivante :
activeassist-business-rules
.Remplissez le document comme indiqué dans le tableau suivant. Pour ajouter le champ suivant, cliquez sur Ajouter un champ.
Nom du champ Type de champ Valeur du champ Note action
string
Notify
Si la valeur est définie sur Apply
, le service applique la recommandation et supprime le rôle inutilisé.projectId
string
Stub-Project-ID
Ce tutoriel utilise une recommandation de bouchon (stub). Si vous souhaitez utiliser les recommandations d'un projet Google Cloud existant, saisissez plutôt l'ID du projet. projectNumber
string
999999999
Ce tutoriel utilise une recommandation de bouchon (stub).
Si vous utilisez une recommandation d'un projet Google Cloud existant, saisissez plutôt le numéro du projet. Vous le trouverez sur la page d'accueil de la console Google Cloud.recommenderType
string
google.iam.policy.Recommender
Non applicable. recommenderSubtype
string
REMOVE_ROLE
Non applicable. slackWebhookURL
string
Saisissez l'URL du webhook Slack que vous avez généré à une étape précédente. L'URL ressemble à ceci :
https://hooks.slack.com/services/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
Ce tutoriel vous explique comment créer une règle pour déterminer si une recommandation est appliquée automatiquement ou si une notification est générée et envoyée à une plate-forme telle que Slack. Pour savoir comment une recommandation peut être automatiquement appliquée en fonction de l'évaluation d'exemples de règles métier que vous avez configurées, consultez le dépôt associé.
Lorsque le document est rempli, cliquez sur Enregistrer.
Créer un service Cloud Run planifié
Dans cette section, vous allez créer un service Cloud Run planifié nommé recommendation-collector
, qui appelle l'API Recommender et récupère les recommandations actives. L'API Recommender d'Identity and Access Management est utilisée dans ce tutoriel en tant qu'API Recommender. Le service lit les métadonnées de la collection Firestore activeassist-metadata
que vous avez créée pour déterminer les recommandations à récupérer.
Cliquez sur Ouvrir dans Cloud Shell pour ouvrir Cloud Shell pour le projet du gestionnaire de recommandations.
Lorsque Cloud Shell s'ouvre, les commandes suivantes s'exécutent :
- La commande de clonage du dépôt GitHub.
- La commande de changement de répertoire.
Lorsque la boîte de dialogue Ouvrir dans Cloud Shell s'affiche, sélectionnez Approuver, puis cliquez sur Confirmer.
Définissez l'ID et le numéro du projet du gestionnaire de recommandations actuel en tant que variables :
export RECO_MGR_PROJECT=PROJECT_ID gcloud config set project $RECO_MGR_PROJECT export RECO_MGR_PROJECT_NUMBER=$(gcloud projects describe $DEVSHELL_PROJECT_ID --format='value(projectNumber)')
Remplacez
PROJECT_ID
par l'ID du projet. Une fois les commandes saisies, cliquez sur Autoriser lorsque vous y êtes invité.Définissez la variable pour la région de déploiement :
export REGION=us-central1
Bien que ce tutoriel utilise la région
us-central1
, vous pouvez utiliser n'importe quelle région où Cloud Run est disponible.Créez une variable d'environnement pour votre image Docker :
export RECOMMENDER_IMAGE=gcr.io/$RECO_MGR_PROJECT/recommendation-collector:1.0
Créez l'image Docker et importez-la dans Container Registry :
gcloud builds submit --tag $RECOMMENDER_IMAGE
Créez un compte de service pour que le service
recommendation-collector
puisse interagir avec d'autres services Google Cloud du pipeline :gcloud iam service-accounts create recommendation-collector-sa \ --description "Service Account that the recommendation-collector service uses to invoke other Google Cloud services" \ --display-name "recommendation-collector-sa" \ --project $RECO_MGR_PROJECT
Il est recommandé d'accorder des autorisations précises à vos services Cloud Run en attribuant des rôles prédéfinis au compte de service. Pour en savoir plus, consultez la section Identité du service.
Accordez au compte de service du service
recommendation-collector
l'accès à Firestore et à l'API Recommender :gcloud projects add-iam-policy-binding $RECO_MGR_PROJECT \ --member serviceAccount:recommendation-collector-sa@$RECO_MGR_PROJECT.iam.gserviceaccount.com \ --role roles/datastore.user gcloud projects add-iam-policy-binding $RECO_MGR_PROJECT \ --member serviceAccount:recommendation-collector-sa@$RECO_MGR_PROJECT.iam.gserviceaccount.com \ --role roles/pubsub.publisher
Si vous exécutez ce tutoriel à l'aide de l'exemple
stub
fourni dans le dépôt que vous avez cloné, passez à l'étape suivante.Si vous créez un pipeline en suivant ce tutoriel et en utilisant des recommandations générées pour un projet Google Cloud existant, vous devez attribuer des autorisations IAM aux comptes de service que vous avez créés pour exécuter les deux services Cloud Run.
Définissez une variable d'environnement,
TEST_PROJECT_ID
, avec l'ID du projet pour lequel vous exécutez ce pipeline avant d'exécuter les commandes :export TEST_PROJECT_ID=TEST_PROJECT_ID gcloud projects add-iam-policy-binding $TEST_PROJECT_ID \ --member serviceAccount:recommendation-collector-sa@$RECO_MGR_PROJECT.iam.gserviceaccount.com \ --role roles/recommender.iamAdmin gcloud projects add-iam-policy-binding $TEST_PROJECT_ID \ --member serviceAccount:recommendation-collector-sa@$RECO_MGR_PROJECT.iam.gserviceaccount.com \ --role roles/serviceusage.serviceUsageConsumer gcloud services enable recommender.googleapis.com --project $TEST_PROJECT_ID
Assurez-vous que l'ID de projet que vous utilisez correspond à celui que vous avez saisi lors de la création des collections Firestore.
Pour ce tutoriel, vous déployez le service avec une variable d'environnement appelée
STUB_RECOMMENDATIONS
. Cette variable vous permet d'utiliser un bouchon (stub) pour tester le pipeline.Déployez le service Cloud Run :
gcloud run deploy recommendation-collector \ --image=$RECOMMENDER_IMAGE \ --no-allow-unauthenticated \ --region $REGION \ --platform managed \ --service-account recommendation-collector-sa@$RECO_MGR_PROJECT.iam.gserviceaccount.com \ --set-env-vars="STUB_RECOMMENDATIONS=true" \ --project $RECO_MGR_PROJECT \
Acceptez toutes les requêtes du système.
Si vous souhaitez exécuter le pipeline à l'aide des recommandations Active Assist générées pour un projet Google Cloud, supprimez la ligne suivante de la commande avant de la déployer :
--set-env-vars="STUB_RECOMMENDATIONS=true"
Configurer une tâche Cloud Scheduler pour exécuter recommender-collector service
Dans Cloud Shell, créez un compte de service pour les tâches Cloud Scheduler à utiliser pour exécuter le service
recommendation-collector
:gcloud iam service-accounts create recommender-scheduler-sa \ --description "Service Account used by Cloud Scheduler to invoke the recommender-parser service" \ --display-name "recommender-scheduler-sa" \ --project $RECO_MGR_PROJECT
Attribuez au compte de service le rôle
run/invoker
pour lui permettre d'appeler le service Cloud Run :gcloud run services add-iam-policy-binding recommendation-collector \ --member=serviceAccount:recommender-scheduler-sa@$RECO_MGR_PROJECT.iam.gserviceaccount.com \ --role=roles/run.invoker \ --region=$REGION \ --platform=managed
Obtenez l'URL du service
recommendation-collector
:export RECOMMENDER_SERVICE_URI=`gcloud run services describe recommendation-collector \ --platform managed \ --project $RECO_MGR_PROJECT \ --region $REGION \ --format="value(status.url)"`/run
Créez une tâche Cloud Scheduler nommée
recommender-iam-scheduler
:gcloud scheduler jobs create http recommender-iam-scheduler \ --project $RECO_MGR_PROJECT \ --time-zone "America/Los_Angeles" \ --schedule="0 */3 * * *" \ --uri=$RECOMMENDER_SERVICE_URI \ --description="Scheduler job to invoke recommendation pipeline" \ --oidc-service-account-email="recommender-scheduler-sa@$RECO_MGR_PROJECT.iam.gserviceaccount.com" \ --headers="Content-Type=application/json" \ --http-method="POST"
Définissez le fuseau horaire en fonction de votre emplacement. Le format de la valeur de fuseau horaire est basé sur la base de données tz.
Pour plus d'informations, consultez la page sur gcloud scheduler jobs create http.
Votre tâche Cloud Scheduler appelle la route
/run
pour le servicerecommendation-collector
.Utiliser l'option
--schedule="0 */3 * * *"
permet d'exécuter la tâche Scheduler toutes les trois heures. Vous pouvez modifier ce paramètre en fonction de vos besoins. Pour plus d'informations, consultez la section Configurer les planifications de tâches Cron.
Créer le moteur de règles de recommandation pour traiter les recommandations
Dans cette section, vous allez créer un deuxième service Cloud Run nommé recommendation-rules-engine
pour traiter les recommandations recueillies par le service recommendation-collector
. Le service recommendation-rules-engine
est appelé par Pub/Sub lorsque de nouvelles recommandations sont envoyées dans le sujet activeassist-recommendations
.
Ce service analyse les recommandations en fonction des règles commerciales que vous avez définies dans la collection activeassist-business-rules
.
Dans Cloud Shell, ouvrez le répertoire
recommendation-rules-engine
:cd ../recommendation-rules-engine
Créez une variable d'environnement pour votre image Docker :
export RULES_ENGINE_IMAGE=gcr.io/$RECO_MGR_PROJECT/recommendation-rules-engine:1.0
Créez l'image Docker et importez-la dans Container Registry :
gcloud builds submit --tag $RULES_ENGINE_IMAGE
Créez un compte de service pour que le service
recommendation-rules-engine
puisse interagir avec d'autres services Google Cloud du pipeline :gcloud iam service-accounts create recommendation-rules-sa \ --description "Service Account that recommendation-rules-engine uses to invoke other Google Cloud services" \ --display-name "recommendation-rules-sa" \ --project $RECO_MGR_PROJECT
Accordez au compte de service du service
recommendation-rules-engine
l'accès à Firestore :gcloud projects add-iam-policy-binding $RECO_MGR_PROJECT \ --member serviceAccount:recommendation-rules-sa@$RECO_MGR_PROJECT.iam.gserviceaccount.com \ --role roles/datastore.user
Si vous utilisez les bouchons (stubs) fournis pour ce tutoriel, passez à l'étape suivante.
Si vous testez le pipeline à l'aide des recommandations générées pour un projet Google Cloud au lieu des bouchons fournis dans ce tutoriel, exécutez les commandes suivantes pour autoriser le compte de service du moteur de règles à accéder à votre projet :
gcloud projects add-iam-policy-binding $TEST_PROJECT_ID \ --member serviceAccount:recommendation-rules-sa@$RECO_MGR_PROJECT.iam.gserviceaccount.com \ --role roles/serviceusage.serviceUsageConsumer gcloud projects add-iam-policy-binding $TEST_PROJECT_ID \ --member serviceAccount:recommendation-rules-sa@$RECO_MGR_PROJECT.iam.gserviceaccount.com \ --role roles/recommender.iamAdmin gcloud projects add-iam-policy-binding $TEST_PROJECT_ID \ --member serviceAccount:recommendation-rules-sa@$RECO_MGR_PROJECT.iam.gserviceaccount.com \ --role roles/resourcemanager.projectIamAdmin
Déployez le service Cloud Run :
gcloud run deploy recommendation-rules-engine \ --image=$RULES_ENGINE_IMAGE \ --no-allow-unauthenticated \ --region $REGION \ --platform managed \ --service-account recommendation-rules-sa@$RECO_MGR_PROJECT.iam.gserviceaccount.com \ --project $RECO_MGR_PROJECT
Acceptez toutes les invites du système.
Obtenez l'URL
recommendation-rules-engine
:export RECOMMENDER_SERVICE_RULES_URI=`gcloud run services describe recommendation-rules-engine \ --platform managed \ --project $RECO_MGR_PROJECT \ --region $REGION \ --format="value(status.url)"`/process
L'URL que vous récupérez à cette étape est appelée lorsque de nouvelles recommandations sont disponibles dans le sujet Pub/Sub que vous créez à l'étape suivante.
Créer un sujet Pub/Sub pour les recommandations actives
Dans cette section, vous allez créer un sujet Pub/Sub pour les recommandations Active Assist récupérées par le service recommender-collector
en appelant l'API Recommender.
Dans Cloud Shell, créez un sujet Pub/Sub :
gcloud pubsub topics create activeassist-recommendations
Créez un compte de service à utiliser par Pub/Sub pour appeler le Service Cloud Run
recommendation-rules-engine
:gcloud iam service-accounts create recommendation-engine-sub-sa \ --description "Service Account used by Pub/Sub to push recommendations to the recommendation-rules-engine service" \ --display-name "recommendation-engine-sub-sa" \ --project $RECO_MGR_PROJECT
Le compte de service Pub/Sub doit être associé aux rôles dont il a besoin pour publier des messages et pour appeler le service
recommendation-rules-engine
:gcloud projects add-iam-policy-binding $RECO_MGR_PROJECT \ --member serviceAccount:recommendation-engine-sub-sa@$RECO_MGR_PROJECT.iam.gserviceaccount.com \ --role roles/run.invoker \ --project $RECO_MGR_PROJECT
Créer un abonnement au sujet Pub/Sub
Créez un abonnement au service
recommendation-rules-engine
:# grant Pub/Sub the permission to create tokens PUBSUB_SERVICE_ACCOUNT="service-$RECO_MGR_PROJECT_NUMBER@gcp-sa-pubsub.iam.gserviceaccount.com" gcloud projects add-iam-policy-binding $RECO_MGR_PROJECT \ --member="serviceAccount:$PUBSUB_SERVICE_ACCOUNT"\ --role='roles/iam.serviceAccountTokenCreator' # configure the subscription push identity gcloud pubsub subscriptions create active-assist-recommendations-for-rules-engine \ --topic=activeassist-recommendations \ --topic-project=$RECO_MGR_PROJECT \ --push-auth-service-account=recommendation-engine-sub-sa@$RECO_MGR_PROJECT.iam.gserviceaccount.com \ --ack-deadline=60 \ --push-endpoint=$RECOMMENDER_SERVICE_RULES_URI
Autorisez le compte de service
recommendation-engine-sub-sa
que vous avez créé à appeler le servicerecommendation-rules-engine
:gcloud run services add-iam-policy-binding recommendation-rules-engine \ --member=serviceAccount:recommendation-engine-sub-sa@$RECO_MGR_PROJECT.iam.gserviceaccount.com \ --role=roles/run.invoker \ --region=$REGION \ --platform=managed
Exécuter des tests de bout en bout à l'aide de simulations
Les recommandations Active Assist sont générées par la plate-forme en fonction des modèles d'utilisation et des métriques système. Chaque catégorie de recommandations peut utiliser une période par défaut différente dans le passé pour analyser les données d'utilisation et les métriques en fonction des recommandations générées. Par exemple, les recommandations IAM sont générées par la plate-forme en fonction des schémas d'utilisation des 90 derniers jours.
Pour tester le pipeline de bout en bout, le dépôt que vous avez cloné dans le cadre de ce tutoriel fournit des exemples de recommandations (simulations) que vous utilisez pour exécuter le pipeline de bout en bout.
Dans cette section, vous allez exécuter les opérations suivantes :
- Inspectez les recommandations sur les simulations.
- Appelez le pipeline manuellement.
- Vérifiez si une notification est générée et envoyée au canal Slack que vous avez créé.
Consultez les exemples de recommandations fournis dans le dépôt :
cat ../recommendation-collector/stub.json
Ce fichier fournit un exemple de recommandation avec une action
REMOVE
pour un exemple de rôle appeléroles/gkehub.connect
.Exécutez la commande suivante pour que Cloud Scheduler exécute la tâche immédiatement, au lieu d'attendre la prochaine exécution programmée :
gcloud scheduler jobs run recommender-iam-scheduler
Sur la page de la console Cloud Scheduler, dans la colonne Résultat du job
recommender-iam-scheduler
, vérifiez que le résultat est Opération réussie.Pour obtenir une vue détaillée des étapes exécutées par chacun des services, vous pouvez également afficher les journaux de service Cloud Run pour les services
recommendation-collector
etrecommendation-rules-engine
.Lorsque le pipeline de bout en bout sans serveur que vous créez dans ce tutoriel s'exécute correctement, il génère une notification Slack contenant les détails de la liaison de rôle qu'il est recommandé de supprimer. Voici un exemple du type de notification que vous recevez :
Project xxxxxxxx\ **Impact**: SECURITY\ This role has not been used during the observation window.\ **Role**: roles/gkehub.connect\ **Member**: serviceAccount:sample-sa@recommendation-sample.iam.gserviceaccount.com\ **Action**: remove
Nettoyer
Pour éviter que les ressources utilisées lors de ce tutoriel soient facturées sur votre compte Google Cloud, supprimez le projet contenant les ressources, ou conservez le projet et supprimez les ressources individuelles.
Étape suivante
- Découvrez comment utiliser des recommandations pour l'infrastructure en tant que code.
- Familiarisez-vous avec les technologies sans serveur Google Cloud.
- Découvrez comment intégrer des recommandations Policy Intelligence à un pipeline IaC.