Terjemahan disediakan oleh mesin penerjemah. Jika konten terjemahan yang diberikan bertentangan dengan versi bahasa Inggris aslinya, utamakan versi bahasa Inggris.
Pemilihan tipe instans berbasis atribut untuk Armada Spot
Ketika membuat Armada Spot, Anda harus menentukan satu atau lebih tipe instans untuk mengonfigurasi Instans Sesuai Permintaan dan Instans Spot di armada. Sebagai alternatif untuk menentukan tipe instans secara manual, Anda dapat menentukan atribut yang harus dimiliki instans, dan Amazon EC2 akan mengidentifikasi semua tipe instans dengan atribut tersebut. Hal ini dikenal sebagai pemilihan tipe instans berbasis atribut. Misalnya, Anda dapat menentukan jumlah vCPU minimum dan maksimum yang diperlukan untuk instans Anda, dan Armada Spot akan meluncurkan instans menggunakan tipe instans yang tersedia yang memenuhi kebutuhan vCPU tersebut.
Pemilihan tipe instans berbasis atribut sangat ideal untuk beban kerja dan kerangka kerja yang fleksibel dalam menentukan tipe instans yang digunakan, seperti ketika menjalankan kontainer atau armada web, memproses big data, dan mengimplementasikan alat integrasi dan deployment berkelanjutan (CI/CD).
Keuntungan
Pemilihan tipe instans berbasis atribut memiliki keuntungan berikut:
-
Mudah menggunakan jenis instans yang tepat — Dengan begitu banyak jenis instans yang tersedia, menemukan jenis instans yang tepat untuk beban kerja Anda dapat memakan waktu. Saat Anda menentukan atribut instans, tipe instans akan secara otomatis memiliki atribut yang diperlukan untuk beban kerja Anda.
-
Konfigurasi yang disederhanakan — Untuk menentukan beberapa jenis instans secara manual untuk Armada Spot, Anda harus membuat penggantian template peluncuran terpisah untuk setiap jenis instans. Namun, dengan pemilihan tipe instans berbasis atribut, untuk menyediakan banyak tipe instans, Anda hanya perlu menentukan atribut instans dalam templat peluncuran atau dalam penimpaan templat peluncuran.
-
Penggunaan otomatis tipe instans baru — Saat Anda menentukan atribut instance daripada tipe instans, armada Anda dapat menggunakan tipe instance generasi yang lebih baru saat dirilis, “pemeriksaan masa depan” konfigurasi armada.
-
Fleksibilitas tipe instans — Saat Anda menentukan atribut instance daripada tipe instans, Spot Fleet dapat memilih dari berbagai jenis instans untuk meluncurkan Instans Spot, yang mengikuti praktik terbaik Spot dari fleksibilitas tipe instans.
Topik
Cara kerja pemilihan tipe instans berbasis atribut
Untuk menggunakan pemilihan tipe instans berbasis atribut dalam konfigurasi armada, Anda mengganti daftar tipe instans dengan daftar atribut instans yang dibutuhkan oleh instans Anda. Armada Spot akan meluncurkan instans pada tipe instans yang tersedia yang memiliki atribut instans yang ditentukan.
Topik
Tipe atribut instans
Ada beberapa atribut instance yang dapat Anda tentukan untuk mengekspresikan persyaratan komputasi Anda, seperti:
-
Jumlah vCPU — Jumlah minimum dan maksimum vCPU per instance.
-
Memori — Minimum dan GiBs maksimum memori per instance.
-
Penyimpanan lokal — Apakah akan menggunakan EBS atau volume penyimpanan instans untuk penyimpanan lokal.
-
Kinerja burstable — Apakah akan menggunakan keluarga instans T, termasuk tipe T4G, T3a, T3, dan T2.
Untuk deskripsi setiap atribut dan nilai default, lihat InstanceRequirementsdi Referensi API Amazon EC2.
Tempat mengonfigurasi pemilihan tipe instans berbasis atribut
Bergantung pada apakah Anda menggunakan konsol atau konsol AWS CLI, Anda dapat menentukan atribut instance untuk pemilihan jenis instans berbasis atribut sebagai berikut:
Dalam konsol, Anda dapat menentukan atribut instans di salah satu atau semua komponen konfigurasi armada berikut ini:
-
Dalam templat peluncuran, lalu referensikan templat peluncuran dalam permintaan armada
-
Dalam permintaan armada
Di dalam AWS CLI, Anda dapat menentukan atribut instance dalam satu atau semua komponen konfigurasi armada berikut:
-
Dalam templat peluncuran, dan referensikan templat peluncuran dalam permintaan armada
-
Dalam penimpaan templat peluncuran
Jika Anda menginginkan campuran instans yang menggunakan AMI yang berbeda, Anda dapat menentukan atribut instans dalam banyak penimpaan templat peluncuran. Misalnya, tipe instans yang berbeda dapat menggunakan prosesor berbasis x86 dan Arm.
-
Dalam spesifikasi peluncuran
Cara Armada Spot menggunakan pemilihan tipe instans berbasis atribut saat menyediakan armada
Armada Spot menyediakan armada dengan cara berikut:
-
Armada Spot mengidentifikasi tipe instans yang memiliki atribut tertentu.
-
Armada Spot menggunakan perlindungan harga untuk menentukan tipe instans mana yang akan dikecualikan.
-
Armada Spot menentukan kumpulan kapasitas dari mana ia akan mempertimbangkan untuk meluncurkan instans berdasarkan AWS Wilayah atau Zona Ketersediaan yang memiliki jenis instans yang cocok.
-
Armada Spot menerapkan strategi alokasi yang ditentukan untuk menentukan dari kolam kapasitas yang digunakan untuk meluncurkan instans.
Perhatikan bahwa pemilihan tipe instans berbasis atribut tidak memilih kolam kapasitas yang akan digunakan untuk menyediakan armada; hal tersebut adalah tugas strategi alokasi. Mungkin terdapat tipe instans dalam jumlah besar dengan atribut yang ditentukan, dan beberapa di antaranya mungkin mahal. Strategi alokasi default
lowestPrice
untuk Spot dan Sesuai Permintaan menjamin bahwa Armada Spot akan meluncurkan instans dari kolam kapasitas paling murah.Jika Anda menentukan strategi alokasi, Armada Spot akan meluncurkan instans sesuai dengan strategi alokasi yang ditentukan.
-
Untuk Instans Spot, pemilihan tipe instans berbasis atribut mendukung strategi alokasi
capacityOptimizedPrioritized
,capacityOptimized
danlowestPrice
. -
Untuk Instans Sesuai Permintaan, pemilihan tipe instans berbasis atribut mendukung strategi alokasi
lowestPrice
.
-
-
Jika tidak ada kapasitas untuk tipe instans dengan atribut instans yang ditentukan, tidak ada instans yang dapat diluncurkan, dan armada akan mengembalikan kesalahan.
Perlindungan harga
Perlindungan harga adalah fitur yang mencegah Armada Spot menggunakan tipe instans yang Anda anggap terlalu mahal meskipun sesuai dengan atribut yang Anda tentukan. Untuk menggunakan perlindungan harga, Anda menetapkan ambang harga. Kemudian, ketika Amazon EC2 memilih jenis instans dengan atribut Anda, itu mengecualikan jenis instans dengan harga di atas ambang batas Anda.
Cara Amazon EC2 menghitung ambang harga adalah sebagai berikut:
-
Amazon EC2 pertama-tama mengidentifikasi jenis instans dengan harga terendah dari yang cocok dengan atribut Anda.
-
Amazon EC2 kemudian mengambil nilai (dinyatakan sebagai persentase) yang Anda tentukan untuk parameter perlindungan harga dan mengalikannya dengan harga jenis instans yang diidentifikasi. Hasilnya adalah harga yang digunakan sebagai ambang harga.
Ada ambang harga terpisah untuk Instans On-Demand dan Instans Spot.
Saat Anda membuat armada dengan pemilihan jenis instans berbasis atribut, perlindungan harga diaktifkan secara default. Anda dapat menyimpan nilai default, atau Anda dapat menentukan sendiri.
Anda juga dapat mematikan perlindungan harga. Untuk menunjukkan tidak ada ambang perlindungan harga, tentukan nilai persentase tinggi, seperti999999
.
Topik
Bagaimana jenis instans dengan harga terendah diidentifikasi
Amazon EC2 menentukan harga untuk mendasarkan ambang harga dengan mengidentifikasi jenis instans dengan harga terendah dari yang cocok dengan atribut yang Anda tentukan. Ia melakukan ini dengan cara berikut:
-
Ini pertama kali melihat jenis instance C, M, atau R generasi saat ini yang cocok dengan atribut Anda. Jika menemukan kecocokan, itu mengidentifikasi jenis instance dengan harga terendah.
-
Jika tidak ada kecocokan, maka akan terlihat jenis instance generasi saat ini yang cocok dengan atribut Anda. Jika menemukan kecocokan, itu mengidentifikasi jenis instance dengan harga terendah.
-
Jika tidak ada kecocokan, maka akan melihat jenis instance generasi sebelumnya yang cocok dengan atribut Anda, dan mengidentifikasi jenis instance dengan harga terendah.
Perlindungan harga Instans Sesuai Permintaan
Ambang batas perlindungan harga untuk jenis instans On-Demand dihitung sebagai persentase yang lebih tinggi daripada jenis instans On-Demand dengan harga terendah yang diidentifikasi (). OnDemandMaxPricePercentageOverLowestPrice
Anda menentukan persentase yang lebih tinggi yang bersedia Anda bayar. Jika Anda tidak menentukan parameter ini, maka nilai default 20
digunakan untuk menghitung ambang perlindungan harga 20% lebih tinggi dari harga yang diidentifikasi.
Misalnya, jika harga instans On-Demand yang teridentifikasi adalah0.4271
, dan Anda tentukan25
, maka ambang harga 25% lebih tinggi dari0.4271
. Itu dihitung sebagai berikut:0.4271 * 1.25 =
0.533875
. Harga yang dihitung adalah maksimum yang bersedia Anda bayarkan untuk Instans Sesuai Permintaan, dan, dalam contoh ini, Amazon EC2 akan mengecualikan jenis instans On-Demand yang harganya lebih dari. 0.533875
Perlindungan harga Spot Instance
Secara default, Amazon EC2 akan secara otomatis menerapkan perlindungan harga Instans Spot yang optimal untuk secara konsisten memilih dari berbagai jenis instans. Anda juga dapat mengatur sendiri perlindungan harga secara manual. Namun, membiarkan Amazon EC2 melakukannya untuk Anda dapat meningkatkan kemungkinan kapasitas Spot Anda terpenuhi.
Anda dapat menentukan perlindungan harga secara manual menggunakan salah satu opsi berikut. Jika Anda secara manual mengatur perlindungan harga, kami sarankan menggunakan opsi pertama.
-
Persentase dari jenis instans On-Demand dengan harga terendah yang diidentifikasi []
MaxSpotPriceAsPercentageOfOptimalOnDemandPrice
Misalnya, jika harga jenis instans On-Demand yang diidentifikasi adalah
0.4271
, dan Anda tentukan60
, maka ambang harga adalah 60% dari.0.4271
Itu dihitung sebagai berikut:0.4271 * 0.60 = 0.25626
. Harga yang dihitung adalah maksimum yang bersedia Anda bayarkan untuk Instans Spot, dan, dalam contoh ini, Amazon EC2 akan mengecualikan jenis instans Spot apa pun yang harganya lebih dari.0.25626
-
Persentase lebih tinggi dari jenis instans Spot dengan harga terendah yang diidentifikasi []
SpotMaxPricePercentageOverLowestPrice
Misalnya, jika harga jenis instans Spot yang diidentifikasi adalah
0.1808
, dan Anda tentukan25
, maka ambang harga 25% lebih tinggi dari harga0.1808
. Itu dihitung sebagai berikut:0.1808 * 1.25 = 0.226
. Harga yang dihitung adalah maksimum yang bersedia Anda bayarkan untuk Instans Spot, dan, dalam contoh ini, Amazon EC2 akan mengecualikan jenis instans Spot apa pun yang harganya lebih dari.0.266
Kami tidak menyarankan menggunakan parameter ini karena harga Spot dapat berfluktuasi, dan oleh karena itu ambang batas perlindungan harga Anda mungkin juga berfluktuasi.
Tentukan ambang batas perlindungan harga
Untuk menentukan ambang batas perlindungan harga
Saat membuat Armada Spot, konfigurasikan armada untuk pemilihan tipe instans berbasis atribut, lalu lakukan hal berikut:
-
Konsol
Untuk menentukan ambang perlindungan harga Instans Sesuai Permintaan, di bawah Atribut Instans tambahan, pilih Perlindungan harga sesuai permintaan, lalu pilih Tambahkan atribut. Untuk persentase perlindungan harga Sesuai Permintaan, masukkan ambang perlindungan harga sebagai persentase.
Untuk menentukan ambang batas perlindungan harga Instans Spot, di bawah Atribut instans tambahan, pilih Perlindungan harga Spot, lalu pilih Tambahkan atribut. Pilih parameter dan masukkan ambang perlindungan harga sebagai persentase.
-
AWS CLI
Untuk menentukan ambang batas perlindungan harga Instans Sesuai Permintaan, dalam file konfigurasi JSON, dalam struktur
InstanceRequirements
, untukOnDemandMaxPricePercentageOverLowestPrice
, masukkan ambang batas perlindungan harga sebagai persentase.Untuk menentukan ambang perlindungan harga Instans Spot, dalam file konfigurasi JSON, dalam
InstanceRequirements
struktur, tentukan salah satu parameter berikut:-
Untuk
MaxSpotPriceAsPercentageOfOptimalOnDemandPrice
, masukkan ambang perlindungan harga sebagai persentase. -
Untuk
SpotMaxPricePercentageOverLowestPrice
, masukkan ambang perlindungan harga sebagai persentase.
-
Untuk informasi selengkapnya tentang cara membuat armada, lihat Buat Armada Spot dengan pemilihan tipe instans berbasis atribut.
catatan
Saat membuat Armada Spot, jika Anda mengatur tipe Total kapasitas target ke vCPU atau Memori (MiB) (konsol) atau TargetCapacityUnitType
ke vcpu
atau memory-mib
(AWS CLI), ambang batas perlindungan harga diterapkan berdasarkan harga per vCPU atau per memori, bukan harga per instans.
Pertimbangan
-
Anda dapat menentukan tipe instans atau atribut instans di Armada Spot, tetapi tidak dapat menentukan keduanya pada saat yang bersamaan.
Saat menggunakan CLI, penimpaan templat peluncuran akan menimpa templat peluncuran. Misalnya, jika templat peluncuran berisi tipe instans dan penimpaan templat peluncuran berisi atribut instans, instans yang diidentifikasi oleh atribut instans akan menimpa tipe instans dalam templat peluncuran.
-
Saat menggunakan CLI, saat Anda menentukan atribut instans sebagai penimpaan, Anda juga tidak dapat menentukan bobot atau prioritas.
-
Anda dapat menentukan maksimum empat struktur
InstanceRequirements
dalam konfigurasi permintaan.
Buat Armada Spot dengan pemilihan tipe instans berbasis atribut
Anda dapat mengonfigurasi armada untuk menggunakan pemilihan tipe instans berbasis atribut menggunakan konsol Amazon EC2 atau AWS CLI.
Membuat Armada Spot menggunakan konsol
Guna mengonfigurasi Armada Spot untuk pemilihan tipe instans berbasis atribut (konsol)
Buka konsol Amazon EC2 di https://console.aws.amazon.com/ec2/
. -
Di panel navigasi, pilih Permintaan Spot, lalu pilih Minta Instans Spot.
-
Ikuti langkah-langkah ini untuk membuat Armada Spot. Untuk informasi selengkapnya, lihat Buat permintaan Armada Spot menggunakan parameter yang ditentukan (konsol).
Saat membuat Armada Spot, konfigurasikan armada untuk pemilihan tipe instans berbasis atribut sebagai berikut:
-
Untuk Persyaratan tipe instans, pilih Tentukan atribut instans yang sesuai dengan persyaratan komputasi Anda.
-
Untuk vCPU, masukkan jumlah minimum dan maksimum vCPU yang diinginkan. Untuk menentukan tanpa batasan, pilih Tanpa minimum, Tanpa maksimum, atau keduanya.
-
Untuk Memori (GiB), masukkan jumlah memori minimum dan maksimum yang diinginkan. Untuk menentukan tanpa batasan, pilih Tanpa minimum, Tanpa maksimum, atau keduanya.
-
(Opsional) Untuk atribut instans Tambahan, Anda dapat secara opsional menentukan satu atau lebih atribut untuk mengekspresikan kebutuhan komputasi Anda secara lebih mendetail. Setiap atribut tambahan menambahkan batasan lebih lanjut untuk permintaan Anda.
-
(Opsional) Perluas Pratinjau tipe instans yang cocok untuk melihat tipe instans yang memiliki atribut yang Anda tentukan.
-
Buat Armada Spot menggunakan AWS CLI
Untuk mengonfigurasi Armada Spot guna pemilihan tipe instans berbasis atribut (AWS CLI)
Gunakan perintah request-spot-fleet(AWS CLI) untuk membuat Armada Spot. Tentukan konfigurasi armada dalam file JSON.
aws ec2 request-spot-fleet \ --region
us-east-1
\ --spot-fleet-request-config file://file_name
.json
Contoh file file_name
.json
Contoh berikut ini berisi parameter yang mengonfigurasi Armada Spot untuk menggunakan pemilihan tipe instans berbasis atribut, dan diikuti dengan penjelasan teks.
{ "AllocationStrategy": "
priceCapacityOptimized
", "TargetCapacity":20
, "Type": "request
", "LaunchTemplateConfigs": [{ "LaunchTemplateSpecification": { "LaunchTemplateName": "my-launch-template
", "Version": "1
" }, "Overrides": [{ "InstanceRequirements": { "VCpuCount": { "Min":2
}, "MemoryMiB": { "Min":4
} } }] }] }
Atribut untuk pemilihan tipe instans berbasis atribut ditentukan dalam struktur InstanceRequirements
. Dalam contoh ini, dua atribut ditentukan:
-
VCpuCount
– Minimum 2 vCPU ditentukan. Karena tidak ada jumlah maksimum yang ditentukan, maka tidak ada batas maksimum. -
MemoryMiB
– Minimum 4 MiB memori ditentukan. Karena tidak ada jumlah maksimum yang ditentukan, maka tidak ada batas maksimum.
Setiap tipe instans yang memiliki 2 atau lebih VCPU dan 4 MiB atau lebih memori akan diidentifikasi. Namun, perlindungan harga dan strategi alokasi mungkin akan mengecualikan beberapa tipe instans jika Armada Spot menyediakan armada.
Untuk daftar dan deskripsi semua kemungkinan atribut yang dapat Anda tentukan, lihat InstanceRequirementsdi Referensi API Amazon EC2.
catatan
Jika InstanceRequirements
disertakan dalam konfigurasi armada, InstanceType
dan WeightedCapacity
harus dikecualikan; keduanya tidak dapat menentukan konfigurasi armada pada saat yang sama sebagai atribut instans.
JSON juga berisi konfigurasi armada berikut:
-
"AllocationStrategy": "
– Strategi alokasi untuk Instans Spot di armada.priceCapacityOptimized
" -
"LaunchTemplateName": "
– Templat peluncuran berisi beberapa informasi konfigurasi instans, tetapi jika ada tipe instans yang ditentukan, tipe instans tersebut akan diganti oleh atribut yang ditentukan dalammy-launch-template
", "Version": "
"1
InstanceRequirements
. -
"TargetCapacity":
– Kapasitas target adalah 20 instans.20
-
"Type": "
– Tipe permintaan untuk armada adalahrequest
"request
.
Contoh konfigurasi yang valid dan tidak valid
Jika Anda menggunakan AWS CLI untuk membuat Armada Spot, Anda harus memastikan bahwa konfigurasi armada Anda valid. Contoh berikut menunjukkan konfigurasi yang valid dan tidak valid.
Konfigurasi dianggap tidak valid jika berisi hal berikut:
-
Struktur
Overrides
tunggal denganInstanceRequirements
maupunInstanceType
-
Dua struktur
Overrides
, satu denganInstanceRequirements
dan yang lainnya denganInstanceType
-
Dua struktur
InstanceRequirements
dengan nilai atribut yang tumpang tindih dalamLaunchTemplateSpecification
yang sama
Contoh konfigurasi
- Konfigurasi yang valid: Templat peluncuran tunggal dengan penimpaan
- Konfigurasi yang valid: Template peluncuran tunggal dengan banyak InstanceRequirements
- Konfigurasi yang valid: Dua templat peluncuran, masing-masing dengan penimpaan
- Konfigurasi yang valid: Hanya InstanceRequirements yang ditentukan, tidak ada nilai atribut yang tumpang tindih
- Konfigurasi tidak valid: Overrides berisi InstanceRequirements dan InstanceType
- Konfigurasi tidak valid: Dua Overrides berisi InstanceRequirements dan InstanceType
- Konfigurasi tidak valid: Nilai atribut tumpang tindih
Konfigurasi yang valid: Templat peluncuran tunggal dengan penimpaan
Konfigurasi berikut ini valid. Konfigurasi ini berisi satu templat peluncuran dan satu struktur Overrides
yang berisi satu struktur InstanceRequirements
. Berikut ini adalah penjelasan teks mengenai contoh konfigurasi.
{ "SpotFleetRequestConfig": { "AllocationStrategy": "lowestPrice", "ExcessCapacityTerminationPolicy": "default", "IamFleetRole": "arn:aws:iam::000000000000:role/aws-ec2-spot-fleet-tagging-role", "LaunchTemplateConfigs": [ { "LaunchTemplateSpecification": { "LaunchTemplateName": "My-launch-template", "Version": "1" }, "Overrides": [ { "InstanceRequirements": { "VCpuCount": { "Min": 2, "Max": 8 }, "MemoryMib": { "Min": 0, "Max": 10240 }, "MemoryGiBPerVCpu": { "Max": 10000 }, "RequireHibernateSupport": true } } ] } ], "TargetCapacity": 5000, "OnDemandTargetCapacity": 0, "TargetCapacityUnitType": "vcpu" } }
InstanceRequirements
Untuk menggunakan pemilihan instans berbasis atribut, Anda harus menyertakan struktur InstanceRequirements
dalam konfigurasi armada, dan menentukan atribut yang diinginkan untuk instans tersebut di armada.
Pada contoh sebelumnya, atribut instans berikut ini ditentukan:
-
VCpuCount
– Tipe instans harus memiliki minimum 2 dan maksimum 8 vCPU. -
MemoryMiB
– Tipe instans harus memiliki memori maksimum 10240 MiB. Minimum 0 menunjukkan bahwa tidak ada batas minimum. -
MemoryGiBPerVCpu
– Tipe instans harus memiliki memori maksimum 10.000 GiB per vCPU. ParameterMin
bersifat opsional. Dengan menghilangkannya, Anda mengindikasikan tidak ada batas minimum.
TargetCapacityUnitType
Parameter TargetCapacityUnitType
menentukan unit untuk kapasitas target. Dalam contoh, kapasitas targetnya adalah 5000
dan tipe unit kapasitas targetnya adalah vcpu
, yang bersama-sama menentukan kapasitas target yang diinginkan sebesar 5.000 vCPU. Armada Spot akan meluncurkan instans yang cukup sehingga jumlah total vCPU dalam armada adalah 5.000 vCPU.
Konfigurasi yang valid: Template peluncuran tunggal dengan banyak InstanceRequirements
Konfigurasi berikut ini valid. Konfigurasi ini berisi satu templat peluncuran dan satu struktur Overrides
yang berisi dua struktur InstanceRequirements
. Atribut yang ditentukan di InstanceRequirements
valid karena nilainya tidak tumpang tindih—InstanceRequirements
struktur pertama menentukan VCpuCount
0-2 vCPU, sedangkan struktur InstanceRequirements
kedua menentukan 4-8 vCPU.
{ "SpotFleetRequestConfig": { "AllocationStrategy": "lowestPrice", "ExcessCapacityTerminationPolicy": "default", "IamFleetRole": "arn:aws:iam::000000000000:role/aws-ec2-spot-fleet-tagging-role", "LaunchTemplateConfigs": [ { "LaunchTemplateSpecification": { "LaunchTemplateName": "MyLaunchTemplate", "Version": "1" }, "Overrides": [ { "InstanceRequirements": { "VCpuCount": { "Min": 0, "Max": 2 }, "MemoryMiB": { "Min": 0 } } }, { "InstanceRequirements": { "VCpuCount": { "Min": 4, "Max": 8 }, "MemoryMiB": { "Min": 0 } } } ] } ], "TargetCapacity": 1, "OnDemandTargetCapacity": 0, "Type": "maintain" } }
Konfigurasi yang valid: Dua templat peluncuran, masing-masing dengan penimpaan
Konfigurasi berikut ini valid. Konfigurasi ini berisi dua templat peluncuran, masing-masing dengan satu struktur Overrides
yang berisi satu struktur InstanceRequirements
. Konfigurasi ini berguna untuk dukungan arsitektur arm
dan x86
dalam armada yang sama.
{ "SpotFleetRequestConfig": { "AllocationStrategy": "lowestPrice", "ExcessCapacityTerminationPolicy": "default", "IamFleetRole": "arn:aws:iam::000000000000:role/aws-ec2-spot-fleet-tagging-role", "LaunchTemplateConfigs": [ { "LaunchTemplateSpecification": { "LaunchTemplateName": "armLaunchTemplate", "Version": "1" }, "Overrides": [ { "InstanceRequirements": { "VCpuCount": { "Min": 0, "Max": 2 }, "MemoryMiB": { "Min": 0 } } }, { "LaunchTemplateSpecification": { "LaunchTemplateName": "x86LaunchTemplate", "Version": "1" }, "Overrides": [ { "InstanceRequirements": { "VCpuCount": { "Min": 0, "Max": 2 }, "MemoryMiB": { "Min": 0 } } } ] } ], "TargetCapacity": 1, "OnDemandTargetCapacity": 0, "Type": "maintain" } }
Konfigurasi yang valid: Hanya InstanceRequirements
yang ditentukan, tidak ada nilai atribut yang tumpang tindih
Konfigurasi berikut ini valid. Konfigurasi ini berisi dua struktur LaunchTemplateSpecification
, masing-masing dengan templat peluncuran dan struktur Overrides
yang berisi struktur InstanceRequirements
. Atribut yang ditentukan di InstanceRequirements
valid karena nilainya tidak tumpang tindih—InstanceRequirements
struktur pertama menentukan VCpuCount
0-2 vCPU, sedangkan struktur InstanceRequirements
kedua menentukan 4-8 vCPU.
{ "SpotFleetRequestConfig": { "AllocationStrategy": "lowestPrice", "ExcessCapacityTerminationPolicy": "default", "IamFleetRole": "arn:aws:iam::000000000000:role/aws-ec2-spot-fleet-tagging-role", "LaunchTemplateConfigs": [ { "LaunchTemplateSpecification": { "LaunchTemplateName": "MyLaunchTemplate", "Version": "1" }, "Overrides": [ { "InstanceRequirements": { "VCpuCount": { "Min": 0, "Max": 2 }, "MemoryMiB": { "Min": 0 } } } ] }, { "LaunchTemplateSpecification": { "LaunchTemplateName": "MyOtherLaunchTemplate", "Version": "1" }, "Overrides": [ { "InstanceRequirements": { "VCpuCount": { "Min": 4, "Max": 8 }, "MemoryMiB": { "Min": 0 } } } ] } ], "TargetCapacity": 1, "OnDemandTargetCapacity": 0, "Type": "maintain" } }
Konfigurasi tidak valid: Overrides
berisi InstanceRequirements
dan InstanceType
Konfigurasi berikut ini tidak valid. Struktur Overrides
berisi InstanceRequirements
danInstanceType
. Untuk Overrides
, Anda dapat menentukan antara InstanceRequirements
atau InstanceType
, tetapi tidak keduanya.
{
"SpotFleetRequestConfig": {
"AllocationStrategy": "lowestPrice",
"ExcessCapacityTerminationPolicy": "default",
"IamFleetRole": "arn:aws:iam::000000000000:role/aws-ec2-spot-fleet-tagging-role",
"LaunchTemplateConfigs": [
{
"LaunchTemplateSpecification": {
"LaunchTemplateName": "MyLaunchTemplate",
"Version": "1"
},
"Overrides": [
{
"InstanceRequirements": {
"VCpuCount": {
"Min": 0,
"Max": 2
},
"MemoryMiB": {
"Min": 0
}
}
},
{
"InstanceType": "m5.large"
}
]
}
],
"TargetCapacity": 1,
"OnDemandTargetCapacity": 0,
"Type": "maintain"
}
}
Konfigurasi tidak valid: Dua Overrides
berisi InstanceRequirements
dan InstanceType
Konfigurasi berikut ini tidak valid. Struktur Overrides
berisi InstanceRequirements
danInstanceType
. Anda dapat menentukan antara InstanceRequirements
atau InstanceType
, tetapi tidak keduanya, meskipun berada dalam struktur Overrides
yang berbeda.
{
"SpotFleetRequestConfig": {
"AllocationStrategy": "lowestPrice",
"ExcessCapacityTerminationPolicy": "default",
"IamFleetRole": "arn:aws:iam::000000000000:role/aws-ec2-spot-fleet-tagging-role",
"LaunchTemplateConfigs": [
{
"LaunchTemplateSpecification": {
"LaunchTemplateName": "MyLaunchTemplate",
"Version": "1"
},
"Overrides": [
{
"InstanceRequirements": {
"VCpuCount": {
"Min": 0,
"Max": 2
},
"MemoryMiB": {
"Min": 0
}
}
}
]
},
{
"LaunchTemplateSpecification": {
"LaunchTemplateName": "MyOtherLaunchTemplate",
"Version": "1"
},
"Overrides": [
{
"InstanceType": "m5.large"
}
]
}
],
"TargetCapacity": 1,
"OnDemandTargetCapacity": 0,
"Type": "maintain"
}
}
Konfigurasi tidak valid: Nilai atribut tumpang tindih
Konfigurasi berikut ini tidak valid. Dua struktur InstanceRequirements
masing-masing berisi "VCpuCount":
{"Min": 0, "Max": 2}
. Nilai untuk atribut ini tumpang tindih, yang akan mengakibatkan kolam kapasitas ganda.
{
"SpotFleetRequestConfig": {
"AllocationStrategy": "lowestPrice",
"ExcessCapacityTerminationPolicy": "default",
"IamFleetRole": "arn:aws:iam::000000000000:role/aws-ec2-spot-fleet-tagging-role",
"LaunchTemplateConfigs": [
{
"LaunchTemplateSpecification": {
"LaunchTemplateName": "MyLaunchTemplate",
"Version": "1"
},
"Overrides": [
{
"InstanceRequirements": {
"VCpuCount": {
"Min": 0,
"Max": 2
},
"MemoryMiB": {
"Min": 0
}
},
{
"InstanceRequirements": {
"VCpuCount": {
"Min": 0,
"Max": 2
},
"MemoryMiB": {
"Min": 0
}
}
}
}
]
}
],
"TargetCapacity": 1,
"OnDemandTargetCapacity": 0,
"Type": "maintain"
}
}
Melihat pratinjau tipe instans dengan atribut tertentu
Anda dapat menggunakan AWS CLI perintah get-instance-types-from-instance-requirements untuk melihat pratinjau jenis instance yang cocok dengan atribut yang Anda tentukan. Hal ini sangat berguna untuk mengetahui atribut yang akan ditentukan dalam konfigurasi permintaan Anda tanpa meluncurkan instans apa pun. Perhatikan bahwa perintah tidak mempertimbangkan kapasitas yang tersedia.
Untuk melihat daftar jenis instance dengan menentukan atribut menggunakan AWS CLI
-
(Opsional) Untuk menghasilkan semua atribut yang mungkin yang dapat ditentukan, gunakan perintah get-instance-types-from-instance-requirements dan parameter.
--generate-cli-skeleton
Anda dapat secara opsional mengarahkan output ke file untuk menyimpannya dengan menggunakaninput >
.attributes.json
aws ec2 get-instance-types-from-instance-requirements \ --region us-east-1 \ --generate-cli-skeleton input >
attributes.json
Output yang diharapkan
{ "DryRun": true, "ArchitectureTypes": [ "i386" ], "VirtualizationTypes": [ "hvm" ], "InstanceRequirements": { "VCpuCount": { "Min": 0, "Max": 0 }, "MemoryMiB": { "Min": 0, "Max": 0 }, "CpuManufacturers": [ "intel" ], "MemoryGiBPerVCpu": { "Min": 0.0, "Max": 0.0 }, "ExcludedInstanceTypes": [ "" ], "InstanceGenerations": [ "current" ], "SpotMaxPricePercentageOverLowestPrice": 0, "OnDemandMaxPricePercentageOverLowestPrice": 0, "BareMetal": "included", "BurstablePerformance": "included", "RequireHibernateSupport": true, "NetworkInterfaceCount": { "Min": 0, "Max": 0 }, "LocalStorage": "included", "LocalStorageTypes": [ "hdd" ], "TotalLocalStorageGB": { "Min": 0.0, "Max": 0.0 }, "BaselineEbsBandwidthMbps": { "Min": 0, "Max": 0 }, "AcceleratorTypes": [ "gpu" ], "AcceleratorCount": { "Min": 0, "Max": 0 }, "AcceleratorManufacturers": [ "nvidia" ], "AcceleratorNames": [ "a100" ], "AcceleratorTotalMemoryMiB": { "Min": 0, "Max": 0 }, "NetworkBandwidthGbps": { "Min": 0.0, "Max": 0.0 }, "AllowedInstanceTypes": [ "" ] }, "MaxResults": 0, "NextToken": "" }
-
Buat file konfigurasi JSON menggunakan output dari langkah sebelumnya, dan konfigurasikan sebagai berikut:
catatan
Anda harus memberikan nilai untuk
ArchitectureTypes
,VirtualizationTypes
,VCpuCount
, danMemoryMiB
. Anda dapat menghilangkan atribut lainnya; saat dihilangkan, nilai default digunakan.Untuk deskripsi setiap atribut dan nilai defaultnya, lihat get-instance-types-from-instance-requirements di Referensi Baris Perintah Amazon EC2.
-
Untuk
ArchitectureTypes
, tentukan satu atau lebih tipe arsitektur prosesor. -
Untuk
VirtualizationTypes
, tentukan satu atau lebih tipe virtualisasi. -
Untuk
VCpuCount
, tentukan jumlah minimum dan maksimum vCPU. Untuk menentukan tidak ada batas minimum, untukMin
, tentukan0
. Untuk menentukan tidak ada batas maksimum, hilangkan parameterMax
. -
Untuk
MemoryMiB
, tentukan jumlah memori minimum dan maksimum dalam MiB. Untuk menentukan tidak ada batas minimum, untukMin
, tentukan0
. Untuk menentukan tidak ada batas maksimum, hilangkan parameterMax
. -
Anda dapat secara opsional menentukan satu atau lebih atribut lainnya untuk lebih membatasi daftar tipe instans yang dikembalikan.
-
-
Untuk melihat pratinjau jenis instance yang memiliki atribut yang Anda tentukan dalam file JSON, gunakan perintah get-instance-types-from-instance-requirements, dan tentukan nama dan path ke file JSON Anda dengan menggunakan parameter.
--cli-input-json
Anda dapat secara opsional memformat output untuk muncul dalam format tabel.aws ec2 get-instance-types-from-instance-requirements \ --cli-input-json file://
attributes.json
\ --output tableContoh file
attributes.json
Dalam contoh ini, atribut yang diperlukan disertakan dalam file JSON. Atribut tersebut adalah
ArchitectureTypes
,VirtualizationTypes
,VCpuCount
, danMemoryMiB
. Selain itu, atributInstanceGenerations
opsional juga disertakan. Perhatikan bahwa untukMemoryMiB
, nilaiMax
dapat dihilangkan untuk menunjukkan bahwa tidak ada batasan.{ "ArchitectureTypes": [ "x86_64" ], "VirtualizationTypes": [ "hvm" ], "InstanceRequirements": { "VCpuCount": { "Min": 4, "Max": 6 }, "MemoryMiB": { "Min": 2048 }, "InstanceGenerations": [ "current" ] } }
Contoh output
------------------------------------------ |GetInstanceTypesFromInstanceRequirements| +----------------------------------------+ || InstanceTypes || |+--------------------------------------+| || InstanceType || |+--------------------------------------+| || c4.xlarge || || c5.xlarge || || c5a.xlarge || || c5ad.xlarge || || c5d.xlarge || || c5n.xlarge || || c6a.xlarge || ...
-
Setelah mengidentifikasi tipe instans yang memenuhi kebutuhan Anda, catatlah atribut instans yang Anda gunakan sehingga Anda dapat menggunakannya saat mengonfigurasi permintaan armada.