Pengantar identitas layanan

Halaman ini menjelaskan dua identitas Cloud Run dan cara Library Klien Cloud menggunakan identitas layanan untuk memanggil Google Cloud API. Contoh produk yang memiliki Library Klien Cloud mencakup Cloud Storage, Firestore, Cloud SQL, Pub/Sub, dan Cloud Tasks. Google Cloud Halaman ini ditujukan untuk admin, operator, atau developer yang mengelola kebijakan organisasi dan akses pengguna, atau siapa pun yang ingin mempelajari topik tersebut.

Identitas Cloud Run

Untuk menggunakan Cloud Run, Google Cloud diperlukan dua jenis identitas dengan izin yang sesuai:

  • Akun deployer Cloud Run: Identitas (baik akun pengguna atau akun layanan) yang Anda gunakan untuk men-deploy dan mengelola resource Cloud Run dengan membuat permintaan ke Cloud Run Admin API.
  • Identitas layanan Cloud Run: Identitas (akun layanan) yang digunakan oleh instance Cloud Run. Saat kode Cloud Run yang Anda tulis berinteraksi dengan Library Klien Cloud, atau memanggil layanan Cloud Run lain untuk komunikasi antarlayanan, Anda menggunakan identitas ini untuk membuat permintaan dari Cloud Run keGoogle Cloud API atau layanan Cloud Run lainnya.

Untuk mengakses dan membuat permintaan ke Google Cloud API atau berkomunikasi antar-layanan, setiap identitas harus memiliki izin yang sesuai yang diberikan kepada mereka di Identity and Access Management (IAM).

Memanggil Cloud Run Admin API dengan akun deployer

Anda memanggil Cloud Run Admin API dari Cloud Run menggunakan akun deployer Cloud Run. Akun deployer dapat berupa akun pengguna atau akun layanan, dan mewakili akun yang login ke lingkungan. Google Cloud

Saat akun deployer menggunakan Cloud Run, IAM akan memeriksa apakah akun deployer memiliki izin yang diperlukan untuk melakukan operasi Cloud Run. Diagram berikut menunjukkan cara akun pengguna memanggil Cloud Run Admin API untuk men-deploy revisi baru dari Google Cloud konsol:

Panggil Cloud Run Admin API dari konsol Google Cloud .
Gambar 1. Pengguna menggunakan Google Cloud konsol untuk men-deploy revisi baru dengan mengirim permintaan dengan token akses ke Cloud Run Admin API. IAM menggunakan token akses tersebut untuk memverifikasi bahwa akun pengguna diautentikasi untuk mengakses Cloud Run Admin API sebelum melakukan operasi.

Memanggil Google Cloud API dengan identitas layanan

Saat instance Cloud Run berinteraksi dengan layanan Cloud Run lain yang diautentikasi IAM, atau memanggil Library Klien Cloud baik melalui kode aplikasi atau fitur bawaan seperti integrasi Cloud Run atau pemasangan volume Cloud Storage, lingkungan akan menggunakan Kredensial Default Aplikasi (ADC) untuk otomatis mendeteksi apakah identitas layanan Cloud Run diautentikasi untuk melakukan operasi API. Google Cloud Identitas layanan Cloud Run adalah akun layanan yang ditetapkan sebagai identitas instance Cloud Run saat Anda men-deploy revisi atau menjalankan tugas.

Akun layanan yang digunakan sebagai akun deployer hanya akan digunakan sebagai identitas layanan jika Anda mengonfigurasi akun layanan yang sama dalam konfigurasi Cloud Run.

Bagian panduan ini menjelaskan cara resource Cloud Run menggunakan identitas layanan untuk memanggil dan mengakses layanan dan API Google. Untuk mengetahui informasi selengkapnya tentang konfigurasi identitas layanan, lihat halaman konfigurasi identitas layanan untuk layanan, tugas, dan kumpulan worker.

Jenis akun layanan untuk identitas layanan

Saat instance Cloud Run Anda melakukan panggilan ke Google Cloud API untuk melakukan operasi yang diperlukan, Cloud Run akan otomatis menggunakan akun layanan sebagai identitas layanan. Dua jenis akun layanan yang dapat digunakan sebagai identitas layanan adalah sebagai berikut:

  • Akun layanan yang dikelola pengguna (direkomendasikan): Anda membuat akun layanan ini secara manual dan menentukan kumpulan izin paling minimal yang diperlukan akun layanan untuk mengakses Google Cloud resource tertentu. Akun layanan yang dikelola pengguna mengikuti format SERVICE_ACCOUNT_NAME@PROJECT_ID.iam.gserviceaccount.com.
  • Akun layanan default Compute Engine: Cloud Run otomatis menyediakan akun layanan default Compute Engine sebagai identitas layanan default. Akun layanan default Compute Engine mengikuti format PROJECT_NUMBER-compute@developer.gserviceaccount.com.

Menghindari akun layanan default saat mengonfigurasi identitas layanan

Secara default, akun layanan default Compute Engine akan dibuat secara otomatis. Jika Anda tidak menentukan akun layanan saat resource Cloud Run dibuat, Cloud Run akan menggunakan akun layanan ini.

Bergantung pada konfigurasi kebijakan organisasi Anda, akun layanan default mungkin otomatis diberi peran Editor di project Anda. Sebaiknya nonaktifkan pemberian peran otomatis dengan menerapkan iam.automaticIamGrantsForDefaultServiceAccounts kebijakan organisasi batasan. Jika Anda membuat organisasi setelah 3 Mei 2024, batasan ini diterapkan secara default.

Jika Anda menonaktifkan pemberian peran otomatis, Anda harus menentukan peran mana yang akan diberikan ke akun layanan default, lalu memberikan peran tersebut sendiri.

Jika akun layanan default sudah memiliki peran Editor, sebaiknya ganti peran Editor dengan peran yang kurang permisif.Untuk mengubah peran akun layanan dengan aman, gunakan Policy Simulator untuk melihat dampak perubahan, lalu berikan dan cabut peran yang sesuai.

Cara kerja identitas layanan

Saat kode Anda menggunakan Library Klien Cloud yang membuat permintaan ke Google Cloud API, hal berikut akan terjadi:

  1. Library klien meminta token akses OAuth 2.0 untuk identitas layanan dari server metadata instance.
  2. Server metadata instance menyediakan token akses IAM untuk akun layanan yang dikonfigurasi sebagai identitas layanan.
  3. Permintaan ke Google Cloud API dikirim dengan token akses OAuth 2.0.
  4. IAM memverifikasi identitas layanan yang direferensikan dalam token akses untuk izin yang diperlukan, dan memeriksa binding kebijakan sebelum meneruskan panggilan ke endpoint API.
  5. Google Cloud API melakukan operasi.
Panggil Google Cloud API dari Cloud Run.
Gambar 1. Cloud Run membuat token akses dari server metadata, dan IAM menggunakan token akses tersebut untuk memverifikasi bahwa identitas layanan Cloud Run yang ditetapkan diautentikasi untuk mengakses Google Cloud API.

Membuat token akses untuk permintaan Cloud Run guna memanggil Google Cloud API

Jika kode Cloud Run Anda menggunakan Library Klien Cloud, Anda mengonfigurasi identitas layanan di Cloud Run dengan menetapkan akun layanan saat deployment atau eksekusi. Hal ini memungkinkan library otomatis mendapatkan token akses untuk mengautentikasi permintaan kode Anda. Jika kode Cloud Run Anda berkomunikasi dengan layanan Cloud Run lain yang diautentikasi, Anda harus menambahkan token akses ke permintaan Anda.

Untuk menetapkan akun layanan sebagai identitas layanan, lihat panduan berikut:

Namun, jika Anda menggunakan kode kustom sendiri atau perlu membuat permintaan secara terprogram, Anda dapat menggunakan server metadata secara langsung untuk mengambil token identitas dan token akses secara manual yang dijelaskan di bagian berikutnya. Perhatikan bahwa Anda tidak dapat membuat kueri server ini langsung dari lokal Anda mesin karena server metadata hanya tersedia untuk workload yang berjalan di Google Cloud.

Mengambil token ID dan akses menggunakan server metadata

Dua jenis token yang dapat Anda ambil dengan server metadata adalah sebagai berikut:

Untuk mengambil token, ikuti petunjuk di tab yang sesuai untuk jenis token yang Anda gunakan:

Token akses

Misalnya, jika Anda ingin membuat topik Pub/Sub, gunakan projects.topics.create metode.

  1. Gunakan Server Metadata Compute untuk mengambil token akses:

    curl "http://metadata.google.internal/computeMetadata/v1/instance/service-accounts/default/token" \
        --header "Metadata-Flavor: Google"

    Endpoint ini menampilkan respons JSON dengan atribut access_token.

  2. Dalam permintaan protokol HTTP, permintaan tersebut harus diautentikasi dengan token akses di header Authorization:

    PUT https://pubsub.googleapis.com/v1/projects/PROJECT_ID/topics/TOPIC_ID
    Authorization: Bearer ACCESS_TOKEN
    

    Dengan:

    • PROJECT_ID adalah project ID Anda.
    • TOPIC_ID adalah topic ID Anda.
    • ACCESS_TOKEN adalah token akses yang Anda ambil pada langkah sebelumnya.

    Respons:

    {
        "name": "projects/PROJECT_ID/topics/TOPIC_ID"
    }
    

Token ID

Gunakan Server Metadata Compute untuk mengambil token identitas dengan audiens tertentu:

curl "http://metadata.google.internal/computeMetadata/v1/instance/service-accounts/default/identity?audience=AUDIENCE" \
    --header "Metadata-Flavor: Google"

Dengan AUDIENCE adalah Audiens JWT yang diminta.

Untuk layanan Cloud Run, audiens harus berupa URL layanan yang Anda panggil atau audiens khusus, seperti domain kustom, yang dikonfigurasikan untuk layanan tersebut.

https://service.domain.com

Resource lainnya dapat berupa Client ID OAuth dari resource yang dilindungi IAP:

1234567890.apps.googleusercontent.com

Langkah berikutnya