Configura un criterio di autorizzazione binaria con Cloud Run
Questa guida rapida mostra come configurare e testare una regola di base in un criterio di Autorizzazione binaria con Cloud Run.
In questa guida rapida, utilizzi Autorizzazione binaria per controllare il deployment di un servizio Cloud Run.
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.
Roles required to select or create a project
- Select a project: Selecting a project doesn't require a specific IAM role—you can select any project that you've been granted a role on.
-
Create a project: To create a project, you need the Project Creator
(
roles/resourcemanager.projectCreator
), which contains theresourcemanager.projects.create
permission. Learn how to grant roles.
-
Verify that billing is enabled for your Google Cloud project.
-
Enable the Cloud Run, Artifact Registry, Binary Authorization APIs.
Roles required to enable APIs
To enable APIs, you need the Service Usage Admin IAM role (
roles/serviceusage.serviceUsageAdmin
), which contains theserviceusage.services.enable
permission. Learn how to grant roles. -
Install the Google Cloud CLI.
-
Se utilizzi un provider di identità (IdP) esterno, devi prima accedere a gcloud CLI con la tua identità federata.
-
Per inizializzare gcloud CLI, esegui questo comando:
gcloud init
-
In the Google Cloud console, on the project selector page, select or create a Google Cloud project.
Roles required to select or create a project
- Select a project: Selecting a project doesn't require a specific IAM role—you can select any project that you've been granted a role on.
-
Create a project: To create a project, you need the Project Creator
(
roles/resourcemanager.projectCreator
), which contains theresourcemanager.projects.create
permission. Learn how to grant roles.
-
Verify that billing is enabled for your Google Cloud project.
-
Enable the Cloud Run, Artifact Registry, Binary Authorization APIs.
Roles required to enable APIs
To enable APIs, you need the Service Usage Admin IAM role (
roles/serviceusage.serviceUsageAdmin
), which contains theserviceusage.services.enable
permission. Learn how to grant roles. -
Install the Google Cloud CLI.
-
Se utilizzi un provider di identità (IdP) esterno, devi prima accedere a gcloud CLI con la tua identità federata.
-
Per inizializzare gcloud CLI, esegui questo comando:
gcloud init
Fai clic su Crea servizio per visualizzare il modulo Crea servizio:
Nel modulo visualizzato, esegui le seguenti operazioni:
- Seleziona Cloud Run come piattaforma di sviluppo.
- Seleziona la regione in cui vuoi che si trovi il servizio.
- Specifica il nome che vuoi dare al tuo servizio, ad esempio
test-service
. Fai clic su Avanti per passare alla pagina Configura la prima revisione del servizio.
Nel modulo, esegui le seguenti operazioni:
- Seleziona Esegui il deployment di una revisione da un'immagine container esistente.
Utilizza
us-docker.pkg.dev/cloudrun/container/hello
come immagine container.Espandi la sezione Impostazioni avanzate.
Fai clic sulla scheda Sicurezza.
Seleziona la casella di controllo Verifica il deployment dei container con Autorizzazione binaria:
Per impostazione predefinita, il criterio di Autorizzazione binaria consente il deployment di tutte le immagini.
Fai clic su Avanti per continuare alla pagina Configura il funzionamento del trigger per questo servizio:
Seleziona Consenti l'accesso pubblico per poter aprire il risultato nel tuo browser web.
Fai clic su Crea per eseguire il deployment dell'immagine su Cloud Run e attendi il completamento del deployment.
Il servizio è stato implementato. Le revisioni sono soggette all'applicazione del criterio di autorizzazione binaria.
Vai all'autorizzazione binaria
Fai clic su Modifica criterio.
In Regola predefinita del progetto, nota che l'opzione Consenti tutte le immagini è selezionata.
Vai alla pagina Autorizzazione binaria nella console Google Cloud .
Fai clic su Modifica criterio.
In Regola predefinita, seleziona Non consentire tutte le immagini.
Fai clic su Save Policy (Salva criterio).
Fai clic sul nome del servizio di cui hai eseguito il deployment in precedenza in questa guida.
Fai clic su Modifica ed esegui il deployment di una nuova revisione.
Fai clic su Esegui il deployment.
Vai alla pagina Autorizzazione binaria nella console Google Cloud .
Fai clic su Modifica criterio.
Seleziona Consenti tutte le immagini.
Per salvare la norma, fai clic su Salva norma.
Individua il servizio che vuoi eliminare nell'elenco dei servizi e fai clic sulla relativa casella di controllo per selezionarlo.
Fai clic su Elimina. Vengono eliminate tutte le revisioni del servizio.
Utilizza breakglass per ignorare l'applicazione di Autorizzazione binaria.
Utilizza l'
built-by-cloud-build
per eseguire il deployment solo delle immagini create da Cloud Build.Configura il criterio di autorizzazione binaria utilizzando la Google Cloud console o lo strumento a riga di comando.
Visualizza gli eventi di Autorizzazione binaria per Cloud Run in Cloud Audit Logs.
Crea un servizio con Autorizzazione binaria abilitata
Per creare un servizio Cloud Run con Autorizzazione binaria abilitata:
Aggiorna la policy di Autorizzazione binaria per non consentire tutte le immagini
Il criterio di Autorizzazione binaria contiene una regola predefinita. Questa regola regola il deployment del servizio Cloud Run che hai appena creato.
Per impostazione predefinita, la regola consente il deployment di tutte le immagini container.
Per visualizzare la policy predefinita, segui questi passaggi:
Ora, modifica la policy per bloccare il deployment di tutte le immagini, procedendo nel seguente modo:
Esegui nuovamente il deployment del servizio
Testa la policy aggiornata eseguendo il deployment di una nuova revisione.
Per eseguire il deployment dell'immagine:
Viene visualizzato un messaggio di errore simile al seguente:
Service update rejected by Binary Authorization policy: RevisionREVISION
uses unauthorized container image. Container image 'us-docker.pkg.dev/cloudrun/container/hello@SHA
' is not authorized by policy. Denied by an ALWAYS_DENY admission rule
Reimposta il criterio per consentire tutte le immagini
Per reimpostare il criterio in modo da consentire tutte le immagini:
Ora puoi eseguire il deployment delle immagini.
Esegui la pulizia
Per evitare che al tuo account Google Cloud vengano addebitati costi relativi alle risorse utilizzate in questa pagina, segui questi passaggi.
Per eliminare il servizio creato in Cloud Run, procedi nel seguente modo:
Per disabilitare Autorizzazione binaria, vedi Disabilitazione di Autorizzazione binaria.