Panoramica
Google Distributed Cloud (solo software) per VMware supporta la registrazione degli audit sia a livello di API Google Cloud sia a livello di cluster Kubernetes. Questo documento fornisce informazioni sull'audit logging del cluster Kubernetes. Per informazioni sul logging degli audit delle API Google Cloud, consulta Informazioni sugli audit log delle API Cloud.
Google Distributed Cloud utilizza Kubernetes Audit Logging, che mantiene un record cronologico delle chiamate effettuate al server dell'API Kubernetes di un cluster. Gli audit log sono utili per indagare sulle richieste API sospette e per raccogliendo statistiche.
Puoi configurare un cluster in modo che scriva gli audit log su disco o in Cloud Audit Logs in un progetto Google Cloud. Scrivere in Cloud Audit Logs offre diversi vantaggi tramite la scrittura su disco o persino l'acquisizione dei log in un sistema di logging on-premise:
- Gli audit log per tutti i cluster GKE possono essere centralizzati.
- Le voci di log scritte in Cloud Audit Logs sono immutabili.
- Le voci degli audit log di Cloud vengono conservate per 400 giorni.
- Gli audit log di Cloud sono inclusi nel prezzo di Anthos.
Audit logging basato su disco
Per impostazione predefinita, gli audit log vengono scritti in un il disco in modo che i riavvii e gli upgrade delle VM non causino la scomparsa dei log. Google Distributed Cloud conserva fino a 12 GB di voci di audit log.
Cloud Audit Logs
Se attivi gli audit log di Cloud per un cluster, le voci degli audit log delle attività di amministrazione del server API Kubernetes del cluster vengono inviate a Google Cloud utilizzando il progetto Google Cloud specificato nel campo cloudAuditLogging.projectID
del file di configurazione del cluster.
Questo progetto Google Cloud è chiamato
progetto di audit logging.
Il progetto di audit logging deve essere uguale al tuo progetto host del parco risorse.
Per mettere in memoria e scrivere le voci di log negli audit log di Cloud,
Google Distributed Cloud esegue il deployment di un pod audit-proxy
nel cluster di amministrazione.
Questo componente è disponibile anche come container collaterale sui cluster utente.
Limitazioni
La versione corrente di Cloud Audit Logs per Google Distributed Cloud presenta diversi limiti:
La registrazione dell'accesso ai dati (richieste get, list, watch) non è supportata.
La modifica del criterio di controllo di Kubernetes non è supportata.
Cloud Audit Logs non è resiliente alle interruzioni della rete prolungate. Se le voci di log non possono essere esportate in Google Cloud, vengono memorizzate nella cache in un buffer del disco di 10 GB. Se il buffer si riempie, le voci successive vengono eliminate.
Abilita l'API Anthos Audit
Abilita l'API Anthos Audit nel tuo progetto di audit logging.
Crea un account di servizio per Cloud Audit Logs
Hai già uno o più account di servizio creato per essere utilizzato con Google Distributed Cloud. Per questa funzionalità, devi creare un account di servizio aggiuntivo chiamato account di servizio per i log di controllo.
Crea l'account di servizio per i log di controllo:
gcloud iam service-accounts create audit-logging-service-account
Crea un file della chiave JSON per l'account di servizio Cloud Audit Logs:
gcloud iam service-accounts keys create audit-logging-key.json \ --iam-account AUDIT_LOGGING_SERVICE_ACCOUNT_EMAIL
dove AUDIT_LOGGING_SERVICE_ACCOUNT_EMAIL è l'indirizzo email del tuo account di servizio.
Salva
audit-logging-key.json
sulla workstation di amministrazione nella stessa posizione delle altre chiavi dell'account di servizio.
Crea un cluster di amministrazione con Cloud Audit Logs abilitato
Puoi abilitare Cloud Audit Logs per un cluster di amministrazione solo la prima volta per creare il cluster di amministrazione. Non puoi modificare un cluster di amministrazione esistente per abilitare Cloud Audit Logs.
Consulta la sezione Creare un cluster di amministrazione.
Nel file di configurazione del cluster di amministrazione, compila la sezione
cloudAuditLogging
.Imposta
cloudAuditLogging.projectID
sull'ID del progetto di registrazione degli audit.Imposta
cloudAuditLogging.clusterLocation
su una regione Google Cloud in cui vuoi archiviare gli audit log. Per migliorare la latenza, scegli una regione che vicino al tuo data center on-premise.Imposta
cloudAuditLogging.serviceAccountKeyPath
sul percorso del file della chiave JSON per l'account di servizio di registrazione degli audit.
Ad esempio:
cloudAuditLogging: projectID: "my-project" clusterLocation: "us-west1" serviceAccountKeyPath: "/my-key-folder/audit-logging-key.json"
Continua la creazione del cluster come di consueto.
Creare un cluster utente con gli audit log di Cloud abilitati
Consulta Creazione di un cluster utente.
Nel file di configurazione del cluster utente, compila
cloudAuditLogging
.Imposta
cloudAuditLogging.projectID
sull'ID del progetto di audit logging.Imposta
cloudAuditLogging.clusterLocation
su una regione Google Cloud in cui vuoi archiviare gli audit log. Per ridurre la latenza, scegli una regione vicina al tuo data center on-premise.Imposta
cloudAuditLogging.serviceAccounKeyPath
sul percorso della chiave JSON per il tuo account di servizio Cloud Audit Logs.Assicurati che la sezione
gkeConnect
sia compilata e chegkeConnect.projectID
corrisponda acloudAuditLogging.projectID
.
Ad esempio:
gkeConnect: projectID: "my-project" registerServiceAccountKeyPath: "/my-key-fokder/connect-register-key.json" cloudAuditLogging: projectID: "my-project" clusterLocation: "us-west1" serviceAccountKeyPath: "/my-key-folder/audit-logging-key.json"
Continua la creazione del cluster come di consueto.
Abilita Cloud Audit Logs per un cluster utente esistente
Cloud Audit Logs può essere attivato solo nel progetto Google Cloud in cui è registrato il cluster utente.
Se un cluster di utenti esistente non è registrato, registralo seguendo questi passaggi prima di attivare Cloud Audit Logs:
Aggiungi una sezione
gkeConnect
al file di configurazione del cluster utente. Ad esempio:gkeConnect: projectID: "my-project" registerServiceAccountKeyPath: "/my-key-fokder/connect-register-key.json"
Aggiorna il cluster:
gkectl update cluster --config USER_CLUSTER_CONFIG --kubeconfig ADMIN_CLUSTER_KUBECONFIG
Dopo aver registrato il cluster utente, segui questi passaggi per abilitarlo Cloud Audit Logs:
Compila la sezione
cloudAuditLogging
del file di configurazione del cluster utente. Per informazioni dettagliate sui singoli campi, consulta Creare un cluster di utenti con gli audit log di Cloud abilitati.projectID
incloudAuditLogging
deve essere uguale a quello della sezionegkeConnect
.Aggiorna il cluster:
gkectl update cluster --config USER_CLUSTER_CONFIG --kubeconfig ADMIN_CLUSTER_KUBECONFIG
Disattivare Cloud Audit Logs per un cluster utente esistente
Nel file di configurazione del cluster utente, elimina
cloudAuditLogging
.Aggiorna il cluster utente:
gkectl update cluster --kubeconfig [ADMIN_CLUSTER_KUBECONFIG] --config [USER_CLUSTER_CONFIG]
Accedere ai log di controllo
Audit logging basato su disco
Puoi trovare i log di controllo per il cluster di amministrazione nei nodi del piano di controllo in /var/log/kube-audit/kube-apiserver-audit.log
. I log di controllo per il cluster di utenti si trovano nel file PersistentVolumeClaim
denominato kube-audit-kube-apiserver-0
. Puoi accedere a questi dati all'interno del tuo
Pod tramite voci volumes
:
Aggiungi questa voce per il cluster di amministrazione:
volumes: - name: kube-audit hostPath: path: /var/log/kube-audit type: ""
Aggiungi questa voce per il cluster utente:
volumes: - name: kube-audit persistentVolumeClaim: claimName: kube-audit-kube-apiserver-0
Per pianificare il pod sul nodo del cluster amministrativo appropriato (e solo su questo
nodo), dovrai aggiungere le sezioni nodeSelector
e tolerations
alle specifiche del pod, come segue:
spec: nodeSelector: node-role.kubernetes.io/master: '' tolerations: - key: node-role.kubernetes.io/master value: "" effect: NoSchedule
Per il cluster utente, imposta namespace
come nome del cluster utente, quindi imposta nodeName
come kube-apiserver-0
:
spec: nodeName: NODE_NAME
Per evidenziare il nodeName
di kube-apiserver-0
, esegui il seguente comando:
kubectl get pod kube-apiserver-0 -n USER_CLUSTER_NAME --kubeconfig kubeconfig -o jsonpath='{.spec.nodeName}'
Il nome di ogni log di controllo contiene un timestamp che indica quando il file è stato girato. Un file contiene i log di controllo fino a quella data e ora.
Cloud Audit Logs
Console
Nella console Google Cloud, vai alla pagina Log nel menu Logging.
Nella casella Filtra per etichetta o testo, appena sopra il menu a discesa dai menu descritti sopra, fai clic sulla freccia giù per aprire il menu a discesa. Nel menu, scegli Converti in filtro avanzato.
Compila il campo con il seguente filtro:
resource.type="k8s_cluster" logName="projects/PROJECT_ID/logs/externalaudit.googleapis.com%2Factivity" protoPayload.serviceName="anthosgke.googleapis.com"
Fai clic su Invia filtro per visualizzare tutti gli audit log dei cluster configurati per accedere a questo progetto.
gcloud
Elenca le prime due voci di log nel Log delle attività di amministrazione del progetto che
si applica al tipo di risorsa k8s_cluster
:
gcloud logging read \ 'logName="projects/PROJECT_ID/logs/externalaudit.googleapis.com%2Factivity" \ AND resource.type="k8s_cluster" \ AND protoPayload.serviceName="anthosgke.googleapis.com" ' \ --limit 2 \ --freshness 300d
dove PROJECT_ID è l'ID progetto.
L'output mostra due voci di log. Nota che per ogni voce di log,
Il campo logName
ha il valore
projects/PROJECT_ID/logs/externalaudit.googleapis.com%2Factivity
e protoPayload.serviceName
è uguale a anthosgke.googleapis.com
.
Criteri di audit
Il comportamento di Cloud Audit Logs è determinato da un criterio di audit logging di Kubernetes configurato in modo statico. Al momento la modifica di questo criterio non è supportata, ma lo sarà disponibile in una release futura.