Halaman ini menjelaskan cara menggunakan akun layanan untuk memungkinkan aplikasi yang berjalan di instance virtual machine (VM) Anda dapat melakukan autentikasi ke Google Cloud API dan memberikan akses ke resource.
Agar dapat menggunakan akun layanan untuk autentikasi, Anda harus memastikan terlebih dahulu bahwa VM Anda dikonfigurasi untuk menggunakan akun layanan. Untuk melakukannya, selesaikan salah satu prosedur berikut:
- Untuk menyiapkan akun layanan selama pembuatan VM, baca bagian Membuat VM yang menggunakan akun layanan yang dikelola pengguna.
- Untuk menyiapkan akun layanan di VM yang ada, lihat Mengubah akun layanan yang terpasang.
Sebelum memulai
- Tinjau Ringkasan akun layanan.
-
Siapkan autentikasi, jika Anda belum melakukannya.
Autentikasi adalah proses verifikasi identitas Anda untuk akses ke layanan dan API Google Cloud.
Untuk menjalankan kode atau contoh dari lingkungan pengembangan lokal, Anda dapat melakukan autentikasi ke Compute Engine sebagai berikut.
Untuk menggunakan contoh Python di halaman ini dari lingkungan pengembangan lokal, instal dan lakukan inisialisasi gcloud CLI, lalu siapkan Kredensial Default Aplikasi dengan kredensial pengguna Anda.
- Menginstal Google Cloud CLI.
-
Untuk initialize gcloud CLI, jalankan perintah berikut:
gcloud init
-
Buat kredensial autentikasi lokal untuk Akun Google Anda:
gcloud auth application-default login
Untuk informasi selengkapnya, lihat Siapkan autentikasi untuk lingkungan pengembangan lokal.
Ringkasan
Setelah Anda menyiapkan instance VM untuk dijalankan menggunakan akun layanan, aplikasi yang berjalan pada instance VM dapat menggunakan salah satu metode berikut untuk autentikasi:
- Untuk sebagian besar aplikasi, pilih salah satu opsi berikut:
- Untuk aplikasi yang memerlukan token akses OAuth2, minta dan gunakan token akses langsung dari server metadata
Mengautentikasi aplikasi menggunakan kredensial akun layanan
Setelah menyiapkan instance untuk dijalankan sebagai akun layanan, Anda dapat menggunakan kredensial akun layanan untuk mengautentikasi aplikasi yang berjalan pada instance tersebut.
Mengautentikasi aplikasi dengan library klien
Library klien dapat menggunakan Kredensial Default Aplikasi untuk melakukan autentikasi dengan Google API dan mengirim permintaan ke API tersebut. Kredensial Default Aplikasi memungkinkan aplikasi mendapatkan kredensial secara otomatis dari berbagai sumber, sehingga Anda dapat menguji aplikasi secara lokal, lalu men-deploy-nya ke instance Compute Engine tanpa mengubah kode aplikasi.
Untuk mengetahui informasi tentang cara menyiapkan Kredensial Default Aplikasi, lihat Memberikan kredensial ke Kredensial Default Aplikasi.
Contoh ini menggunakan library klien Python untuk mengautentikasi dan membuat permintaan ke Cloud Storage API untuk mencantumkan bucket dalam sebuah project. Contoh tersebut menggunakan prosedur berikut:
- Dapatkan kredensial autentikasi yang diperlukan untuk Cloud Storage API dan lakukan inisialisasi layanan Cloud Storage dengan metode
build()
dan kredensial tersebut. - Cantumkan bucket di Cloud Storage.
Anda dapat menjalankan contoh ini pada instance yang memiliki akses untuk mengelola bucket di Cloud Storage.
Mengautentikasi aplikasi secara langsung dengan token akses
Untuk sebagian besar aplikasi, Anda dapat melakukan autentikasi menggunakan Kredensial Default Aplikasi, yang menemukan kredensial dan mengelola token untuk Anda. Namun, jika aplikasi Anda mengharuskan Anda menyediakan token akses OAuth2, Compute Engine memungkinkan Anda mendapatkan token akses dari server metadatanya untuk digunakan dalam aplikasi Anda.
Ada beberapa opsi untuk mendapatkan dan menggunakan token akses ini untuk mengautentikasi aplikasi Anda. Misalnya, Anda dapat menggunakan
curl
untuk membuat permintaan sederhana, atau menggunakan bahasa pemrograman seperti Python
agar lebih fleksibel.
cURL
Untuk menggunakan curl
guna meminta token akses dan mengirim permintaan ke API:
Pada instance tempat aplikasi Anda berjalan, buat kueri token akses ke server metadata dengan menjalankan perintah berikut:
$ curl "http://metadata.google.internal/computeMetadata/v1/instance/service-accounts/default/token" \ -H "Metadata-Flavor: Google"
Permintaan tersebut menampilkan respons yang mirip dengan:
{ "access_token":"ya29.AHES6ZRN3-HlhAPya30GnW_bHSb_QtAS08i85nHq39HE3C2LTrCARA", "expires_in":3599, "token_type":"Bearer" }
Untuk permintaan API, Anda harus menyertakan nilai
access_token
, bukan seluruh respons. Jika telah menginstal prosesor JSON command line jq, Anda dapat menggunakan perintah berikut untuk mengekstrak nilai token akses dari respons:$ ACCESS_TOKEN=`curl \ "http://metadata.google.internal/computeMetadata/v1/instance/service-accounts/default/token" \ -H "Metadata-Flavor: Google" | jq -r '.access_token'`
Salin nilai properti
access_token
dari respons dan gunakan untuk mengirim permintaan ke API. Misalnya, permintaan berikut mencetak daftar instance dalam project Anda dari zona tertentu:$ curl https://compute.googleapis.com/compute/v1/projects/PROJECT_ID/zones/ZONE/instances \ -H "Authorization":"Bearer ACCESS_TOKEN"
Ganti kode berikut:
PROJECT_ID
: ID project untuk permintaan ini.ZONE
: zona untuk membuat daftar VM.ACCESS_TOKEN
: nilai token akses yang Anda dapatkan dari langkah sebelumnya.
Untuk mengetahui informasi tentang parameter yang dapat ditetapkan dalam permintaan, lihat dokumentasi Parameter sistem.
Python
Contoh ini menunjukkan cara meminta token untuk mengakses Cloud Storage API dalam aplikasi Python. Contoh tersebut menggunakan prosedur berikut:
- Meminta token akses dari server metadata.
- Mengekstrak token akses dari respons server.
- Menggunakan token akses untuk membuat permintaan ke Cloud Storage.
- Jika permintaan berhasil, skrip akan mencetak respons.
Token akses tidak berlaku lagi setelah beberapa saat. Server metadata menyimpan token akses ke dalam cache hingga memiliki sisa waktu 5 menit sebelum masa berlakunya berakhir. Jika token tidak dapat disimpan dalam cache, permintaan yang melebihi 50 kueri per detik mungkin dibatasi kapasitasnya. Aplikasi Anda harus memiliki token akses yang valid agar panggilan API berhasil.
Mengautentikasi alat pada instance menggunakan akun layanan
Beberapa aplikasi mungkin menggunakan perintah dari alat gcloud
dan gsutil
, yang disertakan secara default di sebagian besar image Compute Engine. Alat ini secara otomatis mengenali akun layanan instance dan izin relevan yang diberikan ke akun layanan. Khususnya, jika Anda memberikan peran yang benar
ke akun layanan, Anda dapat menggunakan alat gcloud
dan gsutil
dari
instance Anda tanpa harus menggunakan gcloud auth login
.
Pengenalan akun layanan ini terjadi secara otomatis dan hanya berlaku untuk alat gcloud
dan gsutil
yang disertakan dengan instance. Jika membuat alat baru atau menambahkan alat kustom, Anda harus mengizinkan aplikasi Anda menggunakan library klien atau dengan menggunakan token akses langsung di aplikasi Anda.
Untuk memanfaatkan pengenalan akun layanan otomatis, berikan peran IAM yang sesuai ke akun layanan dan lampirkan akun layanan ke instance.
Misalnya, jika Anda memberikan peran roles/storage.objectAdmin
ke akun layanan, alat gsutil
dapat mengelola dan mengakses objek Cloud Storage secara otomatis.
Demikian pula, jika Anda mengaktifkan roles/compute.instanceAdmin.v1
untuk akun layanan, alat gcloud compute
dapat mengelola instance secara otomatis.
Langkah selanjutnya
- Mengautentikasi beban kerja ke beban kerja lain melalui mTLS .
- Pelajari lebih lanjut tentang Akun Layanan.
- Pelajari peran dan izin IAM Compute Engine lebih lanjut.
- Pelajari lebih lanjut tentang praktik terbaik untuk menggunakan akun layanan.
Cobalah sendiri
Jika Anda baru pertama kali menggunakan Google Cloud, buat akun untuk mengevaluasi performa Compute Engine dalam skenario dunia nyata. Pelanggan baru mendapatkan kredit gratis senilai $300 untuk menjalankan, menguji, dan men-deploy workload.
Coba Compute Engine gratis