Zugriff gewähren und widerrufen

Jedes Subjekt – ein Nutzer oder eine Gruppe – durchläuft einen zweistufigen Prozess, um Zugriff auf den Management API-Server und den Kubernetes-Cluster zu erhalten:

  • Zugriff auf den Management API-Server:Gewähren Sie einem Eigentümer mit Berechtigungen auf dem Management API-Server mithilfe von ClusterRoleBinding oder RoleBinding Zugriff auf eine vordefinierte ClusterRole.

  • Kubernetes-Clusterzugriff:Gewähren Sie Namespace-spezifischen Zugriff oder clusterweiten Zugriff.

    • Für namespace-spezifischen Zugriff:Wenn Sie Zugriff auf den Namespace eines bestimmten Projekts im Cluster gewähren möchten, erstellen Sie eine ProjectRole und die entsprechende ProjectRoleBinding. Bei diesem Vorgang werden ein Kubernetes-Role und ein Kubernetes-RoleBinding an ein Kubernetes-Namespace im Cluster weitergegeben, das dem Project entspricht, dem das ProjectRole und das ProjectRoleBinding zugeordnet sind.

    • Für clusterweiten Zugriff:Wenn Sie Zugriff auf alle Namespaces im Cluster gewähren möchten, erstellen Sie eine OrganizationRole und die entsprechende OrganizationRoleBinding. Bei diesem Vorgang werden ein Kubernetes-ClusterRole und ein ClusterRoleBinding im gesamten Kubernetes-Cluster weitergegeben.

Diese Seite richtet sich an Nutzer in der Gruppe der Plattformadministratoren, die Berechtigungen in ihrer Organisation verwalten.

Sowohl der Organisations-IAM-Administrator als auch der Projekt-IAM-Administrator können weitere Projektrollen und Projektrollenbindungen erstellen, um zusätzliche projektspezifische Berechtigungen zu gewähren. Organisations-IAM-Administratoren können jedoch Projektrollen und Projektrollenzuweisungen für jedes Projekt erstellen. Projekt-IAM-Administratoren können hingegen nur Projektrollen und Projektrollenzuweisungen für Projekte erstellen, auf die sie Zugriff haben.

Hinweis

Bevor Sie Rollenbindungen verwalten oder den Zugriff widerrufen können, müssen Sie die erforderlichen Berechtigungen anfordern und Ihre Umgebung vorbereiten. Die erforderlichen Rollen hängen davon ab, ob Sie Rollenbindungen verwalten oder den Nutzerzugriff widerrufen.

IAM-Rollen anfordern

Wenden Sie sich an den IAM-Administrator Ihrer Organisation, um die Rollen anzufordern, die Sie für die Ausführung der Aufgaben benötigen:

  • Organisations-IAM-Administrator (organization-iam-admin): Erstellen, Aktualisieren und Löschen von Rollenbindungen auf Organisations- und Projektebene.
  • Org Session Admin (org-session-admin): Aktive Sitzungen und den Zugriff eines Nutzers in einer bestimmten Zone widerrufen.

Umgebung vorbereiten

Führen Sie die folgenden Schritte aus, um die Befehlszeilentools zum Verwalten von Rollenbindungen oder zum Widerrufen des Zugriffs zu verwenden.

Rollenbindungen einrichten

Sie können Rollenbindungen einrichten, die Teammitgliedern Zugriff auf Ressourcen auf Organisations- oder Projektebene gewähren.

Bitten Sie Ihren Organisation-IAM-Administrator, Ihnen die Rolle „Organisation IAM Admin“ zuzuweisen, damit Sie die Berechtigungen erhalten, die Sie zum Einrichten von Rollenbindungen benötigen.

So weisen Sie einem autorisierten Mitglied eine Rolle zu:

Console

  1. Melden Sie sich in der GDC-Konsole an.
  2. Klicken Sie auf Projekt auswählen, um eine Organisation oder ein Projekt auszuwählen.
    • Wenn Sie Rollenbindungen für eine Organisation einrichten möchten, wählen Sie eine Organisation aus.
    • Wählen Sie ein Projekt aus, um Rollenbindungen für ein Projekt einzurichten.
  3. Klicken Sie im Navigationsmenü auf Identität und Zugriff > Zugriff.
  4. Klicken Sie auf Mitglied hinzufügen.
  5. Wählen Sie in der Liste Identitätsanbieter einen Identitätsanbieter aus.
  6. Wählen Sie aus, ob Sie einzelne Nutzer oder Gruppen hinzufügen möchten.
  7. Geben Sie im Feld Nutzername oder Gruppenalias den Nutzernamen, die E-Mail-Adresse oder den Alias ein.
  8. Wählen Sie in der Liste Rolle die Rolle aus, die Sie dem Nutzer oder der Gruppe zuweisen möchten, z. B. Organisationsbetrachter auf Organisationsebene oder Projektersteller auf Projektebene.
  9. Klicken Sie auf Hinzufügen.

Das Mitglied wird in der Liste Autorisiertes Mitglied angezeigt.

gdcloud

  1. Prüfen Sie, ob die gcloud CLI installiert ist.

  2. Melden Sie sich mit dem Befehl gdcloud auth login an, um sich bei Ihrem Identitätsanbieter zu authentifizieren. Weitere Informationen finden Sie unter gdcloud CLI-Authentifizierung.

  3. Rollenbindungen einrichten

    • Rollenbindungen für eine Organisation einrichten:

      gdcloud organizations add-iam-policy-binding root \
        --member=USER_ACCOUNT \
        --role=ROLE_TYPE/ROLE
      

      Ersetzen Sie die folgenden Variablen:

      • USER_ACCOUNT: Das Nutzerkonto, dem Sie die Rolle zuweisen möchten. Für dieses Flag kann entweder eine Nutzer-E-Mail-Adresse mit dem Identitätsanbieterpräfix (user:idpprefix-user@example.com) oder ein Dienstkontoname mit dem Dienstkontoprojekt (serviceAccount:projectName:serviceAccountName) angegeben werden.
      • ROLE_TYPE: die ClusterRole, Role oder OrganizationRole, für die Sie die Rollenbindung einrichten.
      • ROLE: Der Name der vordefinierten oder benutzerdefinierten Rolle, die Sie dem Nutzer zuweisen möchten, z. B. project-creator.
    • Rollenbindungen für ein Projekt einrichten:

      gdcloud projects add-iam-policy-binding PROJECT \
        --member=USER_ACCOUNT \
        --role=ROLE_TYPE/ROLE
      

      Ersetzen Sie die folgenden Variablen:

      • PROJECT: der Name des Projekts, für das Sie die Rollenbindung einrichten.
      • USER_ACCOUNT: Das Nutzerkonto, dem Sie die Rolle zuweisen möchten. Für dieses Flag kann entweder eine Nutzer-E-Mail-Adresse mit dem Identitätsanbieterpräfix (user:idpprefix-user@example.com) oder ein Dienstkontoname mit dem Dienstkontoprojekt (serviceAccount:projectName:serviceAccountName) angegeben werden.
      • ROLE_TYPE: die Role oder ProjectRole, für die Sie die Rollenbindung einrichten.
      • ROLE: Der Name der vordefinierten oder benutzerdefinierten Rolle, die Sie dem Nutzer zuweisen möchten, z. B. project-viewer.

API

  1. Exportieren Sie die Nutzeranmeldedaten, die Sie verwenden:

    export YOUR_IAM_ADMIN_KUBECONFIG=YOUR_IAM_ADMIN_KUBECONFIG
    
  2. Exportieren Sie das Nutzerkonto, dem Sie die Rolle zuweisen möchten, einschließlich des Identitätsanbieterpräfixes (z. B. idpprefix-paul@example.com):

    export USERNAME=IDP_PREFIX-USER_EMAIL
    
  3. Exportieren Sie den Namen der Rolle, die der Nutzer benötigt, z. B. project-creator. Weitere Informationen zur Rolle finden Sie unter Rollendefinitionen.

    export ROLE_NAME=ROLE_NAME
    
  4. Weisen Sie einem Nutzer eine ClusterRole, Role, ProjectRole oder OrganizationRole zu:

    • So weisen Sie einen Nutzer einer ClusterRole zu:

      kubectl create --kubeconfig ${YOUR_IAM_ADMIN_KUBECONFIG} \
      clusterrolebinding ${USERNAME}-${ROLE_NAME}-binding \
      --clusterrole=${ROLE_NAME} --user=${USERNAME}
      

      Wenn für ein ClusterRole anstelle eines ClusterRoleBinding ein RoleBinding erforderlich ist, finden Sie in den Rollendefinitionen den erforderlichen Bindungstyp für die Rolle. Erstellen Sie stattdessen eine RoleBinding im Namespace gpc-system:

      kubectl create --kubeconfig ${YOUR_IAM_ADMIN_KUBECONFIG} \
      rolebinding ${USERNAME}-${ROLE_NAME}-binding \
      --clusterrole=${ROLE_NAME} --user=${USERNAME} --namespace=gpc-system
      
    • So weisen Sie einen Nutzer einer Role zu:

      1. Exportieren Sie den Namespace, in dem die Bindung erstellt werden muss:

        export BINDING_NAMESPACE=BINDING_NAMESPACE
        
      2. Führen Sie die folgenden Befehle aus, um eine RoleBinding zu erstellen:

        kubectl create --kubeconfig ${YOUR_IAM_ADMIN_KUBECONFIG} \
        rolebinding ${USERNAME}-${ROLE_NAME}-binding \
        --role=${ROLE_NAME} --user=${USERNAME} --namespace=${BINDING_NAMESPACE}
        
    • So weisen Sie einen Nutzer einer ProjectRole zu:

      1. projectrolebinding.yaml-Datei erstellen:

        apiVersion: resourcemanager.gdc.goog/v1
        kind: ProjectRoleBinding
        metadata:
          name: BINDING_NAME
          namespace: PROJECT_NAME
        spec:
          roleRef:
            apiGroup: resourcemanager.gdc.goog
            kind: ProjectRole
            name: ROLE_NAME
          subjects:
          - apiGroup: rbac.authorization.k8s.io
            kind: USER_KIND
            name: USERNAME
        

        Ersetzen Sie Folgendes:

        • BINDING_NAME: Ein Name für die Bindung, den der Nutzer anpassen kann (z. B. user-project-creator-binding).
        • PROJECT_NAME: Der Name des Projekts, dem Sie die Rolle zuweisen.
        • ROLE_NAME: Der Name der ProjectRole, die Sie dem Nutzer zuweisen.
        • USER_KIND: Die Art des Nutzers, die User, Group oder ServiceAccount sein kann.
        • USERNAME: Die E-Mail-Adresse des Nutzers, dem Sie die Rolle zuweisen, einschließlich des Identitätsanbieter-Präfixes (z. B. idpprefix-paul@example.com). Diese muss mit dem exportierten USERNAME übereinstimmen.
      2. Wenden Sie die Datei projectrolebinding.yaml an:

        kubectl create -f projectrolebinding.yaml
        
    • So weisen Sie einen Nutzer einem OrganizationRole zu:

      1. Erstellen Sie eine organizationrolebinding.yaml-Datei:

        apiVersion: resourcemanager.gdc.goog/v1
        kind: OrganizationRoleBinding
        metadata:
          name: BINDING_NAME
          namespace: gpc-system
        spec:
          roleRef:
            apiGroup: resourcemanager.gdc.goog
            kind: OrganizationRole
            name: ROLE_NAME
          subjects:
          - apiGroup: rbac.authorization.k8s.io
            kind: USER_KIND
            name: USERNAME
        

        Ersetzen Sie Folgendes:

        • BINDING_NAME: Ein Name für die Bindung, den der Nutzer anpassen kann (z. B. user-organization-creator-binding).
        • ROLE_NAME: Der Name der OrganizationRole, die Sie dem Nutzer zuweisen.
        • USER_KIND: Die Art des Nutzers, die User, Group oder ServiceAccount sein kann.
        • USERNAME: Die E-Mail-Adresse des Nutzers, dem Sie die Rolle zuweisen, einschließlich des Identitätsanbieter-Präfixes (z. B. idpprefix-paul@example.com). Diese muss mit dem exportierten USERNAME übereinstimmen.
      2. Wenden Sie die organizationrolebinding.yaml-YAML-Datei an:

        kubectl create -f organizationrolebinding.yaml
        

Rollenbindungen entfernen

Wenn der Zugriff nicht mehr erforderlich ist, entfernen Sie ein Mitglied und die zugehörigen Rollen, Berechtigungen und den Zugriff.

So entfernen Sie Mitglieder:

Console

  1. Melden Sie sich in der GDC-Konsole an.
  2. Klicken Sie im Navigationsmenü auf Identität und Zugriff > Zugriff.
  3. Wählen Sie in der Liste Autorisierte Mitglieder ein Mitglied aus.
  4. Klicken Sie auf Mitglied entfernen.
  5. Wenn Sie dazu aufgefordert werden, klicken Sie zur Bestätigung auf Mitglied entfernen.

gdcloud

  1. Prüfen Sie, ob die gcloud CLI installiert ist.

  2. Melden Sie sich mit dem Befehl gdcloud auth login an, um sich bei Ihrem Identitätsanbieter zu authentifizieren. Weitere Informationen finden Sie unter gdcloud CLI-Authentifizierung.

  3. Entfernen Sie Rollenbindungen.

    • So entfernen Sie Rollenbindungen für eine Organisation:

      gdcloud organizations remove-iam-policy-binding root \
        --member=USER_ACCOUNT \
        --role=ROLE_TYPE/ROLE
      

      Ersetzen Sie die folgenden Variablen:

      • USER_ACCOUNT: Das Nutzerkonto, aus dem Sie die Rolle entfernen möchten. Für dieses Flag kann entweder eine Nutzer-E-Mail-Adresse mit dem Identitätsanbieterpräfix (user:idpprefix-user@example.com) oder ein Dienstkontoname mit dem Dienstkontoprojekt (serviceAccount:projectName:serviceAccountName) angegeben werden.
      • ROLE_TYPE: Die ClusterRole, Role oder OrganizationRole, für die Sie die Rollenbindung entfernen.
      • ROLE: Der Name der vordefinierten oder benutzerdefinierten Rolle, die Sie aus dem Nutzerkonto entfernen möchten, z. B. project-creator.
    • Rollenbindungen für ein Projekt entfernen:

      gdcloud projects remove-iam-policy-binding PROJECT \
        --member=USER_ACCOUNT \
        --role=ROLE_TYPE/ROLE
      

      Ersetzen Sie die folgenden Variablen:

      • PROJECT: der Name des Projekts, aus dem Sie die Rollenbindung entfernen.
      • USER_ACCOUNT: Das Nutzerkonto, aus dem Sie die Rolle entfernen möchten. Für dieses Flag kann entweder eine Nutzer-E-Mail-Adresse mit dem Identitätsanbieterpräfix (user:idpprefix-user@example.com) oder ein Dienstkontoname mit dem Dienstkontoprojekt (serviceAccount:projectName:serviceAccountName) angegeben werden.
      • ROLE_TYPE: die Role oder ProjectRole, für die Sie die Rollenbindung entfernen.
      • ROLE: Der Name der vordefinierten oder benutzerdefinierten Rolle, die Sie aus dem Nutzerkonto entfernen möchten, z. B. project-viewer.

API

  1. Exportieren Sie die Nutzeranmeldedaten, die Sie verwenden:

    export YOUR_IAM_ADMIN_KUBECONFIG=YOUR_IAM_ADMIN_KUBECONFIG
    
  2. Exportieren Sie das Nutzerkonto, aus dem Sie die Rolle entfernen möchten, einschließlich des Präfixes des Identitätsanbieters (z. B. idpprefix-paul@example.com):

    export USERNAME=IDP_PREFIX-USER_EMAIL
    
  3. Exportieren Sie den Namespace, aus dem die Bindung entfernt wird:

    export BINDING_NAMESPACE=BINDING_NAMESPACE
    
  4. Löschen Sie die ClusterRoleBinding, RoleBinding, ProjectRoleBinding oder OrganizationRoleBinding, um die dem Nutzerkonto erteilte Berechtigung zu widerrufen:

    • So entfernen Sie die ClusterRoleBinding aus einem Nutzerkonto:

      kubectl --kubeconfig ${YOUR_IAM_ADMIN_KUBECONFIG} \
      delete clusterrolebinding ${USERNAME}-pa
      
    • So entfernen Sie die RoleBinding aus einem Nutzerkonto:

      kubectl --kubeconfig ${YOUR_IAM_ADMIN_KUBECONFIG} \
      delete rolebinding ${USERNAME}-pa \
      --namespace=${BINDING_NAMESPACE}
      
    • So entfernen Sie die ProjectRoleBinding aus einem Nutzerkonto:

      kubectl --kubeconfig ${YOUR_IAM_ADMIN_KUBECONFIG} \
      delete projectrolebinding ${USERNAME}-pa \
      --namespace=${BINDING_NAMESPACE}
      
    • So entfernen Sie die OrganizationRoleBinding aus einem Nutzerkonto:

      kubectl --kubeconfig ${YOUR_IAM_ADMIN_KUBECONFIG} \
      delete organizationrolebinding ${USERNAME}-pa \
      --namespace=gpc-system
      

Nutzerzugriff widerrufen

Wenn ein Mitglied Ihre Organisation oder Ihr Team verlässt, können Sie den Zugriff auf die Air-Gap-Appliance von Google Distributed Cloud (GDC) widerrufen. Wenn Sie den Zugriff eines Nutzers widerrufen, wird er von der GDC-Appliance mit Air-Gap abgemeldet und seine Rollen und Berechtigungen werden entfernt. Sie können auch die Aktivitäten und Sitzungen des Nutzers nach Start- und Endzeit auflisten.

So widerrufen Sie den Zugriff eines Nutzers:

  1. Rufen Sie die Berechtigungen ab, die Sie zum Widerrufen von Nutzern benötigen. Bitten Sie Ihren IAM-Administrator der Organisation, Ihnen die Rolle „Org Session Admin“ (org-session-admin) zuzuweisen.

  2. Zugriff des Nutzers widerrufen:

    gdcloud admin auth revoke --accounts USER_EMAIL
    

    Ersetzen Sie USER_EMAIL durch die E-Mail-Adresse des Nutzers, dessen Zugriff Sie widerrufen möchten.

    Nach der Ausführung des Befehls wird eine Ausgabe angezeigt, die in etwa so aussieht. In diesem Beispiel wird der Zugriff für den Nutzer ariel@example.com widerrufen:

    Success: NUMBER of sessions revoked for user ariel@example.com
    

    In diesem Beispiel bezieht sich die Variable NUMBER auf die Anzahl der aktiven Sitzungen des Nutzers.

  3. Prüfen Sie, ob Sie den Zugriff des Nutzers widerrufen haben, indem Sie den Befehl gdcloud admin auth revoke noch einmal ausführen. Bei Erfolg wird Folgendes angezeigt:

    No sessions found for account: ariel@example.com
    

Alle widerrufenen Nutzer auflisten

So sehen Sie alle Nutzer, deren Zugriff widerrufen wurde, sowie ihre Aktivitäten und Sitzungen:

  • Alle widerrufenen Nutzer mit Start- und Endzeit auflisten:

    gdcloud admin auth list --format="csv(ACCOUNT, IDENTITY_PROVIDER, CREATION_TIME, EXPIRATION_TIME)"
    

    Bei erfolgreicher Ausführung erhalten Sie eine Ausgabe ähnlich der folgenden:

    account,identity_provider,creation_time,expiration_time
    ariel@example.com,example-idp,2023-02-15 22:10:52,2023-02-15 23:10:52