Terjemahan disediakan oleh mesin penerjemah. Jika konten terjemahan yang diberikan bertentangan dengan versi bahasa Inggris aslinya, utamakan versi bahasa Inggris.
Anda dapat menggunakan salah satu antarmuka SageMaker AI untuk menjalankan pekerjaan pelatihan dengan SageMaker Training Compiler: Amazon SageMaker Studio Classic, instans SageMaker notebook Amazon, AWS SDK for Python (Boto3) dan. AWS Command Line Interface
Topik
Menggunakan SageMaker Python SDK
Untuk mengaktifkan SageMaker Training Compiler, tambahkan compiler_config
parameter ke SageMaker AI TensorFlow atau Hugging Face estimator. Impor TrainingCompilerConfig
kelas dan berikan instance ke compiler_config
parameter. Contoh kode berikut menunjukkan struktur kelas estimator SageMaker AI dengan SageMaker Training Compiler diaktifkan.
Tip
Untuk memulai dengan model prebuilt yang disediakan oleh library TensorFlow and Transformers, coba gunakan ukuran batch yang disediakan dalam tabel referensi di. Model yang Diuji
catatan
SageMaker Training Compiler for TensorFlow tersedia melalui estimator kerangka SageMaker kerja AI TensorFlow
Untuk informasi yang sesuai dengan kasus penggunaan Anda, lihat salah satu opsi berikut.
Daftar berikut adalah set minimal parameter yang diperlukan untuk menjalankan pekerjaan SageMaker pelatihan dengan compiler.
catatan
Saat menggunakan estimator SageMaker AI Hugging Face, Anda harus menentukantransformers_version
,, tensorflow_version
hyperparameters
, compiler_config
dan parameter untuk SageMaker mengaktifkan Training Compiler. Anda tidak dapat menggunakan image_uri
untuk secara manual menentukan Deep Learning Containers terintegrasi Training Compiler yang terdaftar diKerangka Kerja yang Didukung.
-
entry_point
(str) - Diperlukan. Tentukan nama file skrip pelatihan Anda. -
instance_count
(int) - Diperlukan. Tentukan jumlah instans. -
instance_type
(str) - Diperlukan. Tentukan jenis instance. -
transformers_version
(str) - Diperlukan hanya saat menggunakan penaksir SageMaker AI Hugging Face. Tentukan versi pustaka Hugging Face Transformers yang didukung oleh SageMaker Training Compiler. Untuk menemukan versi yang tersedia, lihatKerangka Kerja yang Didukung. -
framework_version
atautensorflow_version
(str) - Diperlukan. Tentukan TensorFlow versi yang didukung oleh SageMaker Training Compiler. Untuk menemukan versi yang tersedia, lihatKerangka Kerja yang Didukung.catatan
Saat menggunakan TensorFlow estimator SageMaker AI, Anda harus menentukan
framework_version
.Saat menggunakan penaksir SageMaker AI Hugging Face, Anda harus menentukan
transformers_version
keduanya dan.tensorflow_version
-
hyperparameters
(dict) — Opsional. Tentukan hyperparameters untuk pekerjaan pelatihan, sepertin_gpus
,batch_size
, danlearning_rate
. Saat Anda mengaktifkan SageMaker Training Compiler, coba ukuran batch yang lebih besar dan sesuaikan tingkat pembelajaran yang sesuai. Untuk menemukan studi kasus penggunaan kompiler dan ukuran batch yang disesuaikan untuk meningkatkan kecepatan pelatihan, lihat Model yang Diuji danSageMaker Contoh Kompiler Pelatihan Notebook dan Blog. -
compiler_config
(TrainingCompilerConfig objek) - Diperlukan. Sertakan parameter ini untuk mengaktifkan SageMaker Training Compiler. Berikut ini adalah parameter untukTrainingCompilerConfig
kelas.-
enabled
(bool) — Opsional. TentukanTrue
atauFalse
untuk mengaktifkan atau mematikan SageMaker Training Compiler. Nilai default-nya adalahTrue
. -
debug
(bool) — Opsional. Untuk menerima log pelatihan yang lebih detail dari pekerjaan pelatihan yang dipercepat kompiler, ubah ke.True
Namun, pencatatan tambahan mungkin menambah overhead dan memperlambat pekerjaan pelatihan yang dikompilasi. Nilai default-nya adalahFalse
.
-
Awas
Jika Anda mengaktifkan SageMaker Debugger, itu mungkin memengaruhi kinerja SageMaker Training Compiler. Kami menyarankan Anda mematikan Debugger saat menjalankan SageMaker Training Compiler untuk memastikan tidak ada dampak pada kinerja. Untuk informasi selengkapnya, lihat Pertimbangan. Untuk menonaktifkan fungsionalitas Debugger, tambahkan dua argumen berikut ke estimator:
disable_profiler=True,
debugger_hook_config=False
Jika pekerjaan pelatihan dengan kompiler berhasil diluncurkan, Anda menerima log berikut selama fase inisialisasi pekerjaan:
-
dengan
TrainingCompilerConfig(debug=False)
Found configuration for Training Compiler Configuring SM Training Compiler...
-
dengan
TrainingCompilerConfig(debug=True)
Found configuration for Training Compiler Configuring SM Training Compiler... Training Compiler set to debug mode
Menggunakan SageMaker AI Python SDK dan Memperluas AI Framework Deep Learning SageMaker Containers
AWS Deep Learning Containers (DLC) untuk TensorFlow menggunakan versi adaptasi TensorFlow yang menyertakan perubahan di atas kerangka open source TensorFlow . SageMaker AI Framework Deep Learning Containers
catatan
Fitur kustomisasi Docker ini saat ini hanya tersedia untuk TensorFlow.
Untuk memperluas dan menyesuaikan SageMaker AI TensorFlow DLCs untuk kasus penggunaan Anda, gunakan petunjuk berikut.
Buat Dockerfile
Gunakan template Dockerfile berikut untuk memperluas SageMaker AI TensorFlow DLC. Anda harus menggunakan gambar SageMaker AI TensorFlow DLC sebagai gambar dasar wadah Docker Anda. Untuk menemukan gambar SageMaker AI TensorFlow DLC, lihat Kerangka Kerja URIs yang Didukung.
# SageMaker AI TensorFlow Deep Learning Container image
FROM 763104351884.dkr.ecr.<aws-region>
.amazonaws.com/tensorflow-training:<image-tag>
ENV PATH="/opt/ml/code:${PATH}"
# This environment variable is used by the SageMaker AI container
# to determine user code directory.
ENV SAGEMAKER_SUBMIT_DIRECTORY /opt/ml/code
# Add more code lines to customize for your use-case
...
Untuk informasi selengkapnya, lihat Langkah 2: Membuat dan mengunggah skrip pelatihan Dockerfile dan Python.
Pertimbangkan jebakan berikut saat memperluas Kerangka SageMaker AI: DLCs
-
Jangan secara eksplisit menghapus atau mengubah versi TensorFlow paket dalam SageMaker wadah AI. Melakukan hal itu menyebabkan TensorFlow paket yang AWS dioptimalkan ditimpa oleh TensorFlow paket sumber terbuka, yang dapat mengakibatkan penurunan kinerja.
-
Hati-hati dengan paket yang memiliki TensorFlow versi atau rasa tertentu sebagai ketergantungan. Paket-paket ini mungkin secara implisit menghapus instalasi paket sumber terbuka yang AWS dioptimalkan TensorFlow dan menginstal. TensorFlow
Misalnya, ada masalah yang diketahui bahwa pustaka tensorflow/models dan tensorflow/texttensorflow/training/docker/<tensorflow-version>/py3/<cuda-version>/Dockerfile.gpu
Di Dockerfiles, Anda harus menemukan baris kode untuk menginstal ulang TensorFlow biner AWS terkelola (ditentukan ke variabel TF_URL
lingkungan) dan dependensi lainnya secara berurutan. Bagian instalasi ulang akan terlihat seperti contoh berikut:
# tf-models does not respect existing installations of TensorFlow
# and always installs open source TensorFlow
RUN pip3 install --no-cache-dir -U \
tf-models-official==x.y.z
RUN pip3 uninstall -y tensorflow tensorflow-gpu \
; pip3 install --no-cache-dir -U \
${TF_URL} \
tensorflow-io==x.y.z
\
tensorflow-datasets==x.y.z
Bangun dan dorong ke ECR
Untuk membangun dan mendorong container Docker Anda ke Amazon ECR, ikuti petunjuk di tautan berikut:
Jalankan menggunakan SageMaker Python SDK Estimator
Gunakan estimator TensorFlow kerangka kerja SageMaker AI seperti biasa. Anda harus menentukan image_uri
untuk menggunakan wadah baru yang Anda host di Amazon ECR.
import sagemaker, boto3
from sagemaker import get_execution_role
from sagemaker.tensorflow import TensorFlow, TrainingCompilerConfig
account_id = boto3.client('sts').get_caller_identity().get('Account')
ecr_repository = 'tf-custom-container-test'
tag = ':latest'
region = boto3.session.Session().region_name
uri_suffix = 'amazonaws.com'
byoc_image_uri = '{}.dkr.ecr.{}.{}/{}'.format(
account_id, region, uri_suffix, ecr_repository + tag
)
byoc_image_uri
# This should return something like
# 111122223333.dkr.ecr.us-east-2.amazonaws.com/tf-custom-container-test:latest
estimator = TensorFlow(
image_uri=image_uri,
role=get_execution_role(),
base_job_name='tf-custom-container-test-job
',
instance_count=1,
instance_type='ml.p3.8xlarge
'
compiler_config=TrainingCompilerConfig(),
disable_profiler=True,
debugger_hook_config=False
)
# Start training
estimator.fit()
Aktifkan Kompiler SageMaker Pelatihan Menggunakan SageMaker Operasi AI CreateTrainingJob
API
SageMaker Opsi konfigurasi Training Compiler harus ditentukan melalui HyperParameters
kolom AlgorithmSpecification
and dalam sintaks permintaan untuk operasi CreateTrainingJob
API
"AlgorithmSpecification": {
"TrainingImage": "<sagemaker-training-compiler-enabled-dlc-image>
"
},
"HyperParameters": {
"sagemaker_training_compiler_enabled": "true",
"sagemaker_training_compiler_debug_mode": "false"
}
Untuk menemukan daftar lengkap image container deep learning URIs yang telah diimplementasikan SageMaker Training Compiler, lihatKerangka Kerja yang Didukung.