Questo tutorial descrive come utilizzare Autorizzazione binaria in una configurazione di più progetti. Per una configurazione più semplice di un singolo progetto, consulta Iniziare a utilizzare Google Cloud CLI (GKE).
Per stabilire la separazione dei compiti, puoi configurare l&#Autorizzazione binaria in una configurazione con più progetti. Lo scopo di ciascun progetto viene discusso più avanti in questo tutorial.
Obiettivi
In questo tutorial, esegui le seguenti attività:Configura un progetto diverso per il deployment (GKE), l'attestatore e la gestione delle attestazioni per supportare la separazione delle responsabilità.
Configura la regola predefinita del criterio di Autorizzazione binaria in modo che richieda le attestazioni.
Crea una coppia di chiavi PKIX (Public-Key Infrastructure, X.509) per firmare e successivamente verificare la certificazione.
Crea un attestatore utilizzato dall'applicazione di Autorizzazione binaria per verificare l'attestazione.
Firma un'immagine di esempio, creando un'attestazione.
Testa il criterio disadoperando l'immagine di esempio.
Devi configurare il controllo dell'accesso appropriato per ogni progetto tramite Identity and Access Management (IAM).
Per una maggiore sicurezza, puoi utilizzare i Controlli di servizio VPC per contribuire a proteggere le risorse che crei in questo tutorial. Per ulteriori informazioni, consulta Metti al sicuro i tuoi dati con i Controlli di servizio VPC.
Costi
In questo documento utilizzi i seguenti componenti fatturabili di Google Cloud:
- Artifact Registry or Container Registry
- Binary Authorization
- GKE
- Container Registry
- Optional: Cloud Key Management Service
Per generare una stima dei costi basata sull'utilizzo previsto,
utilizza il Calcolatore prezzi.
Prima di iniziare
- Sign in to your Google Cloud account. If you're new to Google Cloud, create an account to evaluate how our products perform in real-world scenarios. New customers also get $300 in free credits to run, test, and deploy workloads.
-
In the Google Cloud console, on the project selector page, select or create a Google Cloud project.
-
Make sure that billing is enabled for your Google Cloud project.
- Install the Google Cloud CLI.
-
To initialize the gcloud CLI, run the following command:
gcloud init
-
In the Google Cloud console, on the project selector page, select or create a Google Cloud project.
-
Make sure that billing is enabled for your Google Cloud project.
- Install the Google Cloud CLI.
-
To initialize the gcloud CLI, run the following command:
gcloud init
- Installa
kubectl
per interagire con GKE.
Configura il progetto di deployment
Il progetto di deployment gestisce i cluster Google Kubernetes Engine (GKE) in cui esegui il deployment delle immagini e il criterio di autorizzazione binaria applicato da questa tecnologia al momento del deployment. Puoi avere più di un progetto di deployment, a seconda delle dimensioni, della complessità e di altri requisiti del tuo ambiente.
Per configurare il progetto di deployment:
Crea il progetto e abilita la fatturazione nella console Google Cloud, se non lo hai già fatto.
Nota di Identity and Access Management: il progetto di deployment contiene il tuo cluster GKE. La configurazione di Identity and Access Management per questo progetto deve rispecchiare questa situazione.
Imposta le variabili di ambiente per archiviare il progetto e il numero di Google Cloud:
DEPLOYER_PROJECT_ID=DEPLOYER_PROJECT_ID
Sostituisci DEPLOYER_PROJECT_ID con l'ID del progetto Google Cloud.
DEPLOYER_PROJECT_NUMBER=$(gcloud projects describe "${DEPLOYER_PROJECT_ID}" \ --format="value(projectNumber)")
Abilita le API:
Container Registry
gcloud --project=${DEPLOYER_PROJECT_ID} \ services enable\ container.googleapis.com\ containerregistry.googleapis.com\ binaryauthorization.googleapis.com
Artifact Registry
gcloud --project=${DEPLOYER_PROJECT_ID} \ services enable\ container.googleapis.com\ artifactregistry.googleapis.com\ binaryauthorization.googleapis.com
Ottieni il nome del account di servizio del progetto di deployment:
DEPLOYER_SERVICE_ACCOUNT="service-${DEPLOYER_PROJECT_NUMBER}@gcp-sa-binaryauthorization.iam.gserviceaccount.com"
Utilizzerai il nome dell'account di servizio in un passaggio successivo quando configurerai le autorizzazioni nella nota di Artifact Analysis associati al tuo attestatore.
Configura il progetto dell'attestatore
Un progetto di attestatore memorizza gli attestatori che possono verificare che un'immagine sia pronta per il deployment. Spesso, è presente un unico progetto di attestatore che funge da repository centralizzato per le informazioni sulle parti attendibili nella procedura di autorizzazione. In questo modo puoi gestire centralmente le chiavi di sicurezza necessarie per verificare l'identità degli attestatori e limitare l'accesso solo alle parti che le amministrano.
Per configurare il progetto di attestatore:
Crea il progetto e abilita la fatturazione nella console Google Cloud, se non lo hai già fatto.
Nota di Identity and Access Management: poiché questo progetto contiene i tuoi attestatori, solo il personale di sicurezza deve disporre dell'accesso in scrittura.
Imposta le variabili di ambiente per archiviare l'ID e il numero del progetto:
ATTESTOR_PROJECT_ID=ATTESTOR_PROJECT_ID
Sostituisci ATTESTOR_PROJECT_ID con l'ID progetto dell'attestatore.
ATTESTOR_PROJECT_NUMBER=$(gcloud projects describe "${ATTESTOR_PROJECT_ID}" \ --format="value(projectNumber)")
Abilita le API Artifact Analysis e Binary Authorization:
gcloud services --project=${ATTESTOR_PROJECT_ID} \ enable containeranalysis.googleapis.com \ binaryauthorization.googleapis.com
Ottieni il nome del account di servizio del progetto di attestazione:
ATTESTOR_SERVICE_ACCOUNT="service-${ATTESTOR_PROJECT_NUMBER}@gcp-sa-binaryauthorization.iam.gserviceaccount.com"
Utilizzerai il nome dell'account di servizio in un passaggio successivo quando configurerai le autorizzazioni nella nota di Artifact Analysis associati al tuo attestatore.
Configurare il progetto di attestazioni
Un progetto di attestazione è un progetto che memorizza le attestazioni effettuate dagli attestatori quando verificano un'immagine. Un progetto di attestazione separato ti consente di organizzare e ispezionare più facilmente le dichiarazioni relative all'idoneità del software.
Crea il progetto e abilita la fatturazione nella console Google Cloud, se non lo hai già fatto.
Nota di Identity and Access Management: tutti i ruoli coinvolti nell'autorizzazione binaria devono avere accesso in lettura alle note e alle occorrenze di analisi degli elementi in questo progetto, tuttavia solo i gestori dell'attestazione devono avere accesso in scrittura.
Imposta una variabile di ambiente per archiviare il nome del progetto:
ATTESTATION_PROJECT_ID=ATTESTATION_PROJECT_ID
Sostituisci ATTESTATION_PROJECT_ID con l'ID progetto di attestazione.
Abilita le API Artifact Analysis e Binary Authorization:
gcloud services --project=${ATTESTATION_PROJECT_ID} \ enable containeranalysis.googleapis.com \ binaryauthorization.googleapis.com
Crea un cluster
Ora puoi creare un cluster GKE nel progetto di deployment.
Si tratta del cluster in cui vuoi eseguire le immagini container di cui hai eseguito il deployment. Quando crei il cluster, passa il flag --binauthz-evaluation-mode=PROJECT_SINGLETON_POLICY_ENFORCE
al comando gcloud container clusters create
.
Per creare il cluster:
gcloud --project=${DEPLOYER_PROJECT_ID} \ container clusters create \ --binauthz-evaluation-mode=PROJECT_SINGLETON_POLICY_ENFORCE \ --zone us-central1-a \ test-cluster
Qui crei un cluster denominato test-cluster
nella
us-central1-a
zona GKE.
Devi anche aggiornare il file kubeconfig
locale per l'installazione di kubectl
. Vengono fornite le credenziali e le informazioni sugli endpoint necessarie per accedere al cluster in GKE.
Per aggiornare il file kubeconfig
locale:
gcloud --project=${DEPLOYER_PROJECT_ID} \ container clusters get-credentials \ --zone us-central1-a \ test-cluster
Crea un attestatore
Un attestatore è una parte responsabile di verificare che una procedura richiesta sia stata completata prima che un'immagine del contenitore possa essere dispiattata. Questa parte può essere un utente o, più spesso, un processo automatico come un sistema di compilazione e test o le pipeline di integrazione e distribuzione continue (CI/CD). Puoi creare attestatori nel tuo progetto di attestatore.
Per creare un attestatore, devi:
- Crea una nota in Analisi degli elementi per archiviare i metadati attendibili utilizzati nella procedura di autorizzazione
- Crea l'attestatore stesso nel progetto dell'attestatore e associa la nota che hai creato
- Aggiungi all'attestatore un'associazione di ruolo IAM per l'account di servizio del progetto di deployment
- Impostare le autorizzazioni per la nota di Artifact Analysis
Per questo tutorial, hai un attestatore denominato test-attestor
e una nota di analisi del contenitore denominata test-attestor-note
. In uno scenario reale, puoi avere un numero qualsiasi di attestatori, ognuno dei quali rappresenta una parte che partecipa alla procedura di autorizzazione dell'immagine.
Crea la nota di Artifact Analysis
Imposta le variabili che memorizzano il nome dell'attestatore e la nota di Artifact Analysis:
ATTESTOR_NAME=test-attestor NOTE_ID=test-attestor-note
Sostituisci:
- test-attestor: il nome dell'attestatore che preferisci.
- test-attestor-note: il nome della nota dell'attestatore che preferisci.
Crea un file JSON in
/tmp/note_payload.json
che descriva la nota di Container Analysis:cat > /tmp/note_payload.json << EOM { "name": "projects/${ATTESTOR_PROJECT_ID}/notes/${NOTE_ID}", "attestation": { "hint": { "human_readable_name": "Attestor Note" } } } EOM
Crea la nota inviando una richiesta HTTP all'API REST di Artifact Analysis:
curl -X POST \ -H "Content-Type: application/json" \ -H "Authorization: Bearer $(gcloud auth print-access-token)" \ --data-binary @/tmp/note_payload.json \ "https://containeranalysis.googleapis.com/v1/projects/${ATTESTOR_PROJECT_ID}/notes/?noteId=${NOTE_ID}"
Verifica che la nota sia stata creata:
curl \ -H "Authorization: Bearer $(gcloud auth print-access-token)" \ "https://containeranalysis.googleapis.com/v1/projects/${ATTESTOR_PROJECT_ID}/notes/${NOTE_ID}"
Crea l'attestatore
Ora puoi creare l'attestatore:
Crea l'attestatore in Autorizzazione binaria:
gcloud --project=${ATTESTOR_PROJECT_ID} \ container binauthz attestors create ${ATTESTOR_NAME} \ --attestation-authority-note=${NOTE_ID} \ --attestation-authority-note-project=${ATTESTOR_PROJECT_ID}
Verifica che l'attestatore sia stato creato:
gcloud --project=${ATTESTOR_PROJECT_ID} \ container binauthz attestors list
L'attestatore che hai creato non è ancora utilizzabile senza una coppia di chiavi PKIX associata, che puoi creare di seguito.
Aggiungi un'associazione di ruolo IAM per il progetto di deployment
Devi aggiungere un'associazione di ruolo IAM per il progetto di implementazione all'attestatore. Viene utilizzato da Autorizzazione binaria quando valuta un criterio per determinare se il progetto dispone delle autorizzazioni per accedere alle attestazioni associate.
Per aggiungere l'associazione del ruolo IAM:
gcloud --project ${ATTESTOR_PROJECT_ID} \ container binauthz attestors add-iam-policy-binding \ "projects/${ATTESTOR_PROJECT_ID}/attestors/${ATTESTOR_NAME}" \ --member="serviceAccount:${DEPLOYER_SERVICE_ACCOUNT}" \ --role=roles/binaryauthorization.attestorsVerifier
Impostare le autorizzazioni per la nota di Artifact Analysis
Devi anche impostare le autorizzazioni per la nota di Artifact Analysis che hai creato in modo che sia accessibile sia al progetto di implementazione sia al progetto di attestazione. Aggiorna il criterio IAM per la nota in modo da assegnare l'accesso come Visualizzatore agli account di servizio del progetto.
Genera un file JSON contenente le informazioni necessarie per impostare il criterio IAM sulla nota.
cat > /tmp/iam_request.json << EOM { 'resource': 'projects/${ATTESTOR_PROJECT_ID}/notes/${NOTE_ID}', 'policy': { 'bindings': [ { 'role': 'roles/containeranalysis.notes.occurrences.viewer', 'members': [ 'serviceAccount:${ATTESTOR_SERVICE_ACCOUNT}', 'serviceAccount:${DEPLOYER_SERVICE_ACCOUNT}' ] } ] } } EOM
Aggiungi l'account di servizio e i ruoli di accesso richiesti al criterio IAM per la nota che hai creato:
curl -X POST \ -H "Content-Type: application/json" \ -H "Authorization: Bearer $(gcloud auth print-access-token)" \ --data-binary @/tmp/iam_request.json \ "https://containeranalysis.googleapis.com/v1/projects/${ATTESTOR_PROJECT_ID}/notes/${NOTE_ID}:setIamPolicy"
Configura le chiavi PKIX
L'Autorizzazione binaria utilizza chiavi crittografiche per verificare in modo sicuro l'identità degli attestatori. In questo modo, solo le parti verificate possono partecipare all'autorizzazione di un'immagine contenitore. La coppia di chiavi è composta da una chiave privata, che l'attestatore utilizza per firmare digitalmente le attestazioni, e da una chiave pubblica, che aggiungi all'attestatore come archiviata dal servizio di autorizzazione binaria.
In questo tutorial utilizzerai l'algoritmo di firma digitale con curva ellittica (ECDSA) consigliato per creare la coppia di chiavi. Puoi anche utilizzare chiavi RSA o PGP per la firma. Per ulteriori informazioni sugli algoritmi di firma, consulta la sezione Finalità e algoritmi delle chiavi.
Le chiavi asimmetriche generate e archiviate da Cloud Key Management Service (Cloud KMS) sono conformi a PKIX. Per ulteriori informazioni sull'utilizzo delle chiavi PKIX e di Cloud KMS, consulta la sezione Creazione di attestatori mediante l'interfaccia a riga di comando.
Genera una coppia di chiavi
Una coppia di chiavi PKIX è composta da una chiave privata, che il firmatario utilizza per firmare digitalmente le attestazioni, e da una chiave pubblica, che aggiungi all'attestatore. Al momento del deployment, Autorizzazione binaria utilizza questa chiave pubblica per verificare l'attestazione firmata dalla chiave privata.
Genera la chiave privata:
Per generare una nuova coppia di chiavi PKIX asimmetrica locale e memorizzarla in un file:
PKIX (Cloud KMS)
Questo passaggio mostra come eseguire un'attestazione utilizzando le chiavi generate e memorizzate in Cloud Key Management Service.
Configura le variabili di ambiente per memorizzare le informazioni sulla coppia di chiavi come gestite da Cloud KMS:
Se hai già una coppia di chiavi, puoi impostare queste variabili di ambiente e saltare il passaggio successivo.
KMS_KEY_PROJECT_ID=KMS_KEY_PROJECT_ID KMS_KEY_LOCATION=KMS_KEY_LOCATION KMS_KEYRING_NAME=KMS_KEYRING_NAME KMS_KEY_NAME=KMS_KEY_NAME KMS_KEY_VERSION=KMS_KEY_VERSION
Sostituisci quanto segue:
- KMS_KEY_PROJECT_ID: l'ID del progetto in cui sono memorizzate le chiavi
- KMS_KEY_LOCATION: la posizione della chiave
- KMS_KEYRING_NAME: il nome della chiave automatizzata
- KMS_KEY_NAME: il nome della chiave
- KMS_KEY_VERSION: la versione chiave
[Facoltativo] Configura una chiave KMS:
Crea una chiave KMS la cui chiave pubblica può essere archiviata in un attestatore. Questo passaggio configura anche le variabili di ambiente che utilizzi di seguito.
Per creare una chiave e configurare le variabili di ambiente:
KMS_KEY_PROJECT_ID=${PROJECT_ID} KMS_KEYRING_NAME=my-binauthz-keyring KMS_KEY_NAME=my-binauthz-kms-key-name KMS_KEY_LOCATION=global KMS_KEY_PURPOSE=asymmetric-signing KMS_KEY_ALGORITHM=ec-sign-p256-sha256 KMS_PROTECTION_LEVEL=software KMS_KEY_VERSION=1
Crea un keyring KMS:
gcloud kms keyrings create ${KMS_KEYRING_NAME} \ --location ${KMS_KEY_LOCATION} \ --project ${KMS_KEY_PROJECT_ID}
Crea la chiave:
gcloud kms keys create ${KMS_KEY_NAME} \ --location ${KMS_KEY_LOCATION} \ --keyring ${KMS_KEYRING_NAME} \ --purpose ${KMS_KEY_PURPOSE} \ --default-algorithm ${KMS_KEY_ALGORITHM} \ --protection-level ${KMS_PROTECTION_LEVEL} \ --project ${KMS_KEY_PROJECT_ID}
Per saperne di più sulla creazione di chiavi KMS, consulta Creare una chiave asimmetrica.
Aggiungi la chiave pubblica all'attestatore:
gcloud --project="${ATTESTOR_PROJECT_ID}" \ container binauthz attestors public-keys add \ --attestor="${ATTESTOR_NAME}" \ --keyversion-project="${KMS_KEY_PROJECT_ID}" \ --keyversion-location="${KMS_KEY_LOCATION}" \ --keyversion-keyring="${KMS_KEYRING_NAME}" \ --keyversion-key="${KMS_KEY_NAME}" \ --keyversion="${KMS_KEY_VERSION}"
PKIX (chiave locale)
Per generare la chiave privata, esegui i seguenti comandi:
PRIVATE_KEY_FILE="/tmp/ec_private.pem" openssl ecparam -genkey -name prime256v1 -noout -out ${PRIVATE_KEY_FILE}
PRIVATE_KEY_FILE è il nome del file che contiene la chiave privata memorizzata nell'attestatore.
Estrai la chiave pubblica dalla chiave privata e memorizzala in un file:
PUBLIC_KEY_FILE="/tmp/ec_public.pem" openssl ec -in ${PRIVATE_KEY_FILE} -pubout -out ${PUBLIC_KEY_FILE}
PUBLIC_KEY_FILE è il nome del file che contiene la chiave pubblica memorizzata nell'attestatore.
Per aggiungere la chiave pubblica esportata all'attestatore, esegui il seguente codice.
gcloud --project="${ATTESTOR_PROJECT_ID}" \ container binauthz attestors public-keys add \ --attestor="${ATTESTOR_NAME}" \ --pkix-public-key-file=${PUBLIC_KEY_FILE} \ --pkix-public-key-algorithm=ecdsa-p256-sha256
L'autorizzazione binaria utilizza la chiave pubblica nell'attestatore per verificare l'attestazione.
Configura il criterio
Ora puoi configurare il criterio nel progetto di deployment. In questo passaggio, esporti il file YAML del criterio nel tuo sistema locale e modifichi la regola predefinita in modo che richieda un'attestazione da parte dell'attestatore che hai definito sopra.
Per configurare il criterio:
Crea un nuovo file di criteri che consenta le immagini di sistema gestite da Google, imposta
evaluationMode
suREQUIRE_ATTESTATION
e aggiungi un nodo denominatorequireAttestationsBy
che fa riferimento all'attestatore che hai creato:cat > /tmp/policy.yaml << EOM globalPolicyEvaluationMode: ENABLE defaultAdmissionRule: evaluationMode: REQUIRE_ATTESTATION enforcementMode: ENFORCED_BLOCK_AND_AUDIT_LOG requireAttestationsBy: - projects/${ATTESTOR_PROJECT_ID}/attestors/${ATTESTOR_NAME} name: projects/${DEPLOYER_PROJECT_ID}/policy EOM
Importa il file YAML dei criteri in Autorizzazione binaria:
gcloud --project=${DEPLOYER_PROJECT_ID} \ container binauthz policy import /tmp/policy.yaml
Per ulteriori informazioni sulla configurazione di un criterio, consulta Configurare un criterio mediante l'interfaccia a riga di comando.
Testa il criterio
In questo tutorial crei un'attestazione, ad esempio immagini pubbliche "Hello World!" da Container Registry e Artifact Registry. Inizialmente, l'applicazione delle norme blocca il deployment delle immagini perché l'attestazione richiesta non esiste.
Per provare a eseguire il deployment dell'immagine:
Container Registry
kubectl run hello-server --image gcr.io/google-samples/hello-app:1.0 --port 8080
Artifact Registry
kubectl run hello-server --image us-docker.pkg.dev/google-samples/containers/gke/hello-app:1.0 --port 8080
Ora verifica che il deployment sia stato bloccato da Autorizzazione binaria:
kubectl get pods
Il comando stampa il seguente messaggio, che indica che l'immagine non è stata dimessa:
No resources found.
Puoi trovare ulteriori dettagli sul deployment:
kubectl get event --template \ '{{range.items}}{{"\033[0;36m"}}{{.reason}}:{{"\033[0m"}}\{{.message}}{{"\n"}}{{end}}'
Viene visualizzata una risposta simile alla seguente:
FailedCreate: Error creating: pods POD_NAME is forbidden: admission webhook "imagepolicywebhook.image-policy.k8s.io" denied the request: Image IMAGE_NAME denied by Binary Authorization default admission rule. Image IMAGE_NAME denied by attestor ATTESTOR_NAME: No attestations found
In questo output:
- POD_NAME: il nome del pod.
- IMAGE_NAME: il nome dell'immagine.
- ATTESTOR_NAME: il nome dell'attestatore.
Assicurati di eliminare il deployment per poter passare al passaggio successivo:
kubectl delete deployment hello-server
Creare un'attestazione
Un'attestazione è una dichiarazione di un attestatore che attesta che un procedura obbligatoria nella pipeline è stata completata e che l'immagine del contenitore in discussione è autorizzata per il deployment. L'attestazione stessa è un record firmato digitalmente che contiene il percorso completo di una versione dell'immagine come memorizzata nel tuo registry di immagini contenitore, nonché l'identità dell'attestatore.
In questo tutorial, l'attestazione indica semplicemente che autorizzi l'immagine per il deployment. Crea l'attestazione nel progetto di attestazione.
Per creare un'attestazione:
Imposta le variabili che memorizzano il percorso del registry e il digest dell'immagine:
Container Registry
IMAGE_PATH="gcr.io/google-samples/hello-app" IMAGE_DIGEST="sha256:c62ead5b8c15c231f9e786250b07909daf6c266d0fcddd93fea882eb722c3be4"
Artifact Registry
IMAGE_PATH="us-docker.pkg.dev/google-samples/containers/gke/hello-app" IMAGE_DIGEST="sha256:37e5287945774f27b418ce567cd77f4bbc9ef44a1bcd1a2312369f31f9cce567" IMAGE_TO_ATTEST=${IMAGE_PATH}@${IMAGE_DIGEST}
Crea l'attestazione
PKIX Cloud KMS
Per creare l'attestazione utilizzando la chiave Cloud KMS, esegui il seguente comando:
gcloud beta container binauthz attestations sign-and-create \ --project="${PROJECT_ID}" \ --artifact-url="${IMAGE_TO_ATTEST}" \ --attestor="${ATTESTOR_NAME}" \ --attestor-project="${PROJECT_ID}" \ --keyversion-project="${KMS_KEY_PROJECT_ID}" \ --keyversion-location="${KMS_KEY_LOCATION}" \ --keyversion-keyring="${KMS_KEYRING_NAME}" \ --keyversion-key="${KMS_KEY_NAME}" \ --keyversion="${KMS_KEY_VERSION}"
PKIX (chiave locale)
Per creare l'attestazione utilizzando una chiave locale:
Genera il payload dell'attestazione:
gcloud --project=${ATTESTATION_PROJECT_ID} \ container binauthz create-signature-payload \ --artifact-url=${IMAGE_TO_ATTEST} > /tmp/generated_payload.json
Il file JSON del payload ha i seguenti contenuti:
Container Registry
{ "critical": { "identity": { "docker-reference": "gcr.io/google-samples/hello-app" }, "image": { "docker-manifest-digest": "sha256:c62ead5b8c15c231f9e786250b07909daf6c266d0fcddd93fea 882eb722c3be4" }, "type": "Google cloud binauthz container signature" } }
Artifact Registry
{ "critical": { "identity": { "docker-reference": "us-docker.pkg.dev/google-samples/containers/gke/hello-app" }, "image": { "docker-manifest-digest": "sha256:37e5287945774f27b418ce567cd77f4bbc9ef44a1bcd1a2312369f31f9cce567" }, "type": "Google cloud binauthz container signature" } }
Firma il payload.
Se utilizzi file PKIX locali, firma il payload con la tua chiave privata PKIX locale e genera un file di firma:
openssl dgst -sha256 -sign ${PRIVATE_KEY_FILE} /tmp/generated_payload.json > /tmp/ec_signature
Il file di output è una versione firmata del file JSON del payload che hai creato sopra.
Recupera l'ID chiave pubblica dall'attestatore.
Puoi visualizzare il tuo ID chiave pubblica in qualsiasi momento utilizzando il comando:
gcloud container binauthz attestors describe ATTESTOR_NAME
.Per salvare l'ID chiave pubblica in una variabile di ambiente, inserisci questo comando:
PUBLIC_KEY_ID=$(gcloud container binauthz attestors describe ${ATTESTOR_NAME} \ --format='value(userOwnedGrafeasNote.publicKeys[0].id)' --project ${ATTESTOR_PROJECT_ID})
Crea e convalida l'attestazione:
gcloud container binauthz attestations create \ --project="${ATTESTATION_PROJECT_ID}" \ --artifact-url="${IMAGE_TO_ATTEST}" \ --attestor="projects/${ATTESTOR_PROJECT_ID}/attestors/${ATTESTOR_NAME}" \ --signature-file=/tmp/ec_signature \ --public-key-id="${PUBLIC_KEY_ID}" \ --validate
Il flag
validate
verifica che l'attestazione possa essere verificata dall'attestatore configurato nelle norme.
Verifica che l'attestazione sia stata creata:
gcloud --project=${ATTESTATION_PROJECT_ID} \ container binauthz attestations list \ --attestor=$ATTESTOR_NAME --attestor-project=$ATTESTOR_PROJECT_ID
Per ulteriori informazioni sulla creazione di attestazioni, consulta la sezione Creare attestazioni.
Riprovare il criterio
Testa il criterio eseguendo il deployment di un'immagine container di esempio nel cluster.
Questa volta, devi eseguire il deployment dell'immagine utilizzando il digest anziché un tag come 1.0
o latest
, poiché Autorizzazione binaria utilizza il digest per cercare le attestazioni. In questo caso, Autorizzazione binaria consente il deployment dell'immagine perché
ha un'attestazione associata.
Per eseguire il deployment dell'immagine:
kubectl run hello-server --image ${IMAGE_TO_ATTEST} --port 8080
Per verificare che l'immagine sia stata dispiata:
kubectl get pods
Il comando stampa un messaggio simile al seguente, che indica che il deployment è andato a buon fine:
NAME READY STATUS RESTARTS AGE hello-server-579859fb5b-h2k8s 1/1 Running 0 1m
Ora che hai eseguito il deployment dell'immagine del contenitore e verificato che la configurazione funzioni, puoi eliminare il cluster creato in GKE:
gcloud --project=${DEPLOYER_PROJECT_ID} \ container clusters delete \ --zone=us-central1-a \ test-cluster
Esegui la pulizia
Per evitare che al tuo account Google Cloud vengano addebitati costi relativi alle risorse utilizzate in questo tutorial, elimina il progetto che contiene le risorse oppure mantieni il progetto ed elimina le singole risorse.
Elimina il cluster che hai creato in GKE:
gcloud container clusters delete \ --zone=us-central1-a \ test-cluster
Puoi anche eliminare i progetti Google Cloud che hai creato per questo tutorial.