Terjemahan disediakan oleh mesin penerjemah. Jika konten terjemahan yang diberikan bertentangan dengan versi bahasa Inggris aslinya, utamakan versi bahasa Inggris.
Memulai dengan CodeBuild
Dalam tutorial berikut, Anda gunakan AWS CodeBuild untuk membangun kumpulan file masukan kode sumber sampel ke dalam versi kode sumber yang dapat diterapkan.
Kedua tutorial memiliki input dan hasil yang sama, tetapi yang satu menggunakan AWS CodeBuild konsol dan yang lainnya menggunakan AWS CLI.
penting
Kami tidak menyarankan Anda menggunakan akun AWS root Anda untuk menyelesaikan tutorial ini.
Topik
Memulai dengan AWS CodeBuild menggunakan konsol
Dalam tutorial ini, Anda gunakan AWS CodeBuild untuk membangun kumpulan file input kode sumber sampel (membangun artefak input atau membangun input) ke dalam versi kode sumber yang dapat diterapkan (membangun artefak keluaran atau keluaran build). Secara khusus, Anda menginstruksikan CodeBuild untuk menggunakan Apache Maven, alat build umum, untuk membangun satu set file kelas Java ke dalam file Java Archive (). JAR Anda tidak perlu terbiasa dengan Apache Maven atau Java untuk menyelesaikan tutorial ini.
Anda dapat bekerja dengan CodeBuild melalui CodeBuild konsol AWS CodePipeline, AWS CLI, atau AWS SDKs. Tutorial ini menunjukkan cara menggunakan CodeBuild konsol. Untuk informasi tentang penggunaan CodePipeline, lihatGunakan CodeBuild dengan CodePipeline.
penting
Langkah-langkah dalam tutorial ini mengharuskan Anda untuk membuat sumber daya (misalnya, bucket S3) yang mungkin mengakibatkan biaya ke AWS akun Anda. Ini termasuk kemungkinan biaya untuk CodeBuild dan untuk AWS sumber daya dan tindakan yang terkait dengan Amazon S3, AWS KMS, dan CloudWatch Log. Untuk informasi selengkapnya, lihat AWS CodeBuild
harga, harga
Topik
- Langkah 1: Buat kode sumber
- Langkah 2: Buat file buildspec
- Langkah 3: Buat dua ember S3
- Langkah 4: Unggah kode sumber dan file buildspec
- Langkah 5: Buat proyek build
- Langkah 6: Jalankan build
- Langkah 7: Lihat informasi build yang dirangkum
- Langkah 8: Lihat informasi build terperinci
- Langkah 9: Dapatkan artefak keluaran build
- Langkah 10: Hapus ember S3
- Membungkus
Langkah 1: Buat kode sumber
(Bagian dari:Memulai dengan AWS CodeBuild menggunakan konsol)
Pada langkah ini, Anda membuat kode sumber yang CodeBuild ingin Anda buat ke bucket keluaran. Kode sumber ini terdiri dari dua file kelas Java dan file Apache Maven Project Object Model ()POM.
-
Di direktori kosong di komputer atau instance lokal Anda, buat struktur direktori ini.
(root directory name)
`-- src |-- main | `-- java `-- test `-- java -
Menggunakan editor teks pilihan Anda, buat file ini, beri nama
MessageUtil.java
, lalu simpan disrc/main/java
direktori.public class MessageUtil { private String message; public MessageUtil(String message) { this.message = message; } public String printMessage() { System.out.println(message); return message; } public String salutationMessage() { message = "Hi!" + message; System.out.println(message); return message; } }
File kelas ini menciptakan sebagai output string karakter yang dilewatkan ke dalamnya.
MessageUtil
Konstruktor menetapkan string karakter.printMessage
Metode ini menciptakan output. OutputsalutationMessage
metodeHi!
diikuti oleh string karakter. -
Buat file ini, beri nama
TestMessageUtil.java
, lalu simpan di/src/test/java
direktori.import org.junit.Test; import org.junit.Ignore; import static org.junit.Assert.assertEquals; public class TestMessageUtil { String message = "Robert"; MessageUtil messageUtil = new MessageUtil(message); @Test public void testPrintMessage() { System.out.println("Inside testPrintMessage()"); assertEquals(message,messageUtil.printMessage()); } @Test public void testSalutationMessage() { System.out.println("Inside testSalutationMessage()"); message = "Hi!" + "Robert"; assertEquals(message,messageUtil.salutationMessage()); } }
File kelas ini menetapkan
message
variabel diMessageUtil
kelas untukRobert
. Kemudian tes untuk melihat apakahmessage
variabel berhasil diatur dengan memeriksa apakah stringRobert
danHi!Robert
muncul dalam output. -
Buat file ini, beri nama
pom.xml
, lalu simpan di direktori root (tingkat atas).<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/maven-v4_0_0.xsd"> <modelVersion>4.0.0</modelVersion> <groupId>org.example</groupId> <artifactId>messageUtil</artifactId> <version>1.0</version> <packaging>jar</packaging> <name>Message Utility Java Sample App</name> <dependencies> <dependency> <groupId>junit</groupId> <artifactId>junit</artifactId> <version>4.11</version> <scope>test</scope> </dependency> </dependencies> <build> <plugins> <plugin> <groupId>org.apache.maven.plugins</groupId> <artifactId>maven-compiler-plugin</artifactId> <version>3.8.0</version> </plugin> </plugins> </build> </project>
Apache Maven menggunakan instruksi dalam file ini untuk mengonversi file
MessageUtil.java
dan menjadiTestMessageUtil.java
file bernamamessageUtil-1.0.jar
dan kemudian menjalankan tes yang ditentukan.
Pada titik ini, struktur direktori Anda akan terlihat seperti ini.
(root directory name)
|-- pom.xml `-- src |-- main | `-- java | `-- MessageUtil.java `-- test `-- java `-- TestMessageUtil.java
Langkah 2: Buat file buildspec
(Langkah sebelumnya: Langkah 1: Buat kode sumber)
Pada langkah ini, Anda membuat file spesifikasi build (spesifikasi build). Buildspec adalah kumpulan perintah build dan pengaturan terkait, dalam YAML format, yang CodeBuild digunakan untuk menjalankan build. Tanpa spesifikasi build, CodeBuild tidak dapat berhasil mengonversi input build Anda menjadi keluaran build atau menemukan artefak keluaran build di lingkungan build untuk diunggah ke bucket keluaran Anda.
Buat file ini, beri namabuildspec.yml
, lalu simpan di direktori root (tingkat atas).
version: 0.2 phases: install: runtime-versions: java: corretto11 pre_build: commands: - echo Nothing to do in the pre_build phase... build: commands: - echo Build started on `date` - mvn install post_build: commands: - echo Build completed on `date` artifacts: files: - target/messageUtil-1.0.jar
penting
Karena deklarasi spesifikasi build harus validYAML, spasi dalam deklarasi spesifikasi build menjadi penting. Jika jumlah spasi dalam deklarasi spesifikasi build Anda tidak cocok dengan yang ini, build mungkin akan segera gagal. Anda dapat menggunakan YAML validator untuk menguji apakah deklarasi spesifikasi build Anda valid. YAML
catatan
Alih-alih menyertakan file spesifikasi build dalam kode sumber, Anda dapat mendeklarasikan perintah build secara terpisah saat membuat project build. Ini sangat membantu jika Anda ingin membangun kode sumber Anda dengan perintah build yang berbeda tanpa memperbarui repositori kode sumber Anda setiap kali. Untuk informasi selengkapnya, lihat Sintaks Buildspec.
Dalam deklarasi spesifikasi build ini:
-
version
mewakili versi standar spesifikasi build yang digunakan. Deklarasi spesifikasi build ini menggunakan versi terbaru,0.2
. -
phases
mewakili fase build di mana Anda dapat menginstruksikan CodeBuild untuk menjalankan perintah. Fase build ini tercantum di sini sebagaiinstall
,pre_build
,build
, danpost_build
. Anda tidak dapat mengubah ejaan nama fase build ini, dan Anda tidak dapat membuat lebih banyak nama fase build.Dalam contoh ini, selama
build
fase, CodeBuild jalankanmvn install
perintah. Perintah ini menginstruksikan Apache Maven untuk mengkompilasi, menguji, dan mengemas file kelas Java yang dikompilasi ke dalam artefak keluaran build. Untuk kelengkapan, beberapaecho
perintah ditempatkan di setiap fase build dalam contoh ini. Ketika Anda melihat informasi build rinci nanti dalam tutorial ini, output dariecho
perintah ini dapat membantu Anda lebih memahami bagaimana CodeBuild menjalankan perintah dan urutan apa. (Meskipun semua fase build disertakan dalam contoh ini, Anda tidak diharuskan menyertakan fase build jika Anda tidak berencana menjalankan perintah apa pun selama fase tersebut.) Untuk setiap fase build, CodeBuild jalankan setiap perintah yang ditentukan, satu per satu, dalam urutan yang terdaftar, dari awal hingga akhir. -
artifacts
mewakili kumpulan artefak keluaran build yang CodeBuild diunggah ke bucket keluaran.files
mewakili file yang akan disertakan dalam output build. CodeBuild mengunggahmessageUtil-1.0.jar
file tunggal yang ditemukan di direktoritarget
relatif di lingkungan build. Nama filemessageUtil-1.0.jar
dan nama direktoritarget
didasarkan pada cara Apache Maven membuat dan menyimpan artefak keluaran build untuk contoh ini saja. Dalam build Anda sendiri, nama file dan direktori ini berbeda.
Untuk informasi selengkapnya, lihat Referensi Buildspec.
Pada titik ini, struktur direktori Anda akan terlihat seperti ini.
(root directory name)
|-- pom.xml |-- buildspec.yml `-- src |-- main | `-- java | `-- MessageUtil.java `-- test `-- java `-- TestMessageUtil.java
Langkah 3: Buat dua ember S3
(Langkah sebelumnya: Langkah 2: Buat file buildspec)
Meskipun Anda dapat menggunakan satu bucket untuk tutorial ini, dua bucket memudahkan untuk melihat dari mana input build berasal dan ke mana output build akan pergi.
-
Salah satu bucket ini (bucket input) menyimpan input build. Dalam tutorial ini, nama bucket input ini adalah
codebuild-
, di manaregion-ID
-account-ID
-input-bucketregion-ID
adalah AWS Wilayah ember danaccount-ID
adalah ID AWS akun Anda. -
Bucket lainnya (ember keluaran) menyimpan output build. Dalam tutorial ini, nama bucket keluaran ini adalah
codebuild-
.region-ID
-account-ID
-output-bucket
Jika Anda memilih nama yang berbeda untuk ember ini, pastikan untuk menggunakannya di seluruh tutorial ini.
Kedua ember ini harus berada di AWS Wilayah yang sama dengan bangunan Anda. Misalnya, jika Anda menginstruksikan CodeBuild untuk menjalankan bangunan di Wilayah Timur AS (Ohio), ember ini juga harus berada di Wilayah Timur AS (Ohio).
Untuk informasi selengkapnya, lihat Membuat Bucket di Panduan Pengguna Layanan Penyimpanan Sederhana Amazon.
catatan
Meskipun CodeBuild juga mendukung input build yang disimpan di CodeCommit GitHub,, dan repositori Bitbucket, tutorial ini tidak menunjukkan cara menggunakannya. Untuk informasi selengkapnya, lihat Rencanakan pembangunan.
Langkah 4: Unggah kode sumber dan file buildspec
(Langkah sebelumnya: Langkah 3: Buat dua ember S3)
Pada langkah ini, Anda menambahkan kode sumber dan membangun file spesifikasi ke bucket input.
Menggunakan utilitas zip sistem operasi Anda, buat file bernama MessageUtil.zip
yang mencakupMessageUtil.java
,TestMessageUtil.java
,pom.xml
, danbuildspec.yml
.
Struktur direktori MessageUtil.zip
file harus terlihat seperti ini.
MessageUtil.zip |-- pom.xml |-- buildspec.yml `-- src |-- main | `-- java | `-- MessageUtil.java `-- test `-- java `-- TestMessageUtil.java
penting
Jangan sertakan
direktori, hanya direktori dan file di (root directory name)
direktori.(root directory name)
Unggah MessageUtil.zip
file ke bucket input bernamacodebuild-
. region-ID
-account-ID
-input-bucket
penting
Untuk CodeCommit, GitHub, dan repositori Bitbucket, menurut konvensi, Anda harus menyimpan file spesifikasi build yang diberi nama buildspec.yml
di root (tingkat atas) setiap repositori atau menyertakan deklarasi spesifikasi build sebagai bagian dari definisi proyek build. Jangan membuat ZIP file yang berisi kode sumber repositori dan membangun file spesifikasi.
Untuk input build yang disimpan di bucket S3 saja, Anda harus membuat ZIP file yang berisi kode sumber dan, menurut konvensi, file spesifikasi build bernama buildspec.yml
di root (tingkat atas) atau menyertakan deklarasi spesifikasi build sebagai bagian dari definisi proyek build.
Jika Anda ingin menggunakan nama yang berbeda untuk file spesifikasi build, atau Anda ingin mereferensikan spesifikasi build di lokasi selain root, Anda dapat menentukan penggantian spesifikasi build sebagai bagian dari definisi proyek build. Untuk informasi selengkapnya, lihat Nama file Buildspec dan lokasi penyimpanan.
Langkah 5: Buat proyek build
(Langkah sebelumnya: Langkah 4: Unggah kode sumber dan file buildspec)
Pada langkah ini, Anda membuat proyek build yang AWS CodeBuild digunakan untuk menjalankan build. Proyek build mencakup informasi tentang cara menjalankan build, termasuk tempat mendapatkan kode sumber, lingkungan build mana yang akan digunakan, perintah build mana yang akan dijalankan, dan tempat menyimpan output build. Lingkungan build mewakili kombinasi sistem operasi, runtime bahasa pemrograman, dan alat yang CodeBuild digunakan untuk menjalankan build. Lingkungan build dinyatakan sebagai image Docker. Untuk informasi selengkapnya, lihat ikhtisar Docker
Untuk lingkungan build ini, Anda menginstruksikan CodeBuild untuk menggunakan image Docker yang berisi versi Java Development Kit (JDK) dan Apache Maven.
Untuk membuat proyek build
Masuk ke AWS Management Console dan buka AWS CodeBuild konsol di https://console.aws.amazon.com/codesuite/codebuild/home
. -
Gunakan pemilih AWS wilayah untuk memilih AWS Wilayah yang CodeBuild didukung. Untuk informasi selengkapnya, lihat AWS CodeBuild titik akhir dan kuota di. Referensi Umum Amazon Web Services
Jika halaman CodeBuild informasi ditampilkan, pilih Buat proyek build. Jika tidak, pada panel navigasi, perluas Build, pilih Build projects, lalu pilih Create build project.
-
Pada halaman Create build project, dalam konfigurasi Project, untuk nama Project, masukkan nama untuk proyek build ini (dalam contoh ini,
codebuild-demo-project
). Membangun nama proyek harus unik di setiap AWS akun. Jika Anda menggunakan nama yang berbeda, pastikan untuk menggunakannya di seluruh tutorial ini.catatan
Pada halaman Buat proyek build, Anda mungkin melihat pesan galat yang mirip dengan berikut ini: Anda tidak berwenang untuk melakukan operasi ini. . Ini kemungkinan besar karena Anda masuk ke AWS Management Console sebagai pengguna yang tidak memiliki izin untuk membuat proyek build.. Untuk memperbaikinya, keluar dari AWS Management Console, lalu masuk kembali dengan kredensil milik salah satu entitas berikut: IAM
-
Pengguna administrator di AWS akun Anda. Untuk informasi selengkapnya, lihat Membuat pengguna dan grup Akun AWS root pertama Anda di Panduan pengguna.
-
Pengguna di AWS akun Anda dengan
AWSCodeBuildAdminAccess
,AmazonS3ReadOnlyAccess
, dan kebijakanIAMFullAccess
terkelola yang dilampirkan pada pengguna tersebut atau ke IAM grup tempat pengguna tersebut berada. Jika Anda tidak memiliki pengguna atau grup di AWS akun Anda dengan izin ini, dan Anda tidak dapat menambahkan izin ini ke pengguna atau grup Anda, hubungi administrator AWS akun Anda untuk mendapatkan bantuan. Untuk informasi selengkapnya, lihat AWS kebijakan terkelola (standar) untuk AWS CodeBuild.
Kedua opsi termasuk izin administrator yang memungkinkan Anda membuat proyek build sehingga Anda dapat menyelesaikan tutorial ini. Sebaiknya Anda selalu menggunakan izin minimum yang diperlukan untuk menyelesaikan tugas Anda. Untuk informasi selengkapnya, lihat AWS CodeBuild referensi izin.
-
-
Di Sumber, untuk penyedia Sumber, pilih Amazon S3.
-
Untuk Bucket, pilih codebuild-
region-ID
-account-ID
-input-ember. -
Untuk kunci objek S3, masukkan
MessageUtil.zip
. -
Di Lingkungan, untuk gambar Lingkungan, biarkan gambar Terkelola dipilih.
-
Untuk sistem operasi, pilih Amazon Linux.
-
Untuk Runtime, pilih Standar.
-
Untuk Gambar, pilih aws/codebuild/amazonlinux2-x86_64-standard:corretto11.
-
Dalam peran Layanan, biarkan peran layanan baru dipilih, dan biarkan nama Peran tidak berubah.
-
Untuk Buildspec, biarkan Gunakan file buildspec yang dipilih.
-
Di Artefak, untuk Jenis, pilih Amazon S3.
-
Untuk nama Bucket, pilih codebuild-
region-ID
-account-ID
-output-ember. -
Biarkan Nama dan Jalur kosong.
-
Pilih Buat proyek build.
Langkah 6: Jalankan build
(Langkah sebelumnya: Langkah 5: Buat proyek build)
Pada langkah ini, Anda menginstruksikan AWS CodeBuild untuk menjalankan build dengan pengaturan dalam proyek build.
Untuk menjalankan build
Buka AWS CodeBuild konsol di https://console.aws.amazon.com/codesuite/codebuild/home
. -
Di panel navigasi, pilih Membangun proyek.
-
Dalam daftar proyek build, pilih codebuild-demo-project, lalu pilih Start build. Pembangunan segera dimulai.
Langkah 7: Lihat informasi build yang dirangkum
(Langkah sebelumnya: Langkah 6: Jalankan build)
Pada langkah ini, Anda melihat informasi yang dirangkum tentang status build Anda.
Untuk melihat informasi build yang dirangkum
-
Jika codebuild-demo-project:
<build-ID>
halaman tidak ditampilkan, di bilah navigasi, pilih Build history. Selanjutnya, dalam daftar proyek build, untuk Project, pilih tautan Build run untuk codebuild-demo-project. Seharusnya hanya ada satu tautan yang cocok. (Jika Anda telah menyelesaikan tutorial ini sebelumnya, pilih tautan dengan nilai terbaru di kolom Selesai.) -
Pada halaman status Build, dalam rincian Fase, fase build berikut harus ditampilkan, dengan Succeeded di kolom Status:
-
SUBMITTED
-
QUEUED
-
PROVISIONING
-
DOWNLOAD_SOURCE
-
INSTALL
-
PRE_BUILD
-
BUILD
-
POST_BUILD
-
UPLOAD_ARTIFACTS
-
FINALIZING
-
COMPLETED
Di Build Status, Succeeded harus ditampilkan.
Jika Anda melihat Dalam Proses sebagai gantinya, pilih tombol segarkan.
-
-
Di samping setiap fase build, nilai Durasi menunjukkan berapa lama fase build berlangsung. Nilai Waktu akhir menunjukkan kapan fase build itu berakhir.
Langkah 8: Lihat informasi build terperinci
(Langkah sebelumnya: Langkah 7: Lihat informasi build yang dirangkum)
Pada langkah ini, Anda melihat informasi mendetail tentang build Anda di CloudWatch Log.
catatan
Untuk melindungi informasi sensitif, berikut ini disembunyikan di CodeBuild log:
-
AWS kunci aksesIDs. Untuk informasi selengkapnya, lihat Mengelola Kunci Akses untuk IAM Pengguna di Panduan AWS Identity and Access Management Pengguna.
-
String ditentukan menggunakan Parameter Store. Untuk informasi selengkapnya, lihat Systems Manager Parameter Store dan Systems Manager Parameter Store Console Walkthrough di Panduan Pengguna Amazon EC2 Systems Manager.
-
String ditentukan menggunakan AWS Secrets Manager. Untuk informasi selengkapnya, lihat Manajemen kunci.
Untuk melihat informasi build yang mendetail
-
Dengan halaman detail build yang masih ditampilkan dari langkah sebelumnya, 10.000 baris terakhir dari log build akan ditampilkan di log Build. Untuk melihat seluruh log build di CloudWatch Log, pilih tautan Lihat seluruh log.
-
Di aliran CloudWatch log Log, Anda dapat menelusuri peristiwa log. Secara default, hanya kumpulan peristiwa log terakhir yang ditampilkan. Untuk melihat peristiwa log sebelumnya, gulir ke awal daftar.
-
Dalam tutorial ini, sebagian besar peristiwa log berisi informasi verbose tentang CodeBuild mengunduh dan menginstal file ketergantungan build ke dalam lingkungan build-nya, yang mungkin tidak Anda pedulikan. Anda dapat menggunakan kotak Filter peristiwa untuk mengurangi informasi yang ditampilkan. Misalnya, jika Anda memasukkan
"[INFO]"
acara Filter, hanya peristiwa yang berisi yang[INFO]
ditampilkan. Untuk informasi selengkapnya, lihat Filter dan sintaks pola di Panduan CloudWatch Pengguna Amazon.
Langkah 9: Dapatkan artefak keluaran build
(Langkah sebelumnya: Langkah 8: Lihat informasi build terperinci)
Pada langkah ini, Anda mendapatkan messageUtil-1.0.jar
file yang CodeBuild dibangun dan diunggah ke bucket output.
Anda dapat menggunakan CodeBuild konsol atau konsol Amazon S3 untuk menyelesaikan langkah ini.
Untuk mendapatkan artefak keluaran build (AWS CodeBuild konsol)
-
Dengan CodeBuild konsol masih terbuka dan halaman detail build masih ditampilkan dari langkah sebelumnya, pilih tab Build details dan gulir ke bawah ke bagian Artefacts.
catatan
Jika halaman detail build tidak ditampilkan, di bilah navigasi, pilih Riwayat build, lalu pilih tautan Build run.
-
Tautan ke folder Amazon S3 berada di bawah lokasi unggah Artefak. Tautan ini membuka folder di Amazon S3 tempat Anda menemukan file artefak keluaran
messageUtil-1.0.jar
build.
Untuk mendapatkan artefak keluaran build (konsol Amazon S3)
Buka konsol Amazon S3 di. https://console.aws.amazon.com/s3/
-
Buka
codebuild-
.region-ID
-account-ID
-output-bucket -
Buka folder
codebuild-demo-project
. -
Buka
target
folder, tempat Anda menemukan file artefak keluaranmessageUtil-1.0.jar
build.
Langkah 10: Hapus ember S3
(Langkah sebelumnya: Langkah 9: Dapatkan artefak keluaran build)
Untuk mencegah tagihan yang sedang berlangsung ke AWS akun Anda, Anda dapat menghapus bucket input dan output yang digunakan dalam tutorial ini. Untuk petunjuknya, lihat Menghapus atau Mengosongkan Bucket di Panduan Pengguna Layanan Penyimpanan Sederhana Amazon.
Jika Anda menggunakan IAM pengguna atau IAM pengguna administrator untuk menghapus bucket ini, pengguna harus memiliki lebih banyak izin akses. Tambahkan pernyataan berikut di antara penanda (### BEGIN ADDING STATEMENT HERE ###
and ### END
ADDING STATEMENTS HERE ###
) ke kebijakan akses yang ada untuk pengguna.
Elips (...) dalam pernyataan ini digunakan untuk singkatnya. Jangan menghapus pernyataan apa pun dalam kebijakan akses yang ada. Jangan masukkan elips ini ke dalam kebijakan.
{ "Version": "2012-10-17", "Id": "...", "Statement": [
### BEGIN ADDING STATEMENT HERE ###
{ "Effect": "Allow", "Action": [ "s3:DeleteBucket", "s3:DeleteObject" ], "Resource": "*" }### END ADDING STATEMENT HERE ###
] }
Membungkus
Dalam tutorial ini, Anda digunakan AWS CodeBuild untuk membangun satu set file kelas Java ke dalam JAR file. Anda kemudian melihat hasil build.
Anda sekarang dapat mencoba menggunakan CodeBuild dalam skenario Anda sendiri. Ikuti petunjuk dalam Rencanakan pembangunan. Jika Anda belum merasa siap, Anda mungkin ingin mencoba membuat beberapa sampel. Untuk informasi selengkapnya, lihat Gunakan sampel berbasis kasus untuk CodeBuild.
Memulai dengan AWS CodeBuild menggunakan AWS CLI
Dalam tutorial ini, Anda gunakan AWS CodeBuild untuk membangun kumpulan file input kode sumber sampel (disebut artefak input build atau input build) ke dalam versi kode sumber yang dapat diterapkan (disebut artefak keluaran build atau output build). Secara khusus, Anda menginstruksikan CodeBuild untuk menggunakan Apache Maven, alat build umum, untuk membangun satu set file kelas Java ke dalam file Java Archive (). JAR Anda tidak perlu terbiasa dengan Apache Maven atau Java untuk menyelesaikan tutorial ini.
Anda dapat bekerja dengan CodeBuild melalui CodeBuild konsol AWS CodePipeline, AWS CLI, atau AWS SDKs. Tutorial ini menunjukkan bagaimana menggunakan CodeBuild dengan. AWS CLI Untuk informasi tentang penggunaan CodePipeline, lihatGunakan CodeBuild dengan CodePipeline.
penting
Langkah-langkah dalam tutorial ini mengharuskan Anda untuk membuat sumber daya (misalnya, bucket S3) yang mungkin mengakibatkan biaya ke AWS akun Anda. Ini termasuk kemungkinan biaya untuk CodeBuild dan untuk AWS sumber daya dan tindakan yang terkait dengan Amazon S3, AWS KMS, dan CloudWatch Log. Untuk informasi selengkapnya, lihat CodeBuildharga, harga
Topik
- Langkah 1: Buat kode sumber
- Langkah 2: Buat file buildspec
- Langkah 3: Buat dua ember S3
- Langkah 4: Unggah kode sumber dan file buildspec
- Langkah 5: Buat proyek build
- Langkah 6: Jalankan build
- Langkah 7: Lihat informasi build yang dirangkum
- Langkah 8: Lihat informasi build terperinci
- Langkah 9: Dapatkan artefak keluaran build
- Langkah 10: Hapus ember S3
- Membungkus
Langkah 1: Buat kode sumber
(Bagian dari:Memulai dengan AWS CodeBuild menggunakan AWS CLI)
Pada langkah ini, Anda membuat kode sumber yang CodeBuild ingin Anda buat ke bucket keluaran. Kode sumber ini terdiri dari dua file kelas Java dan file Apache Maven Project Object Model ()POM.
-
Di direktori kosong di komputer atau instance lokal Anda, buat struktur direktori ini.
(root directory name)
`-- src |-- main | `-- java `-- test `-- java -
Menggunakan editor teks pilihan Anda, buat file ini, beri nama
MessageUtil.java
, lalu simpan disrc/main/java
direktori.public class MessageUtil { private String message; public MessageUtil(String message) { this.message = message; } public String printMessage() { System.out.println(message); return message; } public String salutationMessage() { message = "Hi!" + message; System.out.println(message); return message; } }
File kelas ini menciptakan sebagai output string karakter yang dilewatkan ke dalamnya.
MessageUtil
Konstruktor menetapkan string karakter.printMessage
Metode ini menciptakan output. OutputsalutationMessage
metodeHi!
diikuti oleh string karakter. -
Buat file ini, beri nama
TestMessageUtil.java
, lalu simpan di/src/test/java
direktori.import org.junit.Test; import org.junit.Ignore; import static org.junit.Assert.assertEquals; public class TestMessageUtil { String message = "Robert"; MessageUtil messageUtil = new MessageUtil(message); @Test public void testPrintMessage() { System.out.println("Inside testPrintMessage()"); assertEquals(message,messageUtil.printMessage()); } @Test public void testSalutationMessage() { System.out.println("Inside testSalutationMessage()"); message = "Hi!" + "Robert"; assertEquals(message,messageUtil.salutationMessage()); } }
File kelas ini menetapkan
message
variabel diMessageUtil
kelas untukRobert
. Kemudian tes untuk melihat apakahmessage
variabel berhasil diatur dengan memeriksa apakah stringRobert
danHi!Robert
muncul dalam output. -
Buat file ini, beri nama
pom.xml
, lalu simpan di direktori root (tingkat atas).<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/maven-v4_0_0.xsd"> <modelVersion>4.0.0</modelVersion> <groupId>org.example</groupId> <artifactId>messageUtil</artifactId> <version>1.0</version> <packaging>jar</packaging> <name>Message Utility Java Sample App</name> <dependencies> <dependency> <groupId>junit</groupId> <artifactId>junit</artifactId> <version>4.11</version> <scope>test</scope> </dependency> </dependencies> <build> <plugins> <plugin> <groupId>org.apache.maven.plugins</groupId> <artifactId>maven-compiler-plugin</artifactId> <version>3.8.0</version> </plugin> </plugins> </build> </project>
Apache Maven menggunakan instruksi dalam file ini untuk mengonversi file
MessageUtil.java
dan menjadiTestMessageUtil.java
file bernamamessageUtil-1.0.jar
dan kemudian menjalankan tes yang ditentukan.
Pada titik ini, struktur direktori Anda akan terlihat seperti ini.
(root directory name)
|-- pom.xml `-- src |-- main | `-- java | `-- MessageUtil.java `-- test `-- java `-- TestMessageUtil.java
Langkah 2: Buat file buildspec
(Langkah sebelumnya: Langkah 1: Buat kode sumber)
Pada langkah ini, Anda membuat file spesifikasi build (spesifikasi build). Buildspec adalah kumpulan perintah build dan pengaturan terkait, dalam YAML format, yang CodeBuild digunakan untuk menjalankan build. Tanpa spesifikasi build, CodeBuild tidak dapat berhasil mengonversi input build Anda menjadi keluaran build atau menemukan artefak keluaran build di lingkungan build untuk diunggah ke bucket keluaran Anda.
Buat file ini, beri namabuildspec.yml
, lalu simpan di direktori root (tingkat atas).
version: 0.2 phases: install: runtime-versions: java: corretto11 pre_build: commands: - echo Nothing to do in the pre_build phase... build: commands: - echo Build started on `date` - mvn install post_build: commands: - echo Build completed on `date` artifacts: files: - target/messageUtil-1.0.jar
penting
Karena deklarasi spesifikasi build harus validYAML, spasi dalam deklarasi spesifikasi build menjadi penting. Jika jumlah spasi dalam deklarasi spesifikasi build Anda tidak cocok dengan yang ini, build mungkin akan segera gagal. Anda dapat menggunakan YAML validator untuk menguji apakah deklarasi spesifikasi build Anda valid. YAML
catatan
Alih-alih menyertakan file spesifikasi build dalam kode sumber, Anda dapat mendeklarasikan perintah build secara terpisah saat membuat project build. Ini sangat membantu jika Anda ingin membangun kode sumber Anda dengan perintah build yang berbeda tanpa memperbarui repositori kode sumber Anda setiap kali. Untuk informasi selengkapnya, lihat Sintaks Buildspec.
Dalam deklarasi spesifikasi build ini:
-
version
mewakili versi standar spesifikasi build yang digunakan. Deklarasi spesifikasi build ini menggunakan versi terbaru,0.2
. -
phases
mewakili fase build di mana Anda dapat menginstruksikan CodeBuild untuk menjalankan perintah. Fase build ini tercantum di sini sebagaiinstall
,pre_build
,build
, danpost_build
. Anda tidak dapat mengubah ejaan nama fase build ini, dan Anda tidak dapat membuat lebih banyak nama fase build.Dalam contoh ini, selama
build
fase, CodeBuild jalankanmvn install
perintah. Perintah ini menginstruksikan Apache Maven untuk mengkompilasi, menguji, dan mengemas file kelas Java yang dikompilasi ke dalam artefak keluaran build. Untuk kelengkapan, beberapaecho
perintah ditempatkan di setiap fase build dalam contoh ini. Ketika Anda melihat informasi build rinci nanti dalam tutorial ini, output dariecho
perintah ini dapat membantu Anda lebih memahami bagaimana CodeBuild menjalankan perintah dan urutan apa. (Meskipun semua fase build disertakan dalam contoh ini, Anda tidak diharuskan menyertakan fase build jika Anda tidak berencana menjalankan perintah apa pun selama fase tersebut.) Untuk setiap fase build, CodeBuild jalankan setiap perintah yang ditentukan, satu per satu, dalam urutan yang terdaftar, dari awal hingga akhir. -
artifacts
mewakili kumpulan artefak keluaran build yang CodeBuild diunggah ke bucket keluaran.files
mewakili file yang akan disertakan dalam output build. CodeBuild mengunggahmessageUtil-1.0.jar
file tunggal yang ditemukan di direktoritarget
relatif di lingkungan build. Nama filemessageUtil-1.0.jar
dan nama direktoritarget
didasarkan pada cara Apache Maven membuat dan menyimpan artefak keluaran build untuk contoh ini saja. Dalam build Anda sendiri, nama file dan direktori ini berbeda.
Untuk informasi selengkapnya, lihat Referensi Buildspec.
Pada titik ini, struktur direktori Anda akan terlihat seperti ini.
(root directory name)
|-- pom.xml |-- buildspec.yml `-- src |-- main | `-- java | `-- MessageUtil.java `-- test `-- java `-- TestMessageUtil.java
Langkah 3: Buat dua ember S3
(Langkah sebelumnya: Langkah 2: Buat file buildspec)
Meskipun Anda dapat menggunakan satu bucket untuk tutorial ini, dua bucket memudahkan untuk melihat dari mana input build berasal dan ke mana output build akan pergi.
-
Salah satu bucket ini (bucket input) menyimpan input build. Dalam tutorial ini, nama bucket input ini adalah
codebuild-
, di manaregion-ID
-account-ID
-input-bucketregion-ID
adalah AWS Wilayah ember danaccount-ID
adalah ID AWS akun Anda. -
Bucket lainnya (ember keluaran) menyimpan output build. Dalam tutorial ini, nama bucket keluaran ini adalah
codebuild-
.region-ID
-account-ID
-output-bucket
Jika Anda memilih nama yang berbeda untuk ember ini, pastikan untuk menggunakannya di seluruh tutorial ini.
Kedua ember ini harus berada di AWS Wilayah yang sama dengan bangunan Anda. Misalnya, jika Anda menginstruksikan CodeBuild untuk menjalankan bangunan di Wilayah Timur AS (Ohio), ember ini juga harus berada di Wilayah Timur AS (Ohio).
Untuk informasi selengkapnya, lihat Membuat Bucket di Panduan Pengguna Layanan Penyimpanan Sederhana Amazon.
catatan
Meskipun CodeBuild juga mendukung input build yang disimpan di CodeCommit GitHub,, dan repositori Bitbucket, tutorial ini tidak menunjukkan cara menggunakannya. Untuk informasi selengkapnya, lihat Rencanakan pembangunan.
Langkah 4: Unggah kode sumber dan file buildspec
(Langkah sebelumnya: Langkah 3: Buat dua ember S3)
Pada langkah ini, Anda menambahkan kode sumber dan membangun file spesifikasi ke bucket input.
Menggunakan utilitas zip sistem operasi Anda, buat file bernama MessageUtil.zip
yang mencakupMessageUtil.java
,TestMessageUtil.java
,pom.xml
, danbuildspec.yml
.
Struktur direktori MessageUtil.zip
file harus terlihat seperti ini.
MessageUtil.zip |-- pom.xml |-- buildspec.yml `-- src |-- main | `-- java | `-- MessageUtil.java `-- test `-- java `-- TestMessageUtil.java
penting
Jangan sertakan
direktori, hanya direktori dan file di (root directory name)
direktori.(root directory name)
Unggah MessageUtil.zip
file ke bucket input bernamacodebuild-
. region-ID
-account-ID
-input-bucket
penting
Untuk CodeCommit, GitHub, dan repositori Bitbucket, menurut konvensi, Anda harus menyimpan file spesifikasi build yang diberi nama buildspec.yml
di root (tingkat atas) setiap repositori atau menyertakan deklarasi spesifikasi build sebagai bagian dari definisi proyek build. Jangan membuat ZIP file yang berisi kode sumber repositori dan membangun file spesifikasi.
Untuk input build yang disimpan di bucket S3 saja, Anda harus membuat ZIP file yang berisi kode sumber dan, menurut konvensi, file spesifikasi build bernama buildspec.yml
di root (tingkat atas) atau menyertakan deklarasi spesifikasi build sebagai bagian dari definisi proyek build.
Jika Anda ingin menggunakan nama yang berbeda untuk file spesifikasi build, atau Anda ingin mereferensikan spesifikasi build di lokasi selain root, Anda dapat menentukan penggantian spesifikasi build sebagai bagian dari definisi proyek build. Untuk informasi selengkapnya, lihat Nama file Buildspec dan lokasi penyimpanan.
Langkah 5: Buat proyek build
(Langkah sebelumnya: Langkah 4: Unggah kode sumber dan file buildspec)
Pada langkah ini, Anda membuat proyek build yang AWS CodeBuild digunakan untuk menjalankan build. Proyek build mencakup informasi tentang cara menjalankan build, termasuk tempat mendapatkan kode sumber, lingkungan build mana yang akan digunakan, perintah build mana yang akan dijalankan, dan tempat menyimpan output build. Lingkungan build mewakili kombinasi sistem operasi, runtime bahasa pemrograman, dan alat yang CodeBuild digunakan untuk menjalankan build. Lingkungan build dinyatakan sebagai image Docker. Untuk informasi selengkapnya, lihat ikhtisar Docker
Untuk lingkungan build ini, Anda menginstruksikan CodeBuild untuk menggunakan image Docker yang berisi versi Java Development Kit (JDK) dan Apache Maven.
Untuk membuat proyek build
-
Gunakan tombol AWS CLI untuk menjalankan create-project perintah:
aws codebuild create-project --generate-cli-skeleton
JSON-data yang diformat muncul di output. Salin data ke file bernama
create-project.json
di lokasi di komputer lokal atau contoh di AWS CLI mana diinstal. Jika Anda memilih untuk menggunakan nama file yang berbeda, pastikan untuk menggunakannya di seluruh tutorial ini.Ubah data yang disalin untuk mengikuti format ini, lalu simpan hasil Anda:
{ "name": "codebuild-demo-project", "source": { "type": "S3", "location": "codebuild-
region-ID
-account-ID
-input-bucket/MessageUtil.zip" }, "artifacts": { "type": "S3", "location": "codebuild-region-ID
-account-ID
-output-bucket" }, "environment": { "type": "LINUX_CONTAINER", "image": "aws/codebuild/standard:5.0", "computeType": "BUILD_GENERAL1_SMALL" }, "serviceRole": "serviceIAMRole
" }Ganti
serviceIAMRole
dengan Amazon Resource Name (ARN) dari peran CodeBuild layanan (misalnya,arn:aws:iam::
). Untuk membuatnya, lihat Memungkinkan CodeBuild untuk berinteraksi dengan AWS layanan lain.account-ID
:role/role-name
Dalam data ini:
-
name
mewakili pengenal yang diperlukan untuk proyek build ini (dalam contoh ini,codebuild-demo-project
). Nama proyek build harus unik di semua proyek build di akun Anda. -
Untuk
source
,type
adalah nilai wajib yang mewakili jenis repositori kode sumber (dalam contoh ini,S3
untuk bucket Amazon S3). -
Untuk
source
,location
mewakili jalur ke kode sumber (dalam contoh ini, nama bucket input diikuti dengan nama ZIP file). -
Untuk
artifacts
,type
adalah nilai wajib yang mewakili tipe repositori artefak keluaran build (dalam contoh ini,S3
untuk bucket Amazon S3). -
Untuk
artifacts
,location
mewakili nama bucket keluaran yang Anda buat atau identifikasi sebelumnya (dalam contoh ini,codebuild-
).region-ID
-account-ID
-output-bucket -
Untuk
environment
,type
adalah nilai wajib yang mewakili jenis lingkungan build (dalam contoh ini,LINUX_CONTAINER
). -
Untuk
environment
,image
adalah nilai wajib yang mewakili nama gambar Docker dan kombinasi tag yang digunakan proyek build ini, seperti yang ditentukan oleh jenis repositori gambar Docker (dalam contoh ini,aws/codebuild/standard:5.0
untuk gambar Docker di repositori gambar Docker). CodeBuildaws/codebuild/standard
adalah nama gambar Docker.5.0
adalah tag dari gambar Docker.Untuk menemukan lebih banyak gambar Docker yang dapat Anda gunakan dalam skenario Anda, lihat. Membangun referensi lingkungan
-
Untuk
environment
,computeType
adalah nilai wajib yang mewakili sumber daya komputasi CodeBuild menggunakan (dalam contoh ini,BUILD_GENERAL1_SMALL
).
catatan
Nilai lain yang tersedia dalam data JSON berformat asli, seperti,
description
buildspec
,auth
(termasuktype
danresource
),,path
,name
(untukartifacts
)namespaceType
,environmentVariables
(termasukname
danvalue
)packaging
,,,timeoutInMinutes
encryptionKey
, dantags
(termasukkey
danvalue
) adalah opsional. Mereka tidak digunakan dalam tutorial ini, jadi mereka tidak ditampilkan di sini. Untuk informasi selengkapnya, lihat Buat proyek build (AWS CLI). -
-
Beralih ke direktori yang berisi file yang baru saja Anda simpan, lalu jalankan create-project perintah lagi.
aws codebuild create-project --cli-input-json file://create-project.json
Jika berhasil, data yang mirip dengan ini muncul di output.
{ "project": { "name": "codebuild-demo-project", "serviceRole": "
serviceIAMRole
", "tags": [], "artifacts": { "packaging": "NONE", "type": "S3", "location": "codebuild-region-ID
-account-ID
-output-bucket", "name": "message-util.zip" }, "lastModified": 1472661575.244, "timeoutInMinutes": 60, "created": 1472661575.244, "environment": { "computeType": "BUILD_GENERAL1_SMALL", "image": "aws/codebuild/standard:5.0", "type": "LINUX_CONTAINER", "environmentVariables": [] }, "source": { "type": "S3", "location": "codebuild-region-ID
-account-ID
-input-bucket/MessageUtil.zip" }, "encryptionKey": "arn:aws:kms:region-ID
:account-ID
:alias/aws/s3", "arn": "arn:aws:codebuild:region-ID
:account-ID
:project/codebuild-demo-project" } }-
project
mewakili informasi tentang proyek pembangunan ini.-
tags
mewakili setiap tag yang dideklarasikan. -
packaging
mewakili bagaimana artefak keluaran build disimpan dalam bucket keluaran.NONE
berarti folder dibuat di bucket output. Artefak keluaran build disimpan di folder itu. -
lastModified
mewakili waktu, dalam format waktu Unix, ketika informasi tentang proyek pembangunan terakhir diubah. -
timeoutInMinutes
mewakili jumlah menit setelah itu CodeBuild menghentikan build jika build belum selesai. (Standarnya adalah 60 menit.) -
created
mewakili waktu, dalam format waktu Unix, ketika proyek build dibuat. -
environmentVariables
mewakili variabel lingkungan apa pun yang dideklarasikan dan tersedia CodeBuild untuk digunakan selama pembuatan. -
encryptionKey
mewakili kunci ARN terkelola pelanggan yang CodeBuild digunakan untuk mengenkripsi artefak keluaran build. -
arn
mewakili ARN proyek pembangunan.
-
-
catatan
Setelah Anda menjalankan create-project perintah, pesan kesalahan yang mirip dengan berikut ini mungkin output: Pengguna: user-ARN
tidak diizinkan untuk melakukan: codebuild: CreateProject. Hal ini kemungkinan besar karena Anda mengkonfigurasi AWS CLI dengan kredensi pengguna yang tidak memiliki izin yang cukup untuk digunakan CodeBuild untuk membuat proyek build. Untuk memperbaikinya, konfigurasikan kredensi AWS CLI
dengan milik salah satu entitas berikut: IAM
-
Pengguna administrator di AWS akun Anda. Untuk informasi selengkapnya, lihat Membuat pengguna dan grup Akun AWS root pertama Anda di Panduan pengguna.
-
Pengguna di AWS akun Anda dengan
AWSCodeBuildAdminAccess
,AmazonS3ReadOnlyAccess
, dan kebijakanIAMFullAccess
terkelola yang dilampirkan pada pengguna tersebut atau ke IAM grup tempat pengguna tersebut berada. Jika Anda tidak memiliki pengguna atau grup di AWS akun Anda dengan izin ini, dan Anda tidak dapat menambahkan izin ini ke pengguna atau grup Anda, hubungi administrator AWS akun Anda untuk mendapatkan bantuan. Untuk informasi selengkapnya, lihat AWS kebijakan terkelola (standar) untuk AWS CodeBuild.
Langkah 6: Jalankan build
(Langkah sebelumnya: Langkah 5: Buat proyek build)
Pada langkah ini, Anda menginstruksikan AWS CodeBuild untuk menjalankan build dengan pengaturan dalam proyek build.
Untuk menjalankan build
-
Gunakan tombol AWS CLI untuk menjalankan start-build perintah:
aws codebuild start-build --project-name
project-name
Ganti
project-name
dengan nama proyek build Anda dari langkah sebelumnya (misalnya,codebuild-demo-project
). -
Jika berhasil, data yang mirip dengan berikut ini muncul di output:
{ "build": { "buildComplete": false, "initiator": "
user-name
", "artifacts": { "location": "arn:aws:s3:::codebuild-region-ID
-account-ID
-output-bucket/message-util.zip" }, "projectName": "codebuild-demo-project", "timeoutInMinutes": 60, "buildStatus": "IN_PROGRESS", "environment": { "computeType": "BUILD_GENERAL1_SMALL", "image": "aws/codebuild/standard:5.0", "type": "LINUX_CONTAINER", "environmentVariables": [] }, "source": { "type": "S3", "location": "codebuild-region-ID
-account-ID
-input-bucket/MessageUtil.zip" }, "currentPhase": "SUBMITTED", "startTime": 1472848787.882, "id": "codebuild-demo-project:0cfbb6ec-3db9-4e8c-992b-1ab28EXAMPLE", "arn": "arn:aws:codebuild:region-ID
:account-ID
:build/codebuild-demo-project:0cfbb6ec-3db9-4e8c-992b-1ab28EXAMPLE" } }-
build
mewakili informasi tentang build ini.-
buildComplete
mewakili apakah build telah selesai (true
). Atau,false
. -
initiator
mewakili entitas yang memulai pembangunan. -
artifacts
mewakili informasi tentang keluaran build, termasuk lokasinya. -
projectName
mewakili nama proyek pembangunan. -
buildStatus
mewakili status build saat ini saat start-build perintah dijalankan. -
currentPhase
mewakili fase build saat ini saat start-build perintah dijalankan. -
startTime
mewakili waktu, dalam format waktu Unix, saat proses pembuatan dimulai. -
id
mewakili ID build. -
arn
ARNmewakili build.
-
Catat
id
nilainya. Anda membutuhkannya di langkah berikutnya. -
Langkah 7: Lihat informasi build yang dirangkum
(Langkah sebelumnya: Langkah 6: Jalankan build)
Pada langkah ini, Anda melihat informasi yang dirangkum tentang status build Anda.
Untuk melihat informasi build yang dirangkum
-
Gunakan AWS CLI untuk menjalankan batch-get-builds perintah.
aws codebuild batch-get-builds --ids
id
Ganti
id
denganid
nilai yang muncul pada output dari langkah sebelumnya.Jika berhasil, data yang mirip dengan ini muncul di output.
{ "buildsNotFound": [], "builds": [ { "buildComplete": true, "phases": [ { "phaseStatus": "SUCCEEDED", "endTime": 1472848788.525, "phaseType": "SUBMITTED", "durationInSeconds": 0, "startTime": 1472848787.882 },
... The full list of build phases has been omitted for brevity ...
{ "phaseType": "COMPLETED", "startTime": 1472848878.079 } ], "logs": { "groupName": "/aws/codebuild/codebuild-demo-project", "deepLink": "https://console.aws.amazon.com/cloudwatch/home?region=region-ID
#logEvent:group=/aws/codebuild/codebuild-demo-project;stream=38ca1c4a-e9ca-4dbc-bef1-d52bfEXAMPLE", "streamName": "38ca1c4a-e9ca-4dbc-bef1-d52bfEXAMPLE" }, "artifacts": { "md5sum": "MD5-hash
", "location": "arn:aws:s3:::codebuild-region-ID
-account-ID
-output-bucket/message-util.zip", "sha256sum": "SHA-256-hash
" }, "projectName": "codebuild-demo-project", "timeoutInMinutes": 60, "initiator": "user-name
", "buildStatus": "SUCCEEDED", "environment": { "computeType": "BUILD_GENERAL1_SMALL", "image": "aws/codebuild/standard:5.0", "type": "LINUX_CONTAINER", "environmentVariables": [] }, "source": { "type": "S3", "location": "codebuild-region-ID
-account-ID
-input-bucket/MessageUtil.zip" }, "currentPhase": "COMPLETED", "startTime": 1472848787.882, "endTime": 1472848878.079, "id": "codebuild-demo-project:38ca1c4a-e9ca-4dbc-bef1-d52bfEXAMPLE", "arn": "arn:aws:codebuild:region-ID
:account-ID
:build/codebuild-demo-project:38ca1c4a-e9ca-4dbc-bef1-d52bfEXAMPLE" } ] }-
buildsNotFound
mewakili build IDs untuk build apa pun yang informasinya tidak tersedia. Dalam contoh ini, itu harus kosong. -
builds
mewakili informasi tentang setiap build di mana informasi tersedia. Dalam contoh ini, informasi tentang hanya satu build muncul di output.-
phases
mewakili serangkaian fase build yang CodeBuild berjalan selama proses build. Informasi tentang setiap fase build dicantumkan secara terpisah sebagaistartTime
endTime
,, dandurationInSeconds
(ketika fase build dimulai dan berakhir, dinyatakan dalam format waktu Unix, dan berapa lama berlangsung, dalam hitungan detik), danphaseType
seperti (SUBMITTED
,,PROVISIONING
,DOWNLOAD_SOURCE
,INSTALL
,PRE_BUILD
,BUILD
,POST_BUILD
UPLOAD_ARTIFACTS
FINALIZING
, atauCOMPLETED
) danphaseStatus
(sepertiSUCCEEDED
,,,,FAILED
,FAULT
TIMED_OUT
IN_PROGRESS
, atauSTOPPED
). Pertama kali Anda menjalankan batch-get-buildsperintah, mungkin tidak ada banyak (atau apa pun) fase. Setelah menjalankan batch-get-buildsperintah berikutnya dengan ID build yang sama, lebih banyak fase build akan muncul di output. -
logs
mewakili informasi di Amazon CloudWatch Logs tentang log build. -
md5sum
dansha256sum
mewakili MD5 dan SHA -256 hash dari artefak keluaran build. Ini muncul di output hanya jikapackaging
nilai proyek build disetel keZIP
. (Anda tidak menetapkan nilai ini dalam tutorial ini.) Anda dapat menggunakan hash ini bersama dengan alat checksum untuk mengonfirmasi integritas dan keaslian file.catatan
Anda juga dapat menggunakan konsol Amazon S3 untuk melihat hash ini. Pilih kotak di samping artefak keluaran build, pilih Actions, lalu pilih Properties. Di panel Properties, perluas Metadata, dan lihat nilai untuk x-amz-meta-codebuild-content-md5 dan -content-sha256. x-amz-meta-codebuild (Di konsol Amazon S3, ETagnilai artefak keluaran build tidak boleh ditafsirkan sebagai hash MD5 atau SHA -256.)
Jika Anda menggunakan AWS SDKs untuk mendapatkan hash ini, nilainya diberi nama
codebuild-content-md5
dancodebuild-content-sha256
. -
endTime
mewakili waktu, dalam format waktu Unix, ketika proses pembangunan berakhir.
-
catatan
Metadata Amazon S3 memiliki CodeBuild header bernama yang berisi CodeBuild build
x-amz-meta-codebuild-buildarn
yang menerbitkanbuildArn
artefak ke Amazon S3. Ditambahkan untuk memungkinkan pelacakan sumber untuk notifikasi dan referensi dari mana artefak tersebut dihasilkan.buildArn
-
Langkah 8: Lihat informasi build terperinci
(Langkah sebelumnya: Langkah 7: Lihat informasi build yang dirangkum)
Pada langkah ini, Anda melihat informasi mendetail tentang build Anda di CloudWatch Log.
catatan
Untuk melindungi informasi sensitif, berikut ini disembunyikan di CodeBuild log:
-
AWS kunci aksesIDs. Untuk informasi selengkapnya, lihat Mengelola Kunci Akses untuk IAM Pengguna di Panduan AWS Identity and Access Management Pengguna.
-
String ditentukan menggunakan Parameter Store. Untuk informasi selengkapnya, lihat Systems Manager Parameter Store dan Systems Manager Parameter Store Console Walkthrough di Panduan Pengguna Amazon EC2 Systems Manager.
-
String ditentukan menggunakan AWS Secrets Manager. Untuk informasi selengkapnya, lihat Manajemen kunci.
Untuk melihat informasi build yang mendetail
-
Gunakan browser web Anda untuk pergi ke
deepLink
lokasi yang muncul di output pada langkah sebelumnya (misalnya,https://console.aws.amazon.com/cloudwatch/home?region=
).region-ID
#logEvent:group=/aws/codebuild/codebuild-demo-project;stream=38ca1c4a-e9ca-4dbc-bef1-d52bfEXAMPLE -
Di aliran CloudWatch log Log, Anda dapat menelusuri peristiwa log. Secara default, hanya kumpulan peristiwa log terakhir yang ditampilkan. Untuk melihat peristiwa log sebelumnya, gulir ke awal daftar.
-
Dalam tutorial ini, sebagian besar peristiwa log berisi informasi verbose tentang CodeBuild mengunduh dan menginstal file ketergantungan build ke dalam lingkungan build-nya, yang mungkin tidak Anda pedulikan. Anda dapat menggunakan kotak Filter peristiwa untuk mengurangi informasi yang ditampilkan. Misalnya, jika Anda memasukkan
"[INFO]"
acara Filter, hanya peristiwa yang berisi yang[INFO]
ditampilkan. Untuk informasi selengkapnya, lihat Filter dan sintaks pola di Panduan CloudWatch Pengguna Amazon.
Bagian-bagian dari aliran CloudWatch log Log ini berkaitan dengan tutorial ini.
... [Container] 2016/04/15 17:49:42 Entering phase PRE_BUILD [Container] 2016/04/15 17:49:42 Running command echo Entering pre_build phase... [Container] 2016/04/15 17:49:42 Entering pre_build phase... [Container] 2016/04/15 17:49:42 Phase complete: PRE_BUILD Success: true [Container] 2016/04/15 17:49:42 Entering phase BUILD [Container] 2016/04/15 17:49:42 Running command echo Entering build phase... [Container] 2016/04/15 17:49:42 Entering build phase... [Container] 2016/04/15 17:49:42 Running command mvn install [Container] 2016/04/15 17:49:44 [INFO] Scanning for projects... [Container] 2016/04/15 17:49:44 [INFO] [Container] 2016/04/15 17:49:44 [INFO] ------------------------------------------------------------------------ [Container] 2016/04/15 17:49:44 [INFO] Building Message Utility Java Sample App 1.0 [Container] 2016/04/15 17:49:44 [INFO] ------------------------------------------------------------------------ ... [Container] 2016/04/15 17:49:55 ------------------------------------------------------- [Container] 2016/04/15 17:49:55 T E S T S [Container] 2016/04/15 17:49:55 ------------------------------------------------------- [Container] 2016/04/15 17:49:55 Running TestMessageUtil [Container] 2016/04/15 17:49:55 Inside testSalutationMessage() [Container] 2016/04/15 17:49:55 Hi!Robert [Container] 2016/04/15 17:49:55 Inside testPrintMessage() [Container] 2016/04/15 17:49:55 Robert [Container] 2016/04/15 17:49:55 Tests run: 2, Failures: 0, Errors: 0, Skipped: 0, Time elapsed: 0.018 sec [Container] 2016/04/15 17:49:55 [Container] 2016/04/15 17:49:55 Results : [Container] 2016/04/15 17:49:55 [Container] 2016/04/15 17:49:55 Tests run: 2, Failures: 0, Errors: 0, Skipped: 0 ... [Container] 2016/04/15 17:49:56 [INFO] ------------------------------------------------------------------------ [Container] 2016/04/15 17:49:56 [INFO] BUILD SUCCESS [Container] 2016/04/15 17:49:56 [INFO] ------------------------------------------------------------------------ [Container] 2016/04/15 17:49:56 [INFO] Total time: 11.845 s [Container] 2016/04/15 17:49:56 [INFO] Finished at: 2016-04-15T17:49:56+00:00 [Container] 2016/04/15 17:49:56 [INFO] Final Memory: 18M/216M [Container] 2016/04/15 17:49:56 [INFO] ------------------------------------------------------------------------ [Container] 2016/04/15 17:49:56 Phase complete: BUILD Success: true [Container] 2016/04/15 17:49:56 Entering phase POST_BUILD [Container] 2016/04/15 17:49:56 Running command echo Entering post_build phase... [Container] 2016/04/15 17:49:56 Entering post_build phase... [Container] 2016/04/15 17:49:56 Phase complete: POST_BUILD Success: true [Container] 2016/04/15 17:49:57 Preparing to copy artifacts [Container] 2016/04/15 17:49:57 Assembling file list [Container] 2016/04/15 17:49:57 Expanding target/messageUtil-1.0.jar [Container] 2016/04/15 17:49:57 Found target/messageUtil-1.0.jar [Container] 2016/04/15 17:49:57 Creating zip artifact
Dalam contoh ini, CodeBuild berhasil menyelesaikan fase pre-build, build, dan post-build build. Ini menjalankan tes unit dan berhasil membangun messageUtil-1.0.jar
file.
Langkah 9: Dapatkan artefak keluaran build
(Langkah sebelumnya: Langkah 8: Lihat informasi build terperinci)
Pada langkah ini, Anda mendapatkan messageUtil-1.0.jar
file yang CodeBuild dibangun dan diunggah ke bucket output.
Anda dapat menggunakan CodeBuild konsol atau konsol Amazon S3 untuk menyelesaikan langkah ini.
Untuk mendapatkan artefak keluaran build (AWS CodeBuild konsol)
-
Dengan CodeBuild konsol masih terbuka dan halaman detail build masih ditampilkan dari langkah sebelumnya, pilih tab Build details dan gulir ke bawah ke bagian Artefacts.
catatan
Jika halaman detail build tidak ditampilkan, di bilah navigasi, pilih Riwayat build, lalu pilih tautan Build run.
-
Tautan ke folder Amazon S3 berada di bawah lokasi unggah Artefak. Tautan ini membuka folder di Amazon S3 tempat Anda menemukan file artefak keluaran
messageUtil-1.0.jar
build.
Untuk mendapatkan artefak keluaran build (konsol Amazon S3)
Buka konsol Amazon S3 di. https://console.aws.amazon.com/s3/
-
Buka
codebuild-
.region-ID
-account-ID
-output-bucket -
Buka folder
codebuild-demo-project
. -
Buka
target
folder, tempat Anda menemukan file artefak keluaranmessageUtil-1.0.jar
build.
Langkah 10: Hapus ember S3
(Langkah sebelumnya: Langkah 9: Dapatkan artefak keluaran build)
Untuk mencegah tagihan yang sedang berlangsung ke AWS akun Anda, Anda dapat menghapus bucket input dan output yang digunakan dalam tutorial ini. Untuk petunjuknya, lihat Menghapus atau Mengosongkan Bucket di Panduan Pengguna Layanan Penyimpanan Sederhana Amazon.
Jika Anda menggunakan IAM pengguna atau IAM pengguna administrator untuk menghapus bucket ini, pengguna harus memiliki lebih banyak izin akses. Tambahkan pernyataan berikut di antara penanda (### BEGIN ADDING STATEMENT HERE ###
and ### END
ADDING STATEMENTS HERE ###
) ke kebijakan akses yang ada untuk pengguna.
Elips (...) dalam pernyataan ini digunakan untuk singkatnya. Jangan menghapus pernyataan apa pun dalam kebijakan akses yang ada. Jangan masukkan elips ini ke dalam kebijakan.
{ "Version": "2012-10-17", "Id": "...", "Statement": [
### BEGIN ADDING STATEMENT HERE ###
{ "Effect": "Allow", "Action": [ "s3:DeleteBucket", "s3:DeleteObject" ], "Resource": "*" }### END ADDING STATEMENT HERE ###
] }
Membungkus
Dalam tutorial ini, Anda digunakan AWS CodeBuild untuk membangun satu set file kelas Java ke dalam JAR file. Anda kemudian melihat hasil build.
Anda sekarang dapat mencoba menggunakan CodeBuild dalam skenario Anda sendiri. Ikuti petunjuk dalam Rencanakan pembangunan. Jika Anda belum merasa siap, Anda mungkin ingin mencoba membuat beberapa sampel. Untuk informasi selengkapnya, lihat Gunakan sampel berbasis kasus untuk CodeBuild.