sam build - AWS Serverless Application Model

Terjemahan disediakan oleh mesin penerjemah. Jika konten terjemahan yang diberikan bertentangan dengan versi bahasa Inggris aslinya, utamakan versi bahasa Inggris.

sam build

Halaman ini memberikan informasi referensi untuk AWS Serverless Application Model perintah Command Line Interface (AWS SAMCLI)sam build.

sam buildPerintah menyiapkan aplikasi untuk langkah-langkah selanjutnya dalam alur kerja pengembang, seperti pengujian lokal atau penyebaran ke file. AWS Cloud

Penggunaan

$ sam build <arguments> <options>

Pendapat

ID Sumber Daya

Tidak wajib. Menginstruksikan AWS SAM untuk membangun sumber daya tunggal yang dideklarasikan dalam AWS SAM template. Artefak build untuk sumber daya yang ditentukan akan menjadi satu-satunya yang tersedia untuk perintah berikutnya dalam alur kerja, mis. sam package dan sam deploy.

Opsi

--base-dir, -s DIRECTORY

Selesaikan jalur relatif ke fungsi atau kode sumber lapisan sehubungan dengan direktori ini. Gunakan opsi ini jika Anda ingin mengubah cara jalur relatif ke folder kode sumber diselesaikan. Secara default, jalur relatif diselesaikan sehubungan dengan lokasi templat AWS SAM .

Selain sumber daya dalam aplikasi root atau tumpukan yang sedang Anda bangun, opsi ini juga memberlakukan aplikasi atau tumpukan nest.

Opsi ini berlaku untuk tipe sumber daya dan properti berikut:

  • Tipe sumber daya: Properti AWS::Serverless::Function: CodeUri

  • Tipe sumber daya: Atribut Sumber DayaAWS::Serverless::Function: Entri Metadata: DockerContext

  • Tipe sumber daya: Properti AWS::Serverless::LayerVersion: ContentUri

  • Tipe sumber daya: Properti AWS::Lambda::Function: Code

  • Tipe sumber daya: Properti AWS::Lambda::LayerVersion: Content

--beta-features | --no-beta-features

Izinkan atau tolak fitur beta.

--build-dir, -b DIRECTORY

Jalur ke direktori tempat artefak build disimpan. Direktori ini dan semua isinya akan dihapus dengan opsi ini.

--build-image TEXT

URI dari citra kontainer yang ingin Anda tarik untuk build. Secara default, AWS SAM menarik citra kontainer dari Amazon ECR Publik. Gunakan opsi ini untuk menarik citra dari lokasi lain.

Anda dapat menentukan opsi ini beberapa kali. Setiap instans dari opsi ini dapat mengambil baik string atau pasangan kunci-nilai. Jika Anda menentukan string, string adalah URI citra kontainer untuk digunakan untuk semua sumber daya dalam aplikasi Anda. Misalnya, sam build --use-container --build-image amazon/aws-sam-cli-build-image-python3.8. Jika Anda menentukan pasangan kunci-nilai, kuncinya adalah nama sumber daya, dan nilainya adalah URI citra kontainer untuk digunakan untuk sumber daya tersebut. Sebagai contoh, sam build --use-container --build-image Function1=amazon/aws-sam-cli-build-image-python3.8. Dengan pasangan kunci-nilai, Anda dapat menentukan citra kontainer yang berbeda untuk sumber daya yang berbeda.

Opsi ini hanya berlaku jika opsi --use-container ditentukan, jika tidak akan terjadi kesalahan.

--build-in-source | --no-build-in-source

Berikan --build-in-source untuk membangun proyek Anda langsung di folder sumber.

--build-in-sourceOpsi ini mendukung runtime dan metode build berikut:

  • Runtime - Setiap Node.js runtime yang didukung oleh opsi. sam init --runtime

  • Membangun metodeMakefile,esbuild.

--build-in-sourceOpsi ini tidak kompatibel dengan opsi berikut:

  • --hook-name

  • --use-container

Default: --no-build-in-source

--cached | --no-cached

Aktifkan atau nonaktifkan build yang di-cache. Gunakan opsi ini untuk menggunakan kembali artefak build yang belum berubah dari build sebelumnya. AWS SAM mengevaluasi apakah Anda telah mengubah file apa pun di direktori proyek Anda. Secara default, build tidak di-cache. Jika --no-cached opsi dipanggil, itu akan mengganti cached = true pengaturan di samcofig.toml.

catatan

AWS SAM tidak mengevaluasi apakah Anda telah mengubah modul pihak ketiga yang bergantung pada proyek Anda, di mana Anda belum menyediakan versi tertentu. Misalnya, jika fungsi Python Anda menyertakan requirements.txt file dengan entrirequests=1.x, dan versi modul permintaan terbaru berubah dari 1.1 ke1.2, maka AWS SAM tidak menarik versi terbaru hingga Anda menjalankan build yang tidak di-cache.

--cache-dir

Direktori tempat artefak cache disimpan saat --cached ditentukan. Direktori cache default adalah .aws-sam/cache.

--config-env TEXT

Nama lingkungan yang menentukan nilai parameter default dalam file konfigurasi yang akan digunakan. Nilai default-nya adalah “default”. Untuk informasi selengkapnya tentang file konfigurasi, lihat AWS SAMCLIberkas konfigurasi.

--config-file PATH

Jalur dan nama file dari file konfigurasi yang berisi nilai parameter default yang akan digunakan. Nilai default-nya adalah ”samconfig.toml“ di root direktori proyek. Untuk informasi selengkapnya tentang file konfigurasi, lihat AWS SAMCLIberkas konfigurasi.

--container-env-var, -e TEXT

Variabel lingkungan yang akan diteruskan ke kontainer build. Anda dapat menentukan opsi ini beberapa kali. Setiap instans opsi ini mengambil pasangan kunci-nilai, dengan penjelasan kunci adalah variabel sumber daya dan lingkungan, dan nilai adalah nilai variabel lingkungan. Misalnya: --container-env-var Function1.GITHUB_TOKEN=TOKEN1 --container-env-var Function2.GITHUB_TOKEN=TOKEN2.

Opsi ini hanya berlaku jika opsi --use-container ditentukan, jika tidak akan terjadi kesalahan.

--container-env-var-file, -ef PATH

Nama jalur dan file dari file JSON yang berisi nilai-nilai untuk variabel lingkungan kontainer ini. Untuk informasi selengkapnya tentang file variabel lingkungan kontainer, lihat File variabel lingkungan kontainer.

Opsi ini hanya berlaku jika opsi --use-container ditentukan, jika tidak akan terjadi kesalahan.

--debug

Mengaktifkan logging debug untuk mencetak pesan debug yang AWS SAMCLI dihasilkan, dan untuk menampilkan stempel waktu.

--docker-network TEXT

Menentukan nama atau ID dari Docker jaringan yang ada yang kontainer Docker Lambda harus terhubung ke, bersama dengan jaringan jembatan default. Jika tidak ditentukan, kontainer Lambda hanya terhubung ke jaringan jembatan Docker default.

--exclude, -x

Nama sumber daya untuk dikecualikan darisam build. Misalnya, jika template Anda berisiFunction1,Function2, Function3 dan Anda menjalankansam build --exclude Function2, hanya Function1 dan Function3 akan dibangun.

--help

Menunjukkan pesan ini dan keluar.

--hook-name TEXT

Nama hook yang digunakan untuk memperluas AWS SAMCLI fungsionalitas.

Nilai yang diterima:terraform.

--manifest , -m PATH

Jalur ke file manifest dependensi kustom (misalnya, package.json) yang akan digunakan bukan default.

--parallel

Pengaktifan build paralel. Gunakan opsi ini untuk membangun fungsi dan lapisan AWS SAM template Anda secara paralel. Secara default, fungsi dan lapisan dibangun secara berurutan.

--parameter-overrides

(Opsional) String yang berisi penggantian AWS CloudFormation parameter yang dikodekan sebagai pasangan nilai kunci. Menggunakan format yang sama dengan AWS Command Line Interface (AWS CLI). Misalnya: 'ParameterKey=KeyPairName, ParameterValue = MyKey ParameterKey =InstanceType, ParameterValue =t1.micro'. Opsi ini tidak kompatibel dengan--hook-name.

--profile TEXT

Profil spesifik dari file kredensialmu yang mendapat AWS kredensialnya.

--region TEXT

Wilayah AWS Untuk menyebarkan ke. Misalnya, us-east-1.

--save-params

Simpan parameter yang Anda berikan pada baris perintah ke file AWS SAM konfigurasi.

--skip-prepare-infra

Melewati tahap persiapan jika tidak ada perubahan infrastruktur yang dilakukan. Gunakan dengan --hook-name opsi.

--skip-pull-image

Menentukan apakah perintah harus melewatkan menarik ke bawah citra Docker terbaru untuk waktu aktif Lambda.

--template-file, --template, -t PATH

Path dan nama file file AWS SAM template[default: template.[yaml|yml]]. Opsi ini tidak kompatibel dengan--hook-name.

--terraform-project-root-path

Jalur relatif atau absolut ke direktori tingkat atas yang berisi file Terraform konfigurasi atau kode sumber fungsi Anda. Jika file-file ini terletak di luar direktori yang berisi modul Terraform root Anda, gunakan opsi ini untuk menentukan jalur absolut atau relatifnya. Opsi ini mengharuskan --hook-name diatur keterraform.

--use-container, -u

Jika fungsi Anda tergantung pada paket yang memiliki dependensi terkompilasi secara native, gunakan opsi ini untuk membangun fungsi Anda di dalam kontainer Docker mirip Lambda.