Créer et associer des comptes de facturation

Les environnements isolés Google Distributed Cloud (GDC) nécessitent un compte de facturation pour suivre les coûts des projets et des organisations. Si vous n'associez pas de compte de facturation à une organisation ou à un projet, vous perdrez les données de coûts associées à la ressource.

Pour facturer l'utilisation des services au client, tous les comptes de facturation d'une organisation utilisent une seule et même grille tarifaire.

Avant de commencer

Demandez à l'administrateur IAM de votre organisation de vous accorder les rôles requis suivants. Ces rôles sont associés à l'espace de noms du projet pour la facturation au niveau du projet, ou à l'espace de noms de la plate-forme pour la facturation au niveau de l'organisation :

  • Administrateur de compte de facturation de l'organisation globale : créez, gérez et associez la ressource BillingAccount. Demandez à l'administrateur IAM de votre organisation de vous attribuer le rôle organization-billing-account-admin.

  • Utilisateur du compte de facturation de l'organisation globale : lecture, liste et association de la ressource BillingAccount. Demandez à l'administrateur IAM de votre organisation de vous attribuer le rôle organization-billing-account-user.

  • Administrateur de compte de facturation de l'organisation globale : lecture, liste, création et mise à jour de la ressource BillingAccountBinding. Demandez à l'administrateur IAM de votre organisation de vous attribuer le rôle organization-billing-manager.

Obtenir le fichier kubeconfig

Pour exécuter des commandes sur le serveur de l'API mondiale, assurez-vous de disposer des ressources suivantes :

  1. Connectez-vous et générez le fichier kubeconfig pour le serveur d'API mondial si vous n'en avez pas.

  2. Utilisez le chemin d'accès au fichier kubeconfig du serveur d'API mondial pour remplacer GLOBAL_API_SERVER_KUBECONFIG dans ces instructions.

Créer un compte de facturation

Un compte de facturation est identifié de manière unique par son name et son namespace. Pour créer un compte de facturation, utilisez une ressource personnalisée pour établir name et namespace :

  1. Créez un fichier YAML, puis ajoutez la ressource personnalisée BillingAccount et le contenu suivant :

    apiVersion: billing.global.gdc.goog/v1
    kind: BillingAccount
    metadata:
      namespace: platform
      name: BIL_ACCOUNT_NAME
    spec:
      displayName: BIL_DISPLAY_NAME
      paymentSystemConfig:
        cloudBillingConfig:
          accountID: "012345-6789AB-CDEF01"
    

    Remplacez les variables suivantes :

    • BIL_ACCOUNT_NAME : nom du compte de facturation. Exemple :test-billing-account
    • BIL_DISPLAY_NAME : nom à afficher du compte de facturation. Exemple :"Test Billing Account"
  2. Vérifiez votre type de configuration de paiement. Les comptes de facturation Distributed Cloud doivent disposer de l'une des configurations de paiement suivantes :

    • cloudBillingConfig : configuration de paiement par défaut. Cette configuration stocke un ID de compte de facturation Cloud.

    • customConfig : configuration personnalisée permettant aux partenaires de stocker leur configuration de paiement pour facturer l'organisation. customConfig accepte un dictionnaire de chaînes clé/valeur, avec une clé obligatoire payment-config-type.

    Les exemples suivants montrent des extraits de fichier YAML BillingAccount pour différentes configurations de paiement :

    cloudBillingConfig

    spec:
      paymentSystemConfig:
        cloudBillingConfig:
          accountID: CLOUD_BILLING_ACCOUNT_ID
    

    Remplacez CLOUD_BILLING_ACCOUNT_ID par l'ID de votre compte de facturationGoogle Cloud .

    customConfig

    spec:
     paymentSystemConfig:
       customConfig:
          "payment-config-type": PAYMENT_CONFIG_TYPE
    

    Remplacez PAYMENT_CONFIG_TYPE par le type de configuration de paiement de votre choix pour votre configuration de facturation personnalisée.

    Si vous ne disposez pas des informations de configuration customConfig de votre organisation, saisissez les informations suivantes :

    spec:
     paymentSystemConfig:
       customConfig:
          "payment-config-type": "N/A"
    

    Le fichier YAML suivant montre une ressource BillingAccount complète avec la configuration cloudBillingConfig :

    apiVersion: billing.global.gdc.goog/v1
    kind: BillingAccount
    metadata:
      namespace: platform
      name: test-billing-account
    spec:
      displayName: "Test Billing Account"
      paymentSystemConfig:
        cloudBillingConfig:
          accountID: "012345-6789AB-CDEF01"
    
  3. Enregistrez le fichier YAML. Exécutez la CLI kubectl pour appliquer la ressource dans le serveur d'API Global :

    kubectl --kubeconfig GLOBAL_API_SERVER_KUBECONFIG apply -f billingaccount.yaml
    

    Remplacez GLOBAL_API_SERVER_KUBECONFIG par le fichier kubeconfig du serveur d'API global.

Cette section fournit une série d'étapes pour associer une organisation ou un projet à un BillingAccount.

Pour associer un projet à un BillingAccount, procédez comme suit :

  1. Ajoutez le contenu suivant au fichier : billingaccountbinding.yaml :

    • Dans la section billingAccountRef, remplissez le champ name avec le contenu du champ name de l'BillingAccount que vous souhaitez associer.
    • Dans la section metadata, remplissez le champ namespace avec le contenu du champ identique dans la ressource BillingAccount.

    Dans cet exemple, l'espace de noms du projet est PROJECT_NAME :

    apiVersion: billing.global.gdc.goog/v1
    kind: BillingAccountBinding
    metadata:
      name: billing
      namespace: PROJECT_NAME
    spec:
      billingAccountRef:
        name: BIL_ACCOUNT_NAME
        namespace: platform
    

    Remplacez PROJECT_NAME par le nom du projet associé au compte de facturation.

  2. Exécutez la commande kubectl suivante pour appliquer le fichier billingaccountbinding.yaml :

    kubectl --kubeconfig GLOBAL_API_SERVER_KUBECONFIG apply -f billingaccountbinding.yaml
    
  3. Vérifiez l'état de BillingAccountBinding et assurez-vous qu'il n'y a pas d'erreurs :

    kubectl --kubeconfig GLOBAL_API_SERVER_KUBECONFIG describe billingaccountbinding billing -n PROJECT_NAME
    

    Remplacez PROJECT_NAME par le nom du projet associé au compte de facturation.

Pour associer une organisation à un BillingAccount, procédez comme suit :

  1. Ajoutez le contenu suivant au fichier YAML billingaccountbinding.yaml :

    • Dans la section billingAccountRef, remplissez le champ name avec le contenu du champ name de l'BillingAccount que vous souhaitez associer.
    • Dans la section metadata, remplissez le champ namespace avec le contenu du champ identique dans la ressource BillingAccount. Dans cet exemple, l'espace de noms de l'organisation est platform :
    apiVersion: billing.global.gdc.goog/v1
    kind: BillingAccountBinding
    metadata:
      name: billing
      namespace: platform
    spec:
      billingAccountRef:
        name: BIL_ACCOUNT_NAME
        namespace: platform
    
  2. Exécutez la commande kubectl suivante pour appliquer le fichier billingaccountbinding.yaml :

    kubectl --kubeconfig GLOBAL_API_SERVER_KUBECONFIG apply -f billingaccountbinding.yaml
    
  3. Vérifiez l'état de BillingAccountBinding et assurez-vous qu'il n'y a pas d'erreurs :

    kubectl --kubeconfig GLOBAL_API_SERVER_KUBECONFIG describe billingaccountbinding billing -n platform
    

Lister les liaisons de compte de facturation

Affichez la liste de toutes les ressources BillingAccountBinding déployées et leur état actuel dans tous les espaces de noms de l'organisation :

  kubectl --kubeconfig GLOBAL_API_SERVER_KUBECONFIG get billingaccountbinding -A -o 'custom-columns=NAME:metadata.name,NAMESPACE:metadata.namespace,BillingAccountName:spec.billingAccountRef.name,STATUS:status.conditions[0].status'

Cette commande affiche les NAME, NAMESPACE, BillingAccountName et STATUS de chaque BillingAccountBinding. Le champ STATUS indique si l'association est active ou s'il y a des erreurs.

Hiérarchie et comportement des comptes de facturation

Lorsque vous associez des comptes de facturation à des organisations et des projets, la hiérarchie et les comportements suivants s'appliquent :

  • L'association au niveau du projet est prioritaire : si un projet spécifique, tel que project-A, est explicitement associé à un BillingAccount (tel que billing-account-1), tous les coûts de project-A sont facturés exclusivement à billing-account-1. Cette association au niveau du projet reste valide quels que soient les paramètres de compte de facturation au niveau de l'organisation.

  • Association au niveau de l'organisation pour les projets non associés : si votre organisation est associée à un BillingAccount (tel que billing-account-0), tous les projets de cette organisation qui n'ont pas leur propre BillingAccountBinding explicite sont automatiquement associés à billing-account-0 et facturés à ce compte. Cette association prend généralement effet au bout de 15 minutes environ.

  • Modification des comptes de facturation d'une organisation : si le compte de facturation associé à une organisation change (par exemple, de billing-account-0 à billing-account-new), les projets qui héritaient auparavant de billing-account-0 ne passent pas automatiquement à billing-account-new. Ces projets restent associés à billing-account-0. Si vous souhaitez qu'ils utilisent billing-account-new, vous devez mettre à jour manuellement leur compte de facturation.

Modifier le compte de facturation associé

Dans Distributed Cloud, vous ne pouvez pas supprimer de compte de facturation. Si vous devez modifier votre configuration de facturation, vous devez modifier le compte de facturation associé à une organisation ou à un projet en modifiant le BillingAccountBinding. Voici quelques exemples de scénarios pour ce cas d'utilisation :

  • Les règles comptables de votre entreprise exigent que vous répartissiez les frais associés aux charges de travail de développement et de production dans des comptes distincts.
  • Vous créez un compte de facturation pour facturer un contrat client sur une période d'un an. Lorsque le contrat expire, vous devez facturer la période restante qui dépasse un an.

Modifier le compte de facturation associé à un projet

Pour modifier le compte de facturation associé à un projet :

  1. Créez une BillingAccount pour l'associer au projet. Ce compte remplace l'ancien.

  2. Localisez le fichier YAML de la ressource BillingAccountBinding dans l'espace de noms du projet pour voir quel compte de facturation est associé :

    kubectl --kubeconfig GLOBAL_API_SERVER_KUBECONFIG describe billingaccountbinding billing -n PROJECT_NAME
    
  3. Modifiez BillingAccountBinding pour l'associer au nouveau compte de facturation. Dans la section billingAccountRef, renseignez le champ name avec le nouveau nom BillingAccount créé à l'étape 1 de cette section.

    kubectl --kubeconfig GLOBAL_API_SERVER_KUBECONFIG edit billingaccountbinding billing -n PROJECT_NAME
    
  4. Après avoir effectué les modifications, assurez-vous que le compte de facturation a été correctement mis à jour :

    kubectl --kubeconfig GLOBAL_API_SERVER_KUBECONFIG describe billingaccountbinding billing -n PROJECT_NAME
    

L'exemple suivant montre un fichier YAML BillingAccountBinding avec le compte expired-billing-account associé au projet project-one :

  apiVersion: billing.global.gdc.goog/v1
  kind: BillingAccountBinding
  metadata:
    # The name of a BillingAccountBinding will typically always be `billing`.
    name: billing
    # This is the project.
    namespace: project-one
  spec:
    billingAccountRef:
      # This is an example of a BillingAccount that has expired.
      name: expired-billing-account
      namespace: platform

L'exemple suivant montre le fichier YAML BillingAccountBinding de l'exemple précédent, modifié pour associer un nouveau compte appelé new billing account :

  apiVersion: billing.global.gdc.goog/v1
  kind: BillingAccountBinding
  metadata:
    name: billing
    # This is the project.
    namespace: project-one
  spec:
    billingAccountRef:
      # This is the example of the new BillingAccount.
      name: new-billing-account
      namespace: platform

Modifier le compte de facturation associé à une organisation

Pour modifier le compte de facturation associé à une organisation :

  1. Créez un BillingAccount pour l'associer à l'organisation. Ce compte remplace l'ancien.

  2. Localisez le fichier YAML de la ressource BillingAccountBinding dans l'espace de noms platform pour voir quel compte de facturation est associé :

    kubectl --kubeconfig GLOBAL_API_SERVER_KUBECONFIG describe billingaccountbinding billing -n platform
    
  3. Modifiez BillingAccountBinding pour l'associer au nouveau compte de facturation. Dans la section billingAccountRef, renseignez le champ name avec le nouveau nom BillingAccount créé à l'étape 1.

    kubectl --kubeconfig GLOBAL_API_SERVER_KUBECONFIG edit billingaccountbinding billing -n platform
    
  4. Après avoir effectué les modifications, assurez-vous que le compte de facturation a été correctement mis à jour :

    kubectl --kubeconfig GLOBAL_API_SERVER_KUBECONFIG describe billingaccountbinding billing -n platform