

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

# Menyebarkan fungsi Lambda menggunakan AWS SAM dengan CodeBuild Lambda Java
<a name="sample-lambda-sam-gradle"></a>

The AWS Serverless Application Model (AWS SAM) adalah kerangka kerja sumber terbuka untuk membangun aplikasi tanpa server. Untuk informasi selengkapnya, lihat [AWS Serverless Application Model repositori](https://github.com/aws/serverless-application-model) di. GitHub Contoh Java berikut menggunakan Gradle untuk membangun dan menguji AWS Lambda fungsi. Setelah itu, AWS SAM CLI digunakan untuk menyebarkan CloudFormation template dan bundel penerapan. Dengan menggunakan CodeBuild Lambda, langkah-langkah pembuatan, pengujian, dan penerapan semuanya ditangani secara otomatis, memungkinkan infrastruktur diperbarui dengan cepat tanpa intervensi manual dalam satu build.

## Siapkan AWS SAM repositori Anda
<a name="sample-lambda-sam-gradle.set-up-repo"></a>

Buat AWS SAM `Hello World` proyek menggunakan AWS SAM CLI.

**Untuk membuat AWS SAM Proyek Anda**

1. Ikuti petunjuk di *Panduan AWS Serverless Application Model Pengembang* untuk [Menginstal AWS SAM CLI di mesin](https://docs.aws.amazon.com/serverless-application-model/latest/developerguide/install-sam-cli.html) lokal Anda.

1. Jalankan `sam init` dan pilih konfigurasi proyek berikut.

   ```
   Which template source would you like to use?: 1 - AWS Quick Start Templates
   Choose an AWS Quick Start application template: 1 - Hello World Example
   Use the most popular runtime and package type? (Python and zip) [y/N]: N
   Which runtime would you like to use?: 8 - java21
   What package type would you like to use?: 1 - Zip
   Which dependency manager would you like to use?: 1 - gradle
   Would you like to enable X-Ray tracing on the function(s) in your application? [y/N]: N
   Would you like to enable monitoring using CloudWatch Application Insights? [y/N]: N
   Would you like to set Structured Logging in JSON format on your Lambda functions? [y/N]:  N
   Project name [sam-app]: <insert project name>
   ```

1. Unggah folder AWS SAM proyek ke repositori sumber yang didukung. Untuk daftar jenis sumber yang didukung, lihat [ProjectSource](https://docs.aws.amazon.com/codebuild/latest/APIReference/API_ProjectSource.html).

## Buat proyek CodeBuild Lambda Java
<a name="sample-lambda-sam-gradle.create-project"></a>

Buat proyek AWS CodeBuild Lambda Java dan siapkan izin IAM yang diperlukan untuk build.

**Untuk membuat proyek CodeBuild Lambda Java Anda**

1. Buka AWS CodeBuild konsol di [https://console.aws.amazon.com/codesuite/codebuild/home](https://console.aws.amazon.com/codesuite/codebuild/home).

1.  Jika halaman CodeBuild informasi ditampilkan, pilih **Buat proyek build**. Jika tidak, pada panel navigasi, perluas **Build**, pilih **Build projects**, lalu pilih **Create build project**. 

1. Di **Nama proyek**, masukkan nama untuk proyek pembangunan ini. Membangun nama proyek harus unik di setiap AWS akun. Anda juga dapat menyertakan deskripsi opsional proyek build untuk membantu pengguna lain memahami tujuan proyek ini.

1. Di **Sumber**, pilih repositori sumber tempat AWS SAM proyek Anda berada.

1. Di **Lingkungan**:
   + Untuk **Compute**, pilih **Lambda**.
   + Untuk **Runtime**, pilih **Java**.
   + Untuk **Gambar**, pilih **aws/codebuild/amazonlinux-x86\$164-lambda-standard:corretto21**.
   + Untuk **peran Layanan**, biarkan **peran Layanan baru** dipilih. Catat **nama Peran**. Ini akan diperlukan saat Anda memperbarui izin IAM proyek nanti dalam sampel ini.

1. Pilih **Buat proyek build**.

1. Buka konsol IAM di [https://console.aws.amazon.com/iam/](https://console.aws.amazon.com/iam/). 

1. Di panel navigasi, pilih **Peran dan pilih peran** layanan yang terkait dengan proyek Anda. Anda dapat menemukan peran proyek Anda CodeBuild dengan memilih proyek build, memilih **Edit**, **Lingkungan**, dan kemudian **peran Layanan**.

1. Pilih tab **Trust relationship**, lalu pilih **Edit trust policy**.

1. Tambahkan kebijakan inline berikut ke peran IAM Anda. Ini akan digunakan untuk menyebarkan AWS SAM infrastruktur Anda nanti. Untuk informasi lebih lanjut, lihat [Menambahkan dan menghapus izin identitas IAM](https://docs.aws.amazon.com//IAM/latest/UserGuide/access_policies_manage-attach-detach.html) dalam *Panduan Pengguna IAM*.

------
#### [ JSON ]

****  

   ```
   {
       "Version":"2012-10-17",		 	 	 
       "Statement": [
           {
               "Sid": "",
               "Effect": "Allow",
               "Action": [
                   "cloudformation:*",
                   "lambda:*",
                   "iam:*",
                   "apigateway:*",
                   "s3:*"
               ],
               "Resource": "arn:aws:iam::*:role/Service*"
           }
       ]
   }
   ```

------

## Siapkan proyek buildspec
<a name="sample-lambda-sam-gradle.set-up-buildspec"></a>

Untuk membangun, menguji, dan menerapkan fungsi Lambda Anda CodeBuild , membaca dan mengeksekusi perintah build dari buildspec.

**Untuk menyiapkan buildspec proyek Anda**

1. Di CodeBuild konsol, pilih proyek build Anda, lalu pilih **Edit** dan **Buildspec**.

1. Di **Buildspec**, pilih **Sisipkan perintah build** dan kemudian **Beralih ke** editor.

1. Hapus perintah build yang telah diisi sebelumnya dan tempel di buildspec berikut.

   ```
   version: 0.2
   env:
     variables:
       GRADLE_DIR: "HelloWorldFunction"
   phases:
     build:
       commands:
         - echo "Running unit tests..."
         - cd $GRADLE_DIR; gradle test; cd ..
         - echo "Running build..."
         - sam build --template-file template.yaml
         - echo "Running deploy..."
         - sam package --output-template-file packaged.yaml --resolve-s3 --template-file template.yaml
         - yes | sam deploy
   ```

1. Pilih **Perbarui buildspec**.

## Terapkan infrastruktur AWS SAM Lambda Anda
<a name="sample-lambda-sam-gradle.deploy"></a>

Gunakan CodeBuild Lambda untuk menyebarkan infrastruktur Lambda Anda secara otomatis

**Untuk menyebarkan infrastruktur Lambda Anda**

1. Pilih **Mulai membangun**. Ini akan secara otomatis membangun, menguji, dan menyebarkan AWS SAM aplikasi Anda untuk AWS Lambda digunakan CloudFormation.

1. Setelah build selesai, navigasikan ke AWS Lambda konsol dan cari fungsi Lambda baru Anda di bawah nama AWS SAM proyek.

1. Uji fungsi Lambda Anda dengan memilih **API Gateway** di bawah ikhtisar **Fungsi**, lalu mengklik URL titik **akhir API**. Anda akan melihat halaman terbuka dengan pesan`"message": "hello world"`.

## Bersihkan infrastruktur Anda
<a name="sample-lambda-sam-gradle.clean-up"></a>

Untuk menghindari biaya lebih lanjut untuk sumber daya yang Anda gunakan selama tutorial ini, hapus sumber daya yang dibuat oleh AWS SAM template Anda dan CodeBuild.

**Untuk membersihkan infrastruktur Anda**

1. Arahkan ke CloudFormation konsol dan pilih`aws-sam-cli-managed-default`.

1. Di **Resources**, kosongkan bucket `SamCliSourceBucket` penerapan.

1. Hapus `aws-sam-cli-managed-default` tumpukan.

1. Hapus CloudFormation tumpukan yang terkait dengan AWS SAM proyek Anda. Tumpukan ini harus memiliki nama yang sama dengan AWS SAM proyek Anda.

1. Arahkan ke CloudWatch konsol dan hapus grup CloudWatch log yang terkait dengan CodeBuild proyek Anda.

1. Arahkan ke CodeBuild konsol dan hapus CodeBuild proyek Anda dengan memilih **Delete build project**.