Vous pouvez créer et gérer des règles d'agent à l'aide du
Commande gcloud beta compute instances ops-agents policies
dans la Google Cloud CLI ou le
agent-policy
module Terraform.
Les règles d'agent utilisent
Suite d'outils VM Manager
Compute Engine pour gérer les règles d'OS,
qui peut automatiser le déploiement et la maintenance des configurations logicielles
comme
Agents Google Cloud Observability: l'agent Ops, l'ancien agent Monitoring et l'ancien agent Logging.
Créer une règle d'agent
Cette section explique comment utiliser le SDK Google Cloud pour gérer les règles des agents. Pour en savoir plus sur l'utilisation de Terraform, consultez Intégration de Terraform.
Pour créer une règle d'agent à l'aide de Google Cloud CLI, procédez comme suit :
Si vous ne l'avez pas déjà fait, installez Google Cloud CLI.
Les règles d'agent décrites dans ce document utilisent le groupe de commandes
beta
.Si vous ne l'avez pas déjà fait, installez le composant
beta
de gcloud CLI :gcloud components install beta
Pour vérifier si le composant
beta
est installé, exécutez la commande suivante :gcloud components list
Si vous avez déjà installé le composant
beta
, assurez-vous de disposer de la dernière version :gcloud components update
Utilisez le script suivant pour activer les API et définir les autorisations permettant d'utiliser Google Cloud CLI :
set-permissions.sh
.Pour en savoir plus sur ce script, consultez Le script
set-permissions.sh
.Pour créer une règle, utilisez la commande
gcloud beta compute instances ops-agents policies
create
. Pour connaître la syntaxe de la commande, consultez lesgcloud beta compute instances ops-agents policies
create
dans la documentation Google Cloud.Pour obtenir des exemples de formatage de la commande, consultez les Exemples dans la documentation Google Cloud CLI.
Pour en savoir plus sur les autres commandes du groupe de commandes et les options disponibles, consultez les
gcloud beta compute instances ops-agents policies
.
Bonnes pratiques relatives à l'utilisation des règles d'agent
Pour contrôler l'impact du déploiement sur les systèmes de production, nous vous recommandons de spécifier des étiquettes d'instances et des zones afin de filtrer les instances auxquelles la règle s'applique.
Si vous créez une règle pour l'agent Ops, assurez-vous que l'ancien agent Logging ou Monitoring n'est pas installé sur vos VM. L'exécution de l'agent Ops et des anciens agents sur la même VM peut entraîner l'ingestion de journaux en double ou créer un conflit dans l'ingestion des métriques. Si nécessaire, désinstallez l'agent Monitoring et désinstallez l'agent Logging avant de créer une règle pour installer l'agent Ops.Voici un exemple de plan de déploiement par étapes pour les VM Debian 11 dans un projet appelé my_project
:
Phase 1: Créer une règle nommée ops-agents-policy-safe-rollout
pour installer la
Agent Ops sur toutes les VM avec les étiquettes env=test
et app=myproduct
.
gcloud beta compute instances \
ops-agents policies create ops-agents-policy-safe-rollout \
--agent-rules="type=ops-agent,version=current-major,package-state=installed,enable-autoupgrade=true" \
--os-types=short-name=debian,version=11 \
--group-labels=env=test,app=myproduct \
--project=my_project
Pour en savoir plus sur la spécification du système d'exploitation, consultez la page gcloud beta compute instances ops-agents policies
create
.
Phase 2: Mettre à jour cette règle pour cibler les VM d'une seule zone ayant le
les libellés env=prod
et app=myproduct
.
gcloud beta compute instances \
ops-agents policies update ops-agents-policy-safe-rollout \
--group-labels=env=prod,app=myproduct \
--zones=us-central1-c \
Phase 3 : mettre à jour cette règle pour effacer le filtre des zones et la déployer globalement.
gcloud beta compute instances \
ops-agents policies update ops-agents-policy-safe-rollout \
--clear-zones
Règles sur les VM antérieures à OS Config
Vous devrez peut-être installer et configurer manuellement l'agent OS Config sur les VM antérieures à OS Config. Pour savoir comment installer et valider manuellement l'agent OS Config, consultez la checklist de validation de VM Manager.
Résoudre les problèmes liés aux règles d'agent bêta
Cette section fournit des informations pour vous aider à résoudre les problèmes liés à l'agent bêta pour l'agent Ops, l'ancien agent Monitoring et l'ancien agent Logging.
Les commandes ops-agents policy
échouent
Lorsqu'une commande gcloud beta compute instances ops-agents policies
échoue, la réponse affiche une erreur de validation. Corrigez ces erreurs en corrigeant les arguments de commande et les options, comme indiqué par le message d'erreur.
En plus des erreurs de validation, il est possible que d'autres erreurs indiquent les conditions suivantes:
Les sections suivantes décrivent ces conditions plus en détail.
Autorisation IAM insuffisante
Si une commande gcloud beta compute instances ops-agents policies
échoue avec une erreur d'autorisation, alors
assurez-vous d'avoir exécuté le script set-permissions.sh
comme décrit dans
Créer une règle d'agent
Pour configurer les rôles de stratégie OS Config:
- Administrateur GuestPolicy (
roles/osconfig.guestPolicyAdmin
) : permet d'accéder entièrement aux règles d'invité. - Éditeur GuestPolicy (
roles/osconfig.guestPolicyEditor
) : permet aux utilisateurs d'obtenir, de mettre à jour et de répertorier les règles d'invité. -
Lecteur GuestPolicy (
roles/osconfig.guestPolicyViewer
): Fournit un accès en lecture seule permettant d'obtenir et de répertorier les règles d'invité.
Pour en savoir plus sur le script set-permissions.sh
, consultez
Script set-permissions.sh
.
L'API OS Config n'est pas activée
Voici un exemple d'erreur:
API [osconfig.googleapis.com] not enabled on project PROJECT_ID.
Would you like to enable and retry (this will take a few minutes)?
(y/N)?
Vous pouvez entrer y
pour activer l'API, ou vous pouvez exécuter le script set-permissions.sh
, décrit dans la section Créer une règle d'agent, afin d'accorder toutes les autorisations nécessaires. Si vous saisissez y
au niveau
apparaît dans le message d'erreur, vous devez quand même exécuter
set-permissions.sh
pour définir les autorisations nécessaires.
Pour vérifier que l'API OS Config est activée pour le projet, exécutez les commandes suivantes :
gcloud services list --project PROJECT_ID | grep osconfig.googleapis.com
Le résultat attendu est le suivant :
osconfig.googleapis.com Cloud OS Config API
La règle n'existe pas
Voici un exemple d'erreur:
NOT_FOUND: Requested entity was not found
Cette erreur peut signifier que la règle n'a jamais été créée, qu'elle a été supprimée ou que l'ID de règle spécifié est incorrect. Assurez-vous que la POLICY_ID utilisée dans une commande gcloud beta compute instances ops-agents policies
describe
, update
ou delete
correspond à une stratégie existante. Pour obtenir la liste des agents
utilisez la commande gcloud beta compute instances ops-agents policies
list
.
La règle est créée, mais elle semble n'avoir aucun effet
Les agents OS Config sont déployés sur chaque instance Compute Engine afin de gérer les packages pour les agents Logging et Monitoring. Cette règle peut sembler n'avoir aucun effet si l'agent OS Config sous-jacent n'est pas installés.
Linux
Pour vérifier que l'agent OS Config est installé, exécutez la commande suivante :
gcloud compute ssh instance-id \
--project project-id \
-- sudo systemctl status google-osconfig-agent
Voici un exemple de sortie :
google-osconfig-agent.service - Google OSConfig Agent
Loaded: loaded (/lib/systemd/system/google-osconfig-agent.service; enabled; vendor preset:
Active: active (running) since Wed 2020-01-15 00:14:22 UTC; 6min ago
Main PID: 369 (google_osconfig)
Tasks: 8 (limit: 4374)
Memory: 102.7M
CGroup: /system.slice/google-osconfig-agent.service
└─369 /usr/bin/google_osconfig_agent
Windows
Pour vérifier que l'agent OS Config est installé, exécutez la commande suivante :
Connectez-vous à votre instance via RDP ou un outil similaire, et connectez-vous à Windows.
Ouvrez un terminal PowerShell, puis exécutez la commande PowerShell suivante. Vous n'avez pas besoin de droits d'administrateur.
Get-Service google_osconfig_agent
Voici un exemple de sortie :
Status Name DisplayName
------ ---- -----------
Running google_osconfig_a… Google OSConfig Agent
Si l'agent OS Config n'est pas installé, vous utilisez peut-être un système d'exploitation qui n'est pas compatible avec VM Manager. La Document Détails des systèmes d'exploitation Compute Engine indique les fonctionnalités de VM Manager compatibles avec chaque le système d'exploitation Compute Engine.
Si le système d'exploitation est compatible avec VM Manager, vous pouvez installer manuellement l'agent OS Config.
L'agent OS Config est installé, mais il n'installe pas les agents Ops
Pour vérifier si des erreurs se produisent lorsque l'agent OS Config applique des règles, vous pouvez consulter le journal de l'agent OS Config. Pour ce faire, vous pouvez utiliser l'explorateur de journaux, ou SSH ou RDP pour vérifier des instances Compute Engine individuelles.
Pour afficher les journaux de l'agent OS Config dans l'explorateur de journaux, utilisez le filtre suivant :
resource.type="gce_instance"
logId(OSConfigAgent)
Pour afficher les journaux de l'agent OS Config, procédez comme suit :
CentOS, RHEL,
SLES, SUSE
Exécutez la commande suivante :
gcloud compute ssh INSTANCE_ID \
--project PROJECT_ID \
-- sudo cat /var/log/messages \
| grep "OSConfigAgent\|google-fluentd\|stackdriver-agent"
Debian, Ubuntu
Exécutez la commande suivante :
gcloud compute ssh INSTANCE_ID \
--project PROJECT_ID \
-- sudo cat /var/log/syslog \
| grep "OSConfigAgent\|google-fluentd\|stackdriver-agent"
Windows
Connectez-vous à votre instance via RDP ou un outil similaire, et connectez-vous à Windows.
Ouvrez l'application Event Viewer, puis sélectionnez Windows Logs > Application (Journaux Windows > Application), et recherchez les journaux pour lesquels
Source
est égal àOSConfigAgent
.
Si une erreur se produit lors de la connexion au service OS Config, assurez-vous d'exécuter la
set-permissions.sh
, comme décrit dans
Créer une règle d'agent
pour configurer les métadonnées OS Config.
Pour vérifier que les métadonnées OS Config sont activées, exécutez la commande suivante :
gcloud compute project-info describe \
--project PROJECT_ID \
| grep "enable-osconfig\|enable-guest-attributes" -A 1
Le résultat attendu est le suivant:
- key: enable-guest-attributes
value: 'TRUE'
- key: enable-osconfig
value: 'TRUE'
Les agents d'observabilité sont installés, mais ne fonctionnent pas correctement
Pour en savoir plus sur le débogage d'agents spécifiques, consultez les documents suivants :
- Résoudre les problèmes liés à l'agent Ops
- Résoudre les problèmes liés à l'ancien agent Logging
- Dépanner l'ancien agent Monitoring
Activer les journaux de niveau débogage pour l'agent OS Config
Il peut être utile d'activer la journalisation de niveau débogage dans l'agent OS Config lorsque vous signalez un problème.
Vous pouvez définir les métadonnées osconfig-log-level: debug
pour activer la journalisation au niveau du débogage pour l'agent OS Config. Les journaux collectés contiennent plus d'informations pour faciliter l'investigation.
Afin d'activer la journalisation au niveau du débogage pour l'ensemble du projet, exécutez la commande suivante :
gcloud compute project-info add-metadata \
--project PROJECT_ID \
--metadata osconfig-log-level=debug
Pour activer la journalisation au niveau du débogage sur une VM, exécutez la commande suivante :
gcloud compute instances add-metadata INSTANCE_ID \
--project PROJECT_ID \
--metadata osconfig-log-level=debug
Scripts d'aide
Cette section fournit des informations supplémentaires sur les scripts d'assistance décrits dans ce document :
Script set-permissions.sh
Après avoir téléchargé le script set-permissions.sh
, vous pouvez l'utiliser pour effectuer les actions suivantes, en fonction des arguments que vous fournissez :
Activez l'API Cloud Logging, l'API Cloud Monitoring et l'API OS Config pour le projet.
Accordez les rôles Identity and Access Management Rédacteur de journaux (
roles/logging.logWriter
) et Rédacteur de métriques Monitoring (roles/monitoring.metricWriter
) au compte de service par défaut Compute Engine afin que les agents puissent écrire des journaux et des métriques dans les API Logging and Cloud Monitoring.Activez les métadonnées OS Config pour le projet afin que l'agent OS Config sur chaque VM soit actif.
Attribuez l'un des rôles IAM suivants à l'utilisateur ou au compte de service non propriétaire nécessaire pour créer et gérer des stratégies. Les propriétaires de projet disposent d'un accès complet pour créer et gérer des règles ; tous les autres utilisateurs ou comptes de service doivent disposer de l'un des rôles suivants:
-
Administrateur GuestPolicy (
roles/osconfig.guestPolicyAdmin
): Fournit un accès complet aux règles relatives aux invités. - Éditeur GuestPolicy (
roles/osconfig.guestPolicyEditor
) : permet aux utilisateurs d'obtenir, de mettre à jour et de répertorier les règles d'invité. - Lecteur GuestPolicy (
roles/osconfig.guestPolicyViewer
) : permet d'accéder en lecture seule aux règles d'invité et de les répertorier.
Lors de l'exécution du script, il vous suffit de spécifier la partie
guestPolicy*
du nom du rôle. Le script fournit la partieroles/osconfig.
du nom.-
Administrateur GuestPolicy (
Les exemples suivants illustrent certaines invocations courantes du script. Pour en savoir plus, consultez les commentaires dans le script lui-même.
Pour activer les API, attribuez les rôles nécessaires au compte de service par défaut, et activez les métadonnées OS Config pour un projet, exécutez le script comme suit:
bash set-permissions.sh --project=PROJECT_ID
Pour en plus accorder l'un des rôles OS Config à un utilisateur qui ne dispose pas du rôle Propriétaire (roles/owner
) sur le projet, exécutez le script comme suit :
bash set-permissions.sh --project=PROJECT_ID \ --iam-user=USER_EMAIL \ --iam-permission-role=guestPolicy[Admin|Editor|Viewer]
Pour en plus accorder l'un des rôles OS Config à un compte de service autre que celui par défaut, exécutez le script comme suit :
bash set-permissions.sh --project=PROJECT_ID \ --iam-service-account=SERVICE_ACCT_EMAIL \ --iam-permission-role=guestPolicy[Admin|Editor|Viewer]
Script diagnose.sh
À partir d'un ID de projet, d'un ID d'instance Compute Engine et de l'ID d'une règle d'agent, le script diagnose.sh
collecte automatiquement les informations nécessaires pour diagnostiquer les problèmes liés à la règle :
- Version de l'agent OS Config
- Règle d'invité OS Config sous-jacente
- Règles applicables à cette instance Compute Engine
- Dépôts de packages de l'agent, qui sont extraits vers cette instance Compute Engine
Pour appeler le script, exécutez la commande suivante:
bash diagnose.sh --project-id=PROJECT_ID \ --gce-instance-id=INSTANCE_ID \ --policy-id=POLICY_ID
Intégration de Terraform
Pour savoir comment appliquer ou supprimer une configuration Terraform, consultez la page Commandes Terraform de base. Pour en savoir plus sur le fonctionnement de Terraform, consultez Utiliser Terraform
La compatibilité de Terraform avec les règles d'agent repose sur la Google Cloud CLI
commandes. Pour créer une règle d'agent à l'aide de Terraform, suivez les instructions du module Terraform agent-policy
.
Vous trouverez également des exemples de règles dans le répertoire examples
.