Tutoriel : Déployer des configurations à l’aide de GitOps sur un cluster Kubernetes avec Azure Arc
Important
Ce tutoriel s’applique à GitOps avec Flux v1. GitOps avec Flux v2 est désormais disponible pour les clusters AKS (Azure Kubernetes Service) et Kubernetes avec Azure Arc. Accédez au tutoriel pour GitOps avec Flux v2. Nous vous recommandons d’effectuer une migration vers Flux v2 dès que possible.
La prise en charge des ressources de configuration du cluster basées sur Flux v1, créées avant le 1er janvier 2024, s’achève le 24 mai 2025. À compter du 1er janvier 2024, vous ne pouvez plus créer de ressources de configuration de cluster basées sur Flux v1.
Dans ce tutoriel, vous allez appliquer des configurations Flux v1 à l’aide de GitOps sur un cluster Kubernetes avec Azure Arc. Vous allez découvrir comment :
- Créer une configuration sur un cluster Kubernetes avec Azure Arc à l’aide d’un exemple de dépôt Git.
- Vérifier que la configuration a été correctement créée.
- Appliquer une configuration à partir d'un référentiel Git privé.
- Valider la configuration de Kubernetes.
Prérequis
Compte Azure avec un abonnement actif. Créez un compte gratuitement.
Cluster Kubernetes avec Azure Arc connecté. Si vous n’avez pas encore connecté de cluster, consultez notre guide de démarrage rapide sur la connexion d’un cluster Kubernetes avec Azure Arc.
Installez l’extension
k8s-configuration
d’Azure CLI, version >= 1.0.0 :az extension add --name k8s-configuration
Conseil
Si l'extension
k8s-configuration
est déjà installée, vous pouvez la mettre à jour vers la version la plus récente à l'aide de la commande suivante -az extension update --name k8s-configuration
Créer une configuration
L’exemple de dépôt utilisé dans cet article est structuré autour d’un personnage, l’opérateur de cluster. Les manifestes de ce dépôt provisionnent quelques espaces de noms, déploient des charges de travail et fournissent une configuration spécifique à l’équipe. L’utilisation de ce dépôt avec GitOps permet de créer les ressources suivantes sur votre cluster :
- Espaces de noms :
cluster-config
,team-a
,team-b
- Déploiement :
arc-k8s-demo
- ConfigMap :
team-a/endpoints
Le config-agent
interroge Azure sur l’existence de configurations nouvelles ou mises à jour. Cette tâche peut prendre jusqu’à 5 minutes.
Si vous associez un dépôt privé à la configuration, effectuez les étapes ci-dessous dans Appliquer une configuration à partir d’un dépôt Git privé.
Important
Ce tutoriel s’applique à GitOps avec Flux v1. GitOps avec Flux v2 est désormais disponible pour les clusters AKS (Azure Kubernetes Service) et Kubernetes avec Azure Arc. Accédez au tutoriel pour GitOps avec Flux v2. Nous vous recommandons d’effectuer une migration vers Flux v2 dès que possible.
La prise en charge des ressources de configuration du cluster basées sur Flux v1, créées avant le 1er janvier 2024, s’achève le 24 mai 2025. À compter du 1er janvier 2024, vous ne pouvez plus créer de ressources de configuration de cluster basées sur Flux v1.
Utiliser l’interface de ligne de commande Microsoft Azure
Utilisez l’extension Azure CLI pour k8s-configuration
pour lier notre cluster connecté à un exemple de référentiel Git.
Nommez cette configuration
cluster-config
.Demandez à l’agent de déployer l’opérateur dans l’espace de noms
cluster-config
.Accordez les autorisations
cluster-admin
à l’opérateur.az k8s-configuration flux create --name cluster-config --cluster-name AzureArcTest1 --resource-group AzureArcTest --operator-instance-name cluster-config --operator-namespace cluster-config --repository-url https://github.com/Azure/arc-k8s-demo --scope cluster --cluster-type connectedClusters
{ "complianceStatus": { "complianceState": "Pending", "lastConfigApplied": "0001-01-01T00:00:00", "message": "{\"OperatorMessage\":null,\"ClusterState\":null}", "messageLevel": "3" }, "configurationProtectedSettings": {}, "enableHelmOperator": false, "helmOperatorProperties": null, "id": "/subscriptions/<sub id>/resourceGroups/<group name>/providers/Microsoft.Kubernetes/connectedClusters/<cluster name>/providers/Microsoft.KubernetesConfiguration/sourceControlConfigurations/cluster-config", "name": "cluster-config", "operatorInstanceName": "cluster-config", "operatorNamespace": "cluster-config", "operatorParams": "--git-readonly", "operatorScope": "cluster", "operatorType": "Flux", "provisioningState": "Succeeded", "repositoryPublicKey": "", "repositoryUrl": "https://github.com/Azure/arc-k8s-demo", "resourceGroup": "MyRG", "sshKnownHostsContents": "", "systemData": { "createdAt": "2020-11-24T21:22:01.542801+00:00", "createdBy": null, "createdByType": null, "lastModifiedAt": "2020-11-24T21:22:01.542801+00:00", "lastModifiedBy": null, "lastModifiedByType": null }, "type": "Microsoft.KubernetesConfiguration/sourceControlConfigurations" }
Utiliser un dépôt Git public
Paramètre | Format |
---|---|
--repository-url |
http[s]://server/repo[.git] |
Utiliser un dépôt Git privé avec des clés créées par SSH et Flux
Ajoutez la clé publique générée par Flux au compte d’utilisateur dans votre fournisseur de services Git. Si la clé est ajoutée au dépôt au lieu du compte d’utilisateur, utilisez git@
à la place de user@
dans l’URL.
Pour plus d’informations, accédez à la section Appliquer une configuration à partir d’un dépôt Git privé.
Paramètre | Format | Notes |
---|---|---|
--repository-url |
ssh://user@server/repo[.git] ou user@server:repo[.git] | git@ peut remplacer user@ |
Utiliser un dépôt Git privé avec SSH et des clés fournies par l’utilisateur
Fournissez votre propre clé privée directement ou dans un fichier. La clé doit être au format PEM et se terminer par un saut de ligne (\n).
Ajoutez la clé publique associée au compte d’utilisateur dans votre fournisseur de services Git. Si la clé est ajoutée au dépôt au lieu du compte d’utilisateur, utilisez git@
à la place de user@
.
Pour plus d’informations, accédez à la section Appliquer une configuration à partir d’un dépôt Git privé.
Paramètre | Format | Notes |
---|---|---|
--repository-url |
ssh://user@server/repo[.git] ou user@server:repo[.git] | git@ peut remplacer user@ |
--ssh-private-key |
clé encodée en base64 au format PEM | Fournissez la clé directement |
--ssh-private-key-file |
chemin d’accès complet au fichier local | Indiquez le chemin d’accès complet au fichier local qui contient la clé au format PEM |
Utilisez un hôte Git privé avec des hôtes SSH et connus par l’utilisateur
L’opérateur Flux gère une liste d’hôtes Git courants dans son fichier d’hôtes connus pour authentifier le dépôt Git avant d’établir la connexion SSH. Si vous utilisez un dépôt Git peu courant ou votre propre hôte Git, vous pouvez fournir la clé d’hôte pour permettre à Flux d’identifier votre dépôt.
Tout comme les clés privées, vous pouvez fournir le contenu known_hosts directement ou dans un fichier. Quand vous fournissez votre propre contenu, utilisez les spécifications de format de contenu known_hosts ainsi que l’un des scénarios relatifs aux clés SSH ci-dessus.
Paramètre | Format | Notes |
---|---|---|
--repository-url |
ssh://user@server/repo[.git] ou user@server:repo[.git] | git@ peut remplacer user@ |
--ssh-known-hosts |
encodé en base64 | Fournissez directement le contenu des hôtes connus |
--ssh-known-hosts-file |
chemin d’accès complet au fichier local | Fournissez le contenu des hôtes connus dans un fichier local |
Utiliser un dépôt Git privé avec HTTPS
Paramètre | Format | Notes |
---|---|---|
--repository-url |
https://server/repo [.git] | HTTPS avec authentification de base |
--https-user |
brut ou codé en base64 | Nom d’utilisateur HTTPS |
--https-key |
brut ou codé en base64 | Mot de passe ou jeton d’accès personnel HTTPS |
Notes
- Le chart d’opérateur Helm version 1.2.0+ prend en charge l’authentification privée pour la version Helm HTTPS.
- La version Helm HTTPS n’est pas prise en charge pour les clusters managés AKS.
- Si vous avez besoin de Flux pour accéder au dépôt Git via votre proxy, vous devez mettre à jour les agents Azure Arc avec les paramètres du proxy. Pour plus d’informations, consultez Se connecter à l’aide d’un serveur proxy sortant.
Paramètres supplémentaires
Personnalisez la configuration avec les paramètres facultatifs suivants :
Paramètre | Description |
---|---|
--enable-helm-operator |
Commutateur pour activer la prise en charge des déploiements de charts Helm. |
--helm-operator-params |
Valeurs de chart pour l’opérateur Helm (si activé). Par exemple : --set helm.versions=v3 . |
--helm-operator-chart-version |
Version de chart pour l’opérateur Helm (si activé). Utilisez la version 1.2.0 et ultérieure. Valeur par défaut : '1.2.0'. |
--operator-namespace |
Nom de l’espace de noms de l’opérateur. Valeur par défaut : « default ». 23 caractères au maximum. |
--operator-params |
Paramètres de l’opérateur. Doit être entouré d’apostrophes. Par exemple : --operator-params='--git-readonly --sync-garbage-collection --git-branch=main' |
Options prises en charge dans --operator-params
:
Option | Description |
---|---|
--git-branch |
Branche du dépôt Git à utiliser pour les manifestes Kubernetes. Par défaut, « master ». Les référentiels plus récents ont une branche racine nommée main , auquel cas vous devez définir --git-branch=main . |
--git-path |
Chemin relatif dans le dépôt Git pour permettre à Flux de localiser les manifestes Kubernetes. |
--git-readonly |
Le dépôt Git est considéré comme étant en lecture seule. Flux ne tentera pas d’y accéder en écriture. |
--manifest-generation |
Si l’option est activée, Flux recherche .flux.yaml et exécute Kustomize ou d’autres générateurs de manifeste. |
--git-poll-interval |
Période à laquelle interroger le dépôt Git sur les nouveaux commits. La valeur par défaut est 5m (5 minutes). |
--sync-garbage-collection |
Si l’option est activée, Flux supprime les ressources qu’il a créées mais qui ne sont plus présentes dans Git. |
--git-label |
Étiquette permettant de suivre la progression de la synchronisation. Utilisée pour étiqueter la branche GIT. La valeur par défaut est flux-sync . |
--git-user |
Nom d’utilisateur pour la validation Git. |
--git-email |
Email à utiliser pour la validation Git. |
Si vous ne souhaitez pas que Flux écrive dans le dépôt, et si --git-user
ou --git-email
ne sont pas définis, --git-readonly
est automatiquement défini.
Pour plus d’informations, consultez la documentation relative au flux.
Notes
Valeurs Flux par défaut à synchroniser à partir de la branche master
du dépôt git. Toutefois, les dépôts git plus récents ont la branche racine qui s’appelle main
, donc vous devez définir --git-branch=main
dans --operator-params.
Conseil
Vous pouvez créer une configuration dans le portail Azure sous l’onglet GitOps de la ressource Kubernetes avec Azure Arc.
Valider la configuration
Utilisez Azure CLI pour vérifier si la configuration a été correctement créée.
az k8s-configuration flux show --name cluster-config --cluster-name AzureArcTest1 --resource-group AzureArcTest --cluster-type connectedClusters
La ressource de configuration va être mise à jour avec l’état de conformité, les messages et les informations de débogage.
{
"complianceStatus": {
"complianceState": "Installed",
"lastConfigApplied": "2020-12-10T18:26:52.801000+00:00",
"message": "...",
"messageLevel": "Information"
},
"configurationProtectedSettings": {},
"enableHelmOperator": false,
"helmOperatorProperties": {
"chartValues": "",
"chartVersion": ""
},
"id": "/subscriptions/<sub id>/resourceGroups/AzureArcTest/providers/Microsoft.Kubernetes/connectedClusters/AzureArcTest1/providers/Microsoft.KubernetesConfiguration/sourceControlConfigurations/cluster-config",
"name": "cluster-config",
"operatorInstanceName": "cluster-config",
"operatorNamespace": "cluster-config",
"operatorParams": "--git-readonly",
"operatorScope": "cluster",
"operatorType": "Flux",
"provisioningState": "Succeeded",
"repositoryPublicKey": "...",
"repositoryUrl": "git://github.com/Azure/arc-k8s-demo.git",
"resourceGroup": "AzureArcTest",
"sshKnownHostsContents": null,
"systemData": {
"createdAt": "2020-12-01T03:58:56.175674+00:00",
"createdBy": null,
"createdByType": null,
"lastModifiedAt": "2020-12-10T18:30:56.881219+00:00",
"lastModifiedBy": null,
"lastModifiedByType": null
},
"type": "Microsoft.KubernetesConfiguration/sourceControlConfigurations"
}
Quand une configuration est créée ou mise à jour, il se passe certaines choses :
- Le
config-agent
d’Azure Arc surveille Azure Resource Manager pour les configurations nouvelles ou mises à jour (Microsoft.KubernetesConfiguration/sourceControlConfigurations
) et remarque la nouvelle configurationPending
. - Le
config-agent
lit les propriétés de configuration et crée l’espace de noms de destination. - Le
controller-manager
Azure Arc crée un compte de service Kubernetes et le mappe à ClusterRoleBinding ou RoleBinding pour disposer des autorisations appropriées (étenduecluster
ounamespace
). Il déploie ensuite une instance deflux
. - Si vous utilisez l’option SSH avec les clés générées par le flux,
flux
génère une clé SSH et enregistre la clé publique. - Le
config-agent
signale l’état à la ressource de configuration dans Azure.
Pendant le processus de provisionnement, la ressource de configuration passe par quelques changements d’état. Surveillez la progression avec la commande az k8s-configuration flux show ci-dessus :
Modification du stade | Description |
---|---|
complianceStatus ->Pending |
Représente les états initial et en cours. |
complianceStatus ->Installed |
config-agent a correctement configuré le cluster et a déployé flux sans erreur. |
complianceStatus ->Failed |
config-agent a rencontré une erreur durant le déploiement de flux . Les détails sont fournis dans le corps de la réponse de complianceStatus.message . |
Appliquez une configuration à partir d’un référentiel Git privé
Si vous utilisez un dépôt Git privé, vous devez configurer la clé publique SSH dans votre dépôt. Soit vous la fournissez, soit Flux génère la clé publique SSH. Vous pouvez configurer la clé publique pour le dépôt Git spécifié ou pour l’utilisateur Git ayant accès au dépôt.
Obtenir vos propres adresses IP publiques
Si vous avez généré vos propres clés SSH, vous disposez déjà des clés privées et publiques.
Obtenir la clé publique à l’aide d’Azure CLI
Utilisez ce qui suit dans Azure CLI si Flux génère les clés.
az k8s-configuration flux show --resource-group <resource group name> --cluster-name <connected cluster name> --name <configuration name> --cluster-type connectedClusters --query 'repositoryPublicKey'
"ssh-rsa AAAAB3NzaC1yc2EAAAADAQABAREDACTED"
Obtenir la clé à partir du portail Azure
Effectuez les étapes suivantes dans le portail Azure si Flux génère les clés.
- Dans le portail Azure, accédez à la ressource de cluster connectée.
- Dans la page des ressources, sélectionnez « GitOps », puis consultez la liste des configurations pour ce cluster.
- Sélectionnez la configuration qui utilise le dépôt Git privé.
- Au bas de la fenêtre contextuelle qui s’ouvre, copiez la Repository public key (Clé publique du dépôt).
Ajouter une clé publique à l’aide de GitHub
Utilisez l’une des options suivantes :
Option 1 : Ajoutez la clé publique à votre compte d’utilisateur (s’applique à tous les dépôts de votre compte) :
- Ouvrez GitHub et cliquez sur l’icône de votre profil dans le coin supérieur droit de la page.
- Cliquez sur Paramètres.
- Cliquez sur Clés SSH et GPG.
- Cliquez sur Nouvelle clé SSH.
- Tapez un titre.
- Collez la clé publique sans les guillemets qui l’entourent.
- Cliquez sur Ajouter une clé SSH.
Option 2 : Ajoutez la clé publique en tant que clé de déploiement au dépôt Git (s’applique uniquement à ce dépôt) :
- Ouvrez GitHub et accédez à votre dépôt.
- Cliquez sur Paramètres.
- Cliquez sur Déployer les clés.
- Cliquez sur Ajouter une clé de déploiement.
- Tapez un titre.
- Activez l’option Autoriser l’accès en écriture.
- Collez la clé publique sans les guillemets qui l’entourent.
- Cliquez sur Ajouter une clé.
Ajouter une clé publique à l’aide d’un référentiel Azure DevOps
Pour ajouter la clé à vos clés SSH, procédez comme suit :
- Sous Paramètres utilisateur en haut à droite (à côté de l’image de profil), cliquez sur Clés publiques SSH.
- Sélectionnez + Nouvelle clé.
- Tapez un nom.
- Collez la clé publique sans les guillemets qui l’entourent.
- Cliquez sur Add.
Valider la configuration de Kubernetes
Après que config-agent
a installé l’instance flux
, les ressources se trouvant dans le référentiel Git doivent commencer à circuler vers le cluster. Vérifiez que les espaces de noms, les déploiements et les ressources ont été créés à l’aide de la commande suivante :
kubectl get ns --show-labels
NAME STATUS AGE LABELS
azure-arc Active 24h <none>
cluster-config Active 177m <none>
default Active 29h <none>
itops Active 177m fluxcd.io/sync-gc-mark=sha256.9oYk8yEsRwWkR09n8eJCRNafckASgghAsUWgXWEQ9es,name=itops
kube-node-lease Active 29h <none>
kube-public Active 29h <none>
kube-system Active 29h <none>
team-a Active 177m fluxcd.io/sync-gc-mark=sha256.CS5boSi8kg_vyxfAeu7Das5harSy1i0gc2fodD7YDqA,name=team-a
team-b Active 177m fluxcd.io/sync-gc-mark=sha256.vF36thDIFnDDI2VEttBp5jgdxvEuaLmm7yT_cuA2UEw,name=team-b
Nous pouvons voir que les espaces de noms team-a
, team-b
, itops
et cluster-config
ont été créés.
L’opérateur flux
a été déployé sur l’espace de noms cluster-config
, comme indiqué par la ressource de configuration :
kubectl -n cluster-config get deploy -o wide
NAME READY UP-TO-DATE AVAILABLE AGE CONTAINERS IMAGES SELECTOR
cluster-config 1/1 1 1 3h flux docker.io/fluxcd/flux:1.16.0 instanceName=cluster-config,name=flux
memcached 1/1 1 1 3h memcached memcached:1.5.15 name=memcached
Exploration approfondie
Vous pouvez explorer les autres ressources déployées dans le référentiel de configuration en utilisant ce qui suit :
kubectl -n team-a get cm -o yaml
kubectl -n itops get all
Nettoyer les ressources
Supprimez une configuration à l’aide de l’interface Azure CLI ou du portail Azure. Une fois la commande de suppression exécutée, la ressource de configuration est supprimée immédiatement dans Azure. La suppression complète des objets associés du cluster doit se produire dans les 10 minutes. Si la configuration est à l’état d’échec quand elle est supprimée, la suppression complète des objets associés peut prendre jusqu’à une heure.
Quand une configuration ayant l’étendue namespace
est supprimée, l’espace de noms n’est pas supprimé par Azure Arc pour éviter l’arrêt des charges de travail existantes. Si nécessaire, vous pouvez supprimer cet espace de noms manuellement à l’aide de kubectl
.
az k8s-configuration flux delete --name cluster-config --cluster-name AzureArcTest1 --resource-group AzureArcTest --cluster-type connectedClusters
Notes
Les changements apportés au cluster et qui résultent des déploiements effectués à partir du dépôt Git suivi ne sont pas supprimés quand la configuration est supprimée.
Important
Ce tutoriel s’applique à GitOps avec Flux v1. GitOps avec Flux v2 est désormais disponible pour les clusters AKS (Azure Kubernetes Service) et Kubernetes avec Azure Arc. Accédez au tutoriel pour GitOps avec Flux v2. Nous vous recommandons d’effectuer une migration vers Flux v2 dès que possible.
La prise en charge des ressources de configuration du cluster basées sur Flux v1, créées avant le 1er janvier 2024, s’achève le 24 mai 2025. À compter du 1er janvier 2024, vous ne pouvez plus créer de ressources de configuration de cluster basées sur Flux v1.
Étapes suivantes
Passez au tutoriel suivant pour apprendre à implémenter CI/CD avec GitOps.