Dokumen ini menjelaskan cara membuat dan menjalankan tugas yang menggunakan unit pemrosesan grafis (GPU). Untuk mempelajari lebih lanjut fitur dan batasan GPU, lihat Tentang GPU dalam dokumentasi Compute Engine.
Saat membuat tugas Batch, Anda dapat menggunakan GPU secara opsional untuk mempercepat workload tertentu. Kasus penggunaan umum untuk tugas yang menggunakan GPU mencakup pemrosesan data intensif dan workload kecerdasan buatan (AI) seperti machine learning (ML).
Sebelum memulai
- Jika belum pernah menggunakan Batch, baca Mulai menggunakan Batch dan aktifkan Batch dengan menyelesaikan prasyarat untuk project dan pengguna.
-
Untuk mendapatkan izin yang diperlukan untuk membuat tugas, minta administrator untuk memberi Anda peran IAM berikut:
-
Batch Job Editor (
roles/batch.jobsEditor) di project -
Pengguna Akun Layanan (
roles/iam.serviceAccountUser) di akun layanan tugas, yang secara default adalah akun layanan Compute Engine default
Untuk mengetahui informasi selengkapnya tentang pemberian peran, lihat Mengelola akses ke project, folder, dan organisasi.
Anda mungkin juga bisa mendapatkan izin yang diperlukan melalui peran khusus atau peran bawaan lainnya.
-
Batch Job Editor (
Membuat tugas yang menggunakan GPU
Untuk membuat tugas yang menggunakan GPU, lakukan hal berikut:
- Rencanakan persyaratan untuk tugas yang menggunakan GPU.
- Buat tugas dengan persyaratan dan metode yang telah Anda identifikasi. Untuk contoh cara membuat tugas menggunakan opsi yang direkomendasikan, lihat Membuat contoh tugas yang menggunakan GPU dalam dokumen ini.
Merencanakan persyaratan untuk tugas yang menggunakan GPU
Sebelum membuat tugas yang menggunakan GPU, rencanakan persyaratan tugas seperti yang dijelaskan di bagian berikut:
Langkah 1: Pilih jenis mesin GPU dan opsi penggunaan
Persyaratan tugas bervariasi berdasarkan jenis mesin GPU dan opsi penggunaan yang Anda inginkan, dan opsi untuk setiap jenis mesin GPU dan opsi penggunaan mungkin saling bergantung.
Untuk memilih jenis mesin GPU dan opsi penggunaan untuk tugas Anda, selesaikan langkah-langkah berikut:
Identifikasi dan pilih prioritas Anda:
- Jika Anda ingin memprioritaskan performa dan harga dasar, lihat bagian Pilih jenis mesin GPU dalam dokumen ini.
- Jika Anda ingin memprioritaskan ketersediaan resource atau diskon, lihat bagian Pilih opsi konsumsi dalam dokumen ini.
Buat pilihan yang tersisa berdasarkan apa yang kompatibel dengan pilihan pertama Anda.
Untuk mengidentifikasi opsi yang kompatibel dengan pilihan pertama Anda, lihat Ketersediaan opsi konsumsi menurut jenis mesin dalam dokumentasi Compute Engine.
Lihat bagian yang tersisa untuk Pilih opsi penggunaan atau Pilih jenis mesin GPU.
Pilih jenis mesin GPU
Untuk memilih jenis mesin GPU untuk tugas dan memahami persyaratan tugasnya, selesaikan langkah-langkah berikut:
Pilih jenis mesin GPU: Untuk meninjau jenis mesin GPU yang tersedia (kombinasi yang valid dari jenis GPU, jumlah GPU, dan jenis mesin (vCPU dan memori)) serta kasus penggunaan yang direkomendasikan, lihat Jenis mesin GPU dan Kelompok mesin yang dioptimalkan akselerator dalam dokumentasi Compute Engine.
Pahami persyaratan tugas untuk jenis mesin GPU Anda: Kolom yang diperlukan agar tugas dapat menentukan jenis mesin GPU bervariasi berdasarkan kategori dalam tabel berikut:
Jenis mesin GPU dan persyaratan tugasnya GPU untuk VM yang dioptimalkan akselerator: VM dengan jenis mesin dari kelompok mesin yang dioptimalkan akselerator memiliki jenis dan jumlah GPU ini yang terpasang secara otomatis.
Untuk menggunakan GPU bagi VM yang dioptimalkan akselerator, sebaiknya tentukan jenis mesin. Setiap jenis mesin yang dioptimalkan akselerator hanya mendukung jenis dan jumlah GPU tertentu, sehingga secara fungsional setara, baik Anda menentukan atau tidak menentukan nilai tersebut selain jenis mesin yang dioptimalkan akselerator.
Secara khusus, Batch juga mendukung penentuan hanya jenis dan jumlah GPU untuk VM yang dioptimalkan akselerator, tetapi opsi vCPU dan memori yang dihasilkan sering kali sangat terbatas. Oleh karena itu, sebaiknya Anda memverifikasi bahwa opsi vCPU dan memori yang tersedia kompatibel dengan persyaratan tugas pekerjaan.
GPU untuk VM N1: GPU ini mengharuskan Anda menentukan jenis dan jumlah yang akan dipasang ke setiap VM dan harus dipasang ke VM dengan jenis mesin dari seri mesin N1.
Untuk menggunakan GPU bagi VM N1, sebaiknya tentukan setidaknya jenis GPU dan jumlah GPU. Pastikan kombinasi nilai cocok dengan salah satu opsi GPU yang valid untuk jenis mesin N1. Opsi vCPU dan memori untuk VM N1 yang menggunakan jenis dan jumlah GPU tertentu cukup fleksibel. Kecuali jika Anda membuat tugas menggunakan konsol Google Cloud , Anda dapat mengizinkan Batch memilih jenis mesin secara otomatis yang memenuhi persyaratan tugas.
Pilih opsi konsumsi
Bagian ini merangkum cara memilih opsi pemakaian untuk tugas dan persyaratan tugas untuk setiap opsi.
Opsi penggunaan yang tersedia untuk Batch dan persyaratannya dijelaskan dalam tabel berikut, yang mencantumkannya berdasarkan kasus penggunaannya: dari ketersediaan resource yang kira-kira tertinggi hingga terendah.
Singkatnya, sebaiknya sebagian besar pengguna memilih opsi penggunaan untuk tugas sebagai berikut:
- Kecuali jika salah satu kondisi lainnya benar, gunakan VM mulai fleksibel (Pratinjau) (lebih disarankan, jika memenuhi persyaratan Anda) atau sesuai permintaan.
- Jika tugas Anda memerlukan jaminan ketersediaan resource yang sangat tinggi atau jika Anda memiliki pemesanan yang tidak digunakan dan tidak dapat dihapus, gunakan pemesanan mode kalender (Pratinjau) (lebih disarankan, jika memenuhi persyaratan Anda) atau pemesanan.
- (Opsional) Jika workload Anda sangat fault-tolerant, Anda mungkin dapat mengurangi biaya dengan mencoba menggunakan Spot VM.
| Opsi konsumsi dan persyaratan tugasnya | |
|---|---|
Pemesanan
|
Batch menggunakan reservasi untuk tugas yang dapat memakai VM yang dipesan dan tidak digunakan. Untuk mengetahui informasi selengkapnya tentang persyaratan tugas untuk menggunakan reservasi, lihat halaman Memastikan ketersediaan resource menggunakan reservasi VM. |
Reservasi mode kalender (Pratinjau)
|
Batch menggunakan reservasi mode kalender untuk tugas yang melakukan semua hal berikut:
|
VM mulai fleksibel (Pratinjau)
|
Batch menggunakan VM mulai fleksibel untuk tugas yang melakukan semua hal berikut:
|
Sesuai permintaan
|
Batch menggunakan on-demand untuk sebagian besar tugas lainnya secara default. Jika Anda ingin memastikan bahwa job menggunakan on-demand, lakukan semua hal berikut:1
1Pengecualian: Untuk tugas yang menggunakan seri mesin A3, perilaku
defaultnya unik, dan sebaiknya Anda tidak menggunakan on-demand dan tidak
membiarkan kolom |
Spot VM
|
Batch menggunakan Spot VM untuk tugas yang memenuhi semua hal berikut:
|
Langkah 2: Instal driver GPU
Untuk menggunakan GPU dalam tugas, Anda harus menginstal driver GPU. Untuk menginstal driver GPU, pilih salah satu metode berikut:
Instal driver GPU secara otomatis (direkomendasikan jika memungkinkan): Seperti yang ditunjukkan dalam contoh, agar Batch mengambil driver GPU yang diperlukan dari lokasi pihak ketiga dan menginstalnya atas nama Anda, tetapkan kolom
installGpuDriversuntuk tugas ketrue. Metode ini direkomendasikan jika tugas Anda tidak mengharuskan Anda menginstal driver secara manual.Secara opsional, jika Anda perlu menentukan versi driver GPU yang diinstal Batch, tetapkan juga kolom
driverVersion.Menginstal driver GPU secara manual: Metode ini diperlukan jika salah satu kondisi berikut terpenuhi:
- Tugas menggunakan script dan container runnable, serta tidak memiliki akses internet. Untuk mengetahui informasi selengkapnya tentang akses yang dimiliki tugas, lihat Ringkasan jaringan batch.
- Tugas menggunakan image VM kustom. Untuk mempelajari lebih lanjut image OS VM dan image OS VM yang dapat Anda gunakan, lihat Ringkasan lingkungan OS VM.
Untuk menginstal driver GPU yang diperlukan secara manual, metode berikut direkomendasikan:
Buat image VM kustom yang menyertakan driver GPU.
Untuk menginstal driver GPU, jalankan skrip penginstalan berdasarkan OS yang ingin Anda gunakan:
Jika tugas Anda memiliki runnable container dan tidak menggunakan Container-Optimized OS, Anda juga harus menginstal NVIDIA Container Toolkit
Saat Anda membuat dan mengirimkan tugas yang menggunakan GPU, tentukan image VM kustom yang menyertakan driver GPU, dan tetapkan kolom
installGpuDriversuntuk tugas kefalse(default).
Langkah 3: Tentukan resource VM yang kompatibel
Untuk mempelajari persyaratan dan opsi dalam menentukan resource VM untuk tugas, lihat Resource tugas.
Singkatnya, Anda harus melakukan semua hal berikut saat menentukan resource VM untuk tugas yang menggunakan GPU:
Pastikan jenis mesin GPU tersedia di lokasi VM tugas Anda.
Untuk mempelajari tempat jenis mesin GPU tersedia, lihat Ketersediaan akselerator dalam dokumentasi Compute Engine.
Jika Anda menentukan jenis mesin tugas, pastikan jenis mesin tersebut memiliki vCPU dan memori yang cukup untuk persyaratan tugas. Jenis mesin tugas harus ditentukan setiap kali Anda membuat tugas menggunakan konsol Google Cloud dan direkomendasikan setiap kali Anda membuat tugas yang menggunakan GPU untuk VM yang dioptimalkan untuk akselerator.
Pastikan Anda menentukan resource VM untuk tugas menggunakan metode yang valid:
- Tentukan resource VM secara langsung menggunakan kolom
instances[].policy(direkomendasikan jika memungkinkan). Metode ini ditunjukkan dalam contoh. - Tentukan resource VM melalui template menggunakan kolom
instances[].instanceTemplate. Metode ini diperlukan untuk menginstal driver GPU secara manual melalui image kustom. Untuk mengetahui informasi selengkapnya, lihat Menentukan resource tugas menggunakan template instance VM.
- Tentukan resource VM secara langsung menggunakan kolom
Buat contoh tugas yang menggunakan GPU
Bagian berikut menjelaskan cara membuat contoh tugas untuk setiap opsi penggunaan. Secara khusus, contoh tugas menggunakan opsi yang direkomendasikan: semua menginstal driver GPU secara otomatis, dan semua menentukan resource VM secara langsung.
| Opsi konsumsi | Contoh petunjuk tugas |
|---|---|
| Reservasi atau reservasi mode kalender (Pratinjau) | |
| VM mulai fleksibel (Pratinjau) | |
| VM Sesuai Permintaan atau Spot VM |
Pilih salah satu opsi berikut berdasarkan jenis mesin GPU Anda: |
Menggunakan GPU dan VM mulai fleksibel
Anda dapat membuat tugas yang menggunakan GPU untuk VM A3 melalui Dynamic Workload Scheduler menggunakan gcloud CLI atau Batch API.
gcloud
Buat file JSON yang menginstal driver GPU, menentukan jenis mesin GPU yang mendukung VM Flex-start, memblokir reservasi, dan berjalan di lokasi yang mendukung jenis mesin GPU.
Misalnya, untuk membuat tugas skrip dasar yang menggunakan VM dan GPU mulai fleksibel untuk VM yang dioptimalkan untuk akselerator, buat file JSON dengan konten berikut.
{ "taskGroups": [ { "taskSpec": { "runnables": [ { "script": { "text": "echo Hello world from task ${BATCH_TASK_INDEX}." } } ] }, "taskCount": 3, "parallelism": 1 } ], "allocationPolicy": { "instances": [ { "installGpuDrivers": INSTALL_GPU_DRIVERS, "policy": { "provisioningModel":"FLEX_START", "machineType": "MACHINE_TYPE", "reservation": "NO_RESERVATION" } } ], "location": { "allowedLocations": [ "ALLOWED_LOCATIONS" ] } }, "logsPolicy": { "destination": "CLOUD_LOGGING" } }Ganti kode berikut:
INSTALL_GPU_DRIVERS: Jika disetel ketrue, Batch akan mengambil driver yang diperlukan untuk jenis GPU yang Anda tentukan di kolompolicydari lokasi pihak ketiga, dan Batch akan menginstalnya untuk Anda. Jika Anda menyetel kolom ini kefalse(default), Anda harus menginstal driver GPU secara manual untuk menggunakan GPU apa pun untuk tugas ini.MACHINE_TYPE: jenis mesin GPU yang mendukung VM dengan fitur Mulai fleksibel. Untuk mengetahui informasi selengkapnya, lihat Ketersediaan opsi konsumsi menurut jenis mesin dalam dokumentasi Compute Engine.ALLOWED_LOCATIONS: Anda dapat secara opsional menggunakan kolomallowedLocations[]untuk menentukan region atau zona tertentu dalam region tempat VM untuk tugas Anda diizinkan berjalan—misalnya,regions/us-central1mengizinkan semua zona di regionus-central1. Pastikan Anda menentukan lokasi yang menawarkan jenis mesin GPU yang Anda inginkan untuk tugas ini. Jika tidak, jika Anda menghapus kolom ini, pastikan lokasi tugas menawarkan jenis mesin GPU.
Untuk membuat dan menjalankan tugas, gunakan perintah
gcloud alpha batch jobs submit:gcloud batch jobs submit JOB_NAME \ --location LOCATION \ --config JSON_CONFIGURATION_FILEGanti kode berikut:
JOB_NAME: nama tugas.LOCATION: lokasi tugas.JSON_CONFIGURATION_FILE: jalur untuk file JSON dengan detail konfigurasi tugas.
API
Buat permintaan POST ke
metode jobs.create v1alpha
yang menginstal driver GPU, menentukan jenis mesin GPU yang mendukung
VM mulai fleksibel, memblokir reservasi, dan berjalan di lokasi yang
mendukung jenis mesin GPU.
Misalnya, untuk membuat tugas skrip dasar yang menggunakan VM dan GPU dengan mulai fleksibel untuk VM yang dioptimalkan akselerator, buat permintaan berikut:
POST https://batch.googleapis.com/v1alpha/projects/PROJECT_ID/locations/LOCATION/jobs?job_id=JOB_NAME
{
"taskGroups": [
{
"taskSpec": {
"runnables": [
{
"script": {
"text": "echo Hello world from task ${BATCH_TASK_INDEX}."
}
}
]
},
"taskCount": 3,
"parallelism": 1
}
],
"allocationPolicy": {
"instances": [
{
"installGpuDrivers": INSTALL_GPU_DRIVERS,
"policy": {
"provisioningModel":"FLEX_START",
"machineType": "MACHINE_TYPE",
"reservation": "NO_RESERVATION"
}
}
],
"location": {
"allowedLocations": [
"ALLOWED_LOCATIONS"
]
}
},
"logsPolicy": {
"destination": "CLOUD_LOGGING"
}
}
Ganti kode berikut:
PROJECT_ID: Project ID project Anda.LOCATION: lokasi tugas.JOB_NAME: nama tugas.INSTALL_GPU_DRIVERS: Jika disetel ketrue, Batch akan mengambil driver yang diperlukan untuk jenis GPU yang Anda tentukan di kolompolicydari lokasi pihak ketiga, dan Batch akan menginstalnya untuk Anda. Jika Anda menyetel kolom ini kefalse(default), Anda harus menginstal driver GPU secara manual untuk menggunakan GPU apa pun untuk tugas ini.MACHINE_TYPE: jenis mesin GPU yang mendukung VM dengan fitur Mulai fleksibel. Untuk mengetahui informasi selengkapnya, lihat Ketersediaan opsi konsumsi menurut jenis mesin dalam dokumentasi Compute Engine.ALLOWED_LOCATIONS: Anda dapat secara opsional menggunakan kolomallowedLocations[]untuk menentukan region atau zona tertentu dalam region tempat VM untuk tugas Anda diizinkan berjalan—misalnya,regions/us-central1mengizinkan semua zona di regionus-central1. Pastikan Anda menentukan lokasi yang menawarkan jenis mesin GPU yang Anda inginkan untuk tugas ini. Jika tidak, jika Anda menghapus kolom ini, pastikan lokasi tugas menawarkan jenis mesin GPU.
Menggunakan GPU untuk VM yang dioptimalkan akselerator
Anda dapat membuat tugas yang menggunakan GPU untuk VM yang dioptimalkan akselerator menggunakan Google Cloud konsol, gcloud CLI, Batch API, Java, Node.js, atau Python.
Konsol
Untuk membuat tugas yang menggunakan GPU menggunakan konsol Google Cloud , lakukan hal berikut:
Di konsol Google Cloud , buka halaman Daftar tugas.
Klik Create. Halaman Create batch job akan terbuka. Di panel kiri, halaman Job details dipilih.
Konfigurasi halaman Detail pekerjaan:
Opsional: Di kolom Nama tugas, sesuaikan nama tugas.
Misalnya, masukkan
example-gpu-job.Konfigurasi bagian Detail tugas:
Di jendela Dapat dijalankan baru, tambahkan setidaknya satu skrip atau penampung agar tugas ini dapat dijalankan.
Misalnya, untuk membuat tugas skrip dasar, lakukan hal berikut:
Centang kotak Script. Kolom akan muncul.
Di kolom, masukkan skrip berikut:
echo Hello world from task ${BATCH_TASK_INDEX}.Klik Done.
Di kolom Jumlah tugas, masukkan jumlah tugas untuk tugas ini.
Misalnya, masukkan
3.Opsional: Di kolom Paralelisme, masukkan jumlah tugas yang akan dijalankan secara bersamaan.
Misalnya, masukkan
1(default).
Konfigurasi halaman Spesifikasi resource:
Di panel kiri, klik Spesifikasi resource. Halaman Spesifikasi resource akan terbuka.
Di bagian Model penyediaan VM, pilih salah satu opsi berikut untuk opsi penggunaan untuk VM tugas ini:
Jika tugas Anda dapat bertahan dari preemption dan Anda menginginkan Spot VM yang didiskon, pilih Spot.
Jika tidak, untuk menggunakan VM sesuai permintaan, pilih Standar (default).
Pilih lokasi untuk tugas ini.
Di kolom Region, pilih region.
Di kolom Zone, lakukan salah satu hal berikut:
Jika Anda ingin membatasi tugas ini agar hanya berjalan di zona tertentu, pilih zona.
Jika tidak, pilih apa saja (default).
Pilih jenis mesin GPU untuk VM tugas ini:
Di opsi kelompok mesin, klik GPU.
Di kolom GPU type, pilih jenis GPU. Kemudian, di kolom Number of GPUs, pilih jumlah GPU untuk setiap VM.
Jika Anda memilih salah satu jenis GPU untuk VM yang dioptimalkan akselerator, kolom Jenis mesin hanya mengizinkan satu opsi untuk jenis mesin berdasarkan jenis dan jumlah GPU yang Anda pilih.
Untuk menginstal driver GPU secara otomatis, pilih GPU driver installation (default).
Konfigurasi jumlah resource VM yang diperlukan untuk setiap tugas:
Di kolom Cores, masukkan jumlah vCPUs per tugas.
Misalnya, masukkan
1(default).Di kolom Memory, masukkan jumlah RAM dalam GB per tugas.
Misalnya, masukkan
0.5(default).
Klik Done.
Opsional: Konfigurasi kolom lainnya untuk tugas ini.
Opsional: Untuk meninjau konfigurasi tugas, di panel kiri, klik Pratinjau.
Klik Buat.
Halaman Job details menampilkan tugas yang Anda buat.
gcloud
Buat file JSON yang menginstal driver GPU, menentukan jenis mesin dari kelompok mesin yang dioptimalkan akselerator, dan berjalan di lokasi yang memiliki jenis mesin GPU.
Misalnya, untuk membuat tugas skrip dasar yang menggunakan GPU untuk VM yang dioptimalkan untuk akselerator, buat file JSON dengan konten berikut:
{ "taskGroups": [ { "taskSpec": { "runnables": [ { "script": { "text": "echo Hello world from task ${BATCH_TASK_INDEX}." } } ] }, "taskCount": 3, "parallelism": 1 } ], "allocationPolicy": { "instances": [ { "installGpuDrivers": INSTALL_GPU_DRIVERS, "policy": { "provisioningModel": "PROVISIONING_MODEL", "machineType": "MACHINE_TYPE", "reservation": "NO_RESERVATION" } } ], "location": { "allowedLocations": [ "ALLOWED_LOCATIONS" ] } }, "logsPolicy": { "destination": "CLOUD_LOGGING" } }Ganti kode berikut:
INSTALL_GPU_DRIVERS: Jika disetel ketrue, Batch akan mengambil driver yang diperlukan untuk jenis GPU yang Anda tentukan di kolompolicydari lokasi pihak ketiga, dan Batch akan menginstalnya untuk Anda. Jika Anda menyetel kolom ini kefalse(default), Anda harus menginstal driver GPU secara manual untuk menggunakan GPU apa pun untuk tugas ini.PROVISIONING_MODEL: model penyediaan untuk opsi penggunaan Anda:STANDARDuntuk VM on-demand atauSPOTuntuk Spot VM.MACHINE_TYPE: jenis mesin dari kelompok mesin yang dioptimalkan akselerator.ALLOWED_LOCATIONS: Anda dapat secara opsional menggunakan kolomallowedLocations[]untuk menentukan region atau zona tertentu dalam region tempat VM untuk tugas Anda diizinkan berjalan—misalnya,regions/us-central1mengizinkan semua zona di regionus-central1. Pastikan Anda menentukan lokasi yang menawarkan jenis mesin GPU yang Anda inginkan untuk tugas ini. Jika tidak, jika Anda menghapus kolom ini, pastikan lokasi tugas menawarkan jenis mesin GPU.
Untuk membuat dan menjalankan tugas, gunakan perintah
gcloud batch jobs submit:gcloud batch jobs submit JOB_NAME \ --location LOCATION \ --config JSON_CONFIGURATION_FILEGanti kode berikut:
JOB_NAME: nama tugas.LOCATION: lokasi tugas.JSON_CONFIGURATION_FILE: jalur untuk file JSON dengan detail konfigurasi tugas.
API
Buat permintaan POST ke
metode jobs.create
yang menginstal driver GPU, menentukan jenis mesin dari
kelompok mesin yang dioptimalkan akselerator, dan berjalan di lokasi yang memiliki
jenis mesin GPU.
Misalnya, untuk membuat tugas skrip dasar yang menggunakan GPU untuk VM yang dioptimalkan untuk akselerator, buat permintaan berikut:
POST https://batch.googleapis.com/v1/projects/PROJECT_ID/locations/LOCATION/jobs?job_id=JOB_NAME
{
"taskGroups": [
{
"taskSpec": {
"runnables": [
{
"script": {
"text": "echo Hello world from task ${BATCH_TASK_INDEX}."
}
}
]
},
"taskCount": 3,
"parallelism": 1
}
],
"allocationPolicy": {
"instances": [
{
"installGpuDrivers": INSTALL_GPU_DRIVERS,
"policy": {
"provisioningModel": "PROVISIONING_MODEL",
"machineType": "MACHINE_TYPE",
"reservation": "NO_RESERVATION"
}
}
],
"location": {
"allowedLocations": [
"ALLOWED_LOCATIONS"
]
}
},
"logsPolicy": {
"destination": "CLOUD_LOGGING"
}
}
Ganti kode berikut:
PROJECT_ID: Project ID project Anda.LOCATION: lokasi tugas.JOB_NAME: nama tugas.INSTALL_GPU_DRIVERS: Jika disetel ketrue, Batch akan mengambil driver yang diperlukan untuk jenis GPU yang Anda tentukan di kolompolicydari lokasi pihak ketiga, dan Batch akan menginstalnya untuk Anda. Jika Anda menyetel kolom ini kefalse(default), Anda harus menginstal driver GPU secara manual untuk menggunakan GPU apa pun untuk tugas ini.PROVISIONING_MODEL: model penyediaan untuk opsi penggunaan Anda:STANDARDuntuk VM on-demand atauSPOTuntuk Spot VM.MACHINE_TYPE: jenis mesin dari kelompok mesin yang dioptimalkan akselerator.ALLOWED_LOCATIONS: Anda dapat secara opsional menggunakan kolomallowedLocations[]untuk menentukan region atau zona tertentu dalam region tempat VM untuk tugas Anda diizinkan berjalan—misalnya,regions/us-central1mengizinkan semua zona di regionus-central1. Pastikan Anda menentukan lokasi yang menawarkan jenis mesin GPU yang Anda inginkan untuk tugas ini. Jika tidak, jika Anda menghapus kolom ini, pastikan lokasi tugas menawarkan jenis mesin GPU.
Java
Node.js
Python
Menggunakan GPU untuk VM N1
Anda dapat membuat tugas yang menggunakan GPU untuk VM N1 menggunakan Google Cloud konsol, gcloud CLI, Batch API, Java, Node.js, atau Python.
Konsol
Untuk membuat tugas yang menggunakan GPU menggunakan konsol Google Cloud , lakukan hal berikut:
Di konsol Google Cloud , buka halaman Daftar tugas.
Klik Create. Halaman Create batch job akan terbuka. Di panel kiri, halaman Job details dipilih.
Konfigurasi halaman Detail pekerjaan:
Opsional: Di kolom Nama tugas, sesuaikan nama tugas.
Misalnya, masukkan
example-gpu-job.Konfigurasi bagian Detail tugas:
Di jendela Dapat dijalankan baru, tambahkan setidaknya satu skrip atau penampung agar tugas ini dapat dijalankan.
Misalnya, untuk membuat tugas skrip dasar, lakukan hal berikut:
Centang kotak Script. Kolom akan muncul.
Di kolom, masukkan skrip berikut:
echo Hello world from task ${BATCH_TASK_INDEX}.Klik Done.
Di kolom Jumlah tugas, masukkan jumlah tugas untuk tugas ini.
Misalnya, masukkan
3.Opsional: Di kolom Paralelisme, masukkan jumlah tugas yang akan dijalankan secara bersamaan.
Misalnya, masukkan
1(default).
Konfigurasi halaman Spesifikasi resource:
Di panel kiri, klik Spesifikasi resource. Halaman Spesifikasi resource akan terbuka.
Di bagian Model penyediaan VM, pilih salah satu opsi berikut untuk opsi penggunaan untuk VM tugas ini:
Jika tugas Anda dapat bertahan dari preemption dan Anda menginginkan Spot VM yang didiskon, pilih Spot.
Jika tidak, untuk menggunakan VM sesuai permintaan, pilih Standar (default).
Pilih lokasi untuk tugas ini.
Di kolom Region, pilih region.
Di kolom Zone, lakukan salah satu hal berikut:
Jika Anda ingin membatasi tugas ini agar hanya berjalan di zona tertentu, pilih zona.
Jika tidak, pilih apa saja (default).
Pilih jenis mesin GPU untuk VM tugas ini:
Di opsi kelompok mesin, klik GPU.
Di kolom GPU type, pilih jenis GPU.
Jika Anda memilih salah satu jenis GPU untuk VM N1, maka kolom Seri akan disetel ke N1.
Di kolom Number of GPUs, pilih jumlah GPU untuk setiap VM.
Di kolom Machine type, pilih jenis mesin.
Untuk menginstal driver GPU secara otomatis, pilih GPU driver installation (default).
Konfigurasi jumlah resource VM yang diperlukan untuk setiap tugas:
Di kolom Cores, masukkan jumlah vCPUs per tugas.
Misalnya, masukkan
1(default).Di kolom Memory, masukkan jumlah RAM dalam GB per tugas.
Misalnya, masukkan
0.5(default).
Klik Done.
Opsional: Konfigurasi kolom lainnya untuk tugas ini.
Opsional: Untuk meninjau konfigurasi tugas, di panel kiri, klik Pratinjau.
Klik Buat.
Halaman Job details menampilkan tugas yang Anda buat.
gcloud
Buat file JSON yang menginstal driver GPU, menentukan sub-bidang
typedancountdari kolomaccelerators[], dan berjalan di lokasi yang memiliki jenis mesin GPU.Misalnya, untuk membuat tugas skrip dasar yang menggunakan GPU untuk VM N1 dan memungkinkan Batch memilih jenis mesin N1 yang tepat, buat file JSON dengan konten berikut:
{ "taskGroups": [ { "taskSpec": { "runnables": [ { "script": { "text": "echo Hello world from task ${BATCH_TASK_INDEX}." } } ] }, "taskCount": 3, "parallelism": 1 } ], "allocationPolicy": { "instances": [ { "installGpuDrivers": INSTALL_GPU_DRIVERS, "policy": { "provisioningModel": "PROVISIONING_MODEL", "reservation": "NO_RESERVATION", "accelerators": [ { "type": "GPU_TYPE", "count": GPU_COUNT } ] } } ], "location": { "allowedLocations": [ "ALLOWED_LOCATIONS" ] } }, "logsPolicy": { "destination": "CLOUD_LOGGING" } }Ganti kode berikut:
INSTALL_GPU_DRIVERS: Jika disetel ketrue, Batch akan mengambil driver yang diperlukan untuk jenis GPU yang Anda tentukan di kolompolicydari lokasi pihak ketiga, dan Batch akan menginstalnya untuk Anda. Jika Anda menyetel kolom ini kefalse(default), Anda harus menginstal driver GPU secara manual untuk menggunakan GPU apa pun untuk tugas ini.PROVISIONING_MODEL: model penyediaan untuk opsi penggunaan Anda:STANDARDuntuk VM on-demand atauSPOTuntuk Spot VM.GPU_TYPE: jenis GPU. Anda dapat melihat daftar jenis GPU yang tersedia menggunakan perintahgcloud compute accelerator-types list. Hanya gunakan kolom ini untuk GPU untuk VM N1.GPU_COUNT: jumlah GPU dari jenis yang ditentukan. Untuk mengetahui informasi selengkapnya tentang opsi yang valid, lihat Jenis mesin GPU untuk seri mesin N1. Hanya gunakan kolom ini untuk GPU untuk VM N1.ALLOWED_LOCATIONS: Anda dapat secara opsional menggunakan kolomallowedLocations[]untuk menentukan region atau zona tertentu dalam region tempat VM untuk tugas Anda diizinkan berjalan—misalnya,regions/us-central1mengizinkan semua zona di regionus-central1. Pastikan Anda menentukan lokasi yang menawarkan jenis mesin GPU yang Anda inginkan untuk tugas ini. Jika tidak, jika Anda menghapus kolom ini, pastikan lokasi tugas menawarkan jenis mesin GPU.
Untuk membuat dan menjalankan tugas, gunakan perintah
gcloud batch jobs submit:gcloud batch jobs submit JOB_NAME \ --location LOCATION \ --config JSON_CONFIGURATION_FILEGanti kode berikut:
JOB_NAME: nama tugas.LOCATION: lokasi tugas.JSON_CONFIGURATION_FILE: jalur untuk file JSON dengan detail konfigurasi tugas.
API
Buat permintaan POST ke
metode jobs.create
yang menginstal driver GPU, menentukan
subkolom type dan count
kolom accelerators[], dan menggunakan lokasi yang memiliki jenis mesin GPU.
Misalnya, untuk membuat tugas skrip dasar yang menggunakan GPU untuk VM N1 dan memungkinkan Batch memilih jenis mesin N1 yang tepat, buat permintaan berikut:
POST https://batch.googleapis.com/v1/projects/PROJECT_ID/locations/LOCATION/jobs?job_id=JOB_NAME
{
"taskGroups": [
{
"taskSpec": {
"runnables": [
{
"script": {
"text": "echo Hello world from task ${BATCH_TASK_INDEX}."
}
}
]
},
"taskCount": 3,
"parallelism": 1
}
],
"allocationPolicy": {
"instances": [
{
"installGpuDrivers": INSTALL_GPU_DRIVERS,
"policy": {
"provisioningModel": "PROVISIONING_MODEL",
"reservation": "NO_RESERVATION",
"accelerators": [
{
"type": "GPU_TYPE",
"count": GPU_COUNT
}
]
}
}
],
"location": {
"allowedLocations": [
"ALLOWED_LOCATIONS"
]
}
},
"logsPolicy": {
"destination": "CLOUD_LOGGING"
}
}
Ganti kode berikut:
PROJECT_ID: Project ID project Anda.LOCATION: lokasi tugas.JOB_NAME: nama tugas.INSTALL_GPU_DRIVERS: Jika disetel ketrue, Batch akan mengambil driver yang diperlukan untuk jenis GPU yang Anda tentukan di kolompolicydari lokasi pihak ketiga, dan Batch akan menginstalnya untuk Anda. Jika Anda menyetel kolom ini kefalse(default), Anda harus menginstal driver GPU secara manual untuk menggunakan GPU apa pun untuk tugas ini.PROVISIONING_MODEL: model penyediaan untuk opsi penggunaan Anda:STANDARDuntuk VM on-demand atauSPOTuntuk Spot VM.GPU_TYPE: jenis GPU. Anda dapat melihat daftar jenis GPU yang tersedia menggunakan perintahgcloud compute accelerator-types list. Hanya gunakan kolom ini untuk GPU untuk VM N1.GPU_COUNT: jumlah GPU dari jenis yang ditentukan. Untuk mengetahui informasi selengkapnya tentang opsi yang valid, lihat Jenis mesin GPU untuk seri mesin N1. Hanya gunakan kolom ini untuk GPU untuk VM N1.ALLOWED_LOCATIONS: Anda dapat secara opsional menggunakan kolomallowedLocations[]untuk menentukan region atau zona tertentu dalam region tempat VM untuk tugas Anda diizinkan berjalan—misalnya,regions/us-central1mengizinkan semua zona di regionus-central1. Pastikan Anda menentukan lokasi yang menawarkan jenis mesin GPU yang Anda inginkan untuk tugas ini. Jika tidak, jika Anda menghapus kolom ini, pastikan lokasi tugas menawarkan jenis mesin GPU.
Java
Node.js
Python
Langkah berikutnya
- Jika Anda mengalami masalah saat membuat atau menjalankan tugas, lihat Pemecahan masalah.
- Melihat tugas.
- Pelajari lebih lanjut opsi pembuatan tugas.