Terjemahan disediakan oleh mesin penerjemah. Jika konten terjemahan yang diberikan bertentangan dengan versi bahasa Inggris aslinya, utamakan versi bahasa Inggris.
Memantau CodePipeline peristiwa
Anda dapat memantau CodePipeline peristiwa di EventBridge, yang mengirimkan aliran data real-time dari aplikasi Anda sendiri, aplikasi software-as-a-service (SaaS), dan. Layanan AWS EventBridge merutekan data tersebut ke target seperti AWS Lambda dan Amazon Simple Notification Service. Peristiwa ini sama dengan yang muncul di Amazon CloudWatch Events, yang memberikan aliran peristiwa sistem yang mendekati waktu nyata yang menggambarkan perubahan AWS sumber daya. Untuk informasi selengkapnya, lihat Apa itu Amazon EventBridge? di Panduan EventBridge Pengguna Amazon.
catatan
Amazon EventBridge adalah cara yang lebih disukai untuk mengelola acara Anda. Amazon CloudWatch Events dan EventBridge merupakan layanan dasar yang sama danAPI, tetapi EventBridge menyediakan lebih banyak fitur. Perubahan yang Anda buat di CloudWatch Acara atau EventBridge akan muncul di setiap konsol.
Acara terdiri dari aturan. Aturan dikonfigurasi dengan memilih yang berikut:
-
Pola Acara. Setiap aturan dinyatakan sebagai pola peristiwa dengan sumber dan jenis peristiwa untuk memantau, dan target acara. Untuk memantau peristiwa, Anda membuat aturan dengan layanan yang Anda pantau sebagai sumber acara, seperti CodePipeline. Misalnya, Anda dapat membuat aturan dengan pola peristiwa yang digunakan CodePipeline sebagai sumber peristiwa untuk memicu aturan ketika ada perubahan dalam status pipeline, tahapan, atau tindakan.
-
Target. Aturan baru menerima layanan yang dipilih sebagai target acara. Anda mungkin ingin menyiapkan layanan target untuk mengirim pemberitahuan, menangkap informasi status, mengambil tindakan korektif, memulai peristiwa, atau mengambil tindakan lain. Ketika Anda menambahkan target Anda, Anda juga harus memberikan izin EventBridge untuk mengizinkannya memanggil layanan target yang dipilih.
Setiap jenis peristiwa perubahan status eksekusi memancarkan pemberitahuan dengan konten pesan tertentu, di mana:
-
version
Entri awal menunjukkan nomor versi untuk acara tersebut. -
version
Entri di bawah pipelinedetail
menunjukkan nomor versi struktur pipa. -
execution-id
Entri di bawah pipelinedetail
menunjukkan ID eksekusi untuk eksekusi pipeline yang menyebabkan perubahan status. Lihat GetPipelineExecution API panggilan di AWS CodePipeline APIReferensi. -
pipeline-execution-attempt
Entri menunjukkan jumlah upaya, atau percobaan ulang, untuk ID eksekusi tertentu.
CodePipeline melaporkan suatu peristiwa EventBridge kapan pun keadaan sumber daya dalam Akun AWS perubahan Anda. Acara dipancarkan dengan jaminan, at-least-once berdasarkan sumber daya berikut:
-
Eksekusi pipa
-
Eksekusi panggung
-
Eksekusi aksi
Peristiwa dipancarkan EventBridge dengan pola acara dan skema yang dirinci di atas. Untuk acara yang diproses, seperti peristiwa yang Anda terima melalui notifikasi yang telah dikonfigurasi di konsol Alat Pengembang, pesan acara menyertakan bidang pola peristiwa dengan beberapa variasi. Misalnya, detail-type
bidang dikonversi kedetailType
. Untuk informasi lebih lanjut, lihat PutEvents API panggilan di EventBridge APIReferensi Amazon.
Contoh berikut menunjukkan acara untuk CodePipeline. Jika memungkinkan, setiap contoh menunjukkan skema untuk peristiwa yang dipancarkan bersama dengan skema untuk acara yang diproses.
Topik
Jenis detail
Saat mengatur acara untuk dipantau, Anda dapat memilih jenis detail untuk acara tersebut.
Anda dapat mengonfigurasi notifikasi yang akan dikirim saat status berubah untuk:
-
Pipa tertentu atau semua saluran pipa Anda. Anda mengontrol ini dengan menggunakan
"detail-type":
"CodePipeline Pipeline Execution State Change"
. -
Tahapan yang ditentukan atau semua tahapan Anda, dalam pipa tertentu atau semua saluran pipa Anda. Anda mengontrol ini dengan menggunakan
"detail-type":
"CodePipeline Stage Execution State Change"
. -
Tindakan tertentu atau semua tindakan, dalam tahap tertentu atau semua tahapan, dalam pipa tertentu atau semua saluran pipa Anda. Anda mengontrol ini dengan menggunakan
"detail-type":
"CodePipeline Action Execution State Change"
.
catatan
Peristiwa yang dipancarkan oleh EventBridge berisi detail-type
parameter, yang dikonversi ke detailType
saat peristiwa diproses.
Jenis detail | Status | Deskripsi |
---|---|---|
CodePipeline Perubahan Status Eksekusi Pipeline | CANCELED | Eksekusi pipa dibatalkan karena struktur pipa diperbarui. |
FAILED | Eksekusi pipeline tidak berhasil diselesaikan. | |
RESUMED | Eksekusi pipeline yang gagal telah dicoba ulang sebagai tanggapan atas RetryStageExecution API panggilan tersebut. |
|
STARTED | Eksekusi pipeline saat ini sedang berjalan. | |
STOPPED | Proses penghentian selesai, dan eksekusi pipa dihentikan. | |
STOPPING | Eksekusi pipeline berhenti karena permintaan untuk berhenti dan menunggu atau menghentikan dan meninggalkan eksekusi pipa. | |
SUCCEEDED | Eksekusi pipa selesai dengan sukses. | |
SUPERSEDED |
Sementara eksekusi pipeline ini menunggu tahap berikutnya selesai, eksekusi pipeline yang lebih baru maju dan dilanjutkan melalui pipeline sebagai gantinya. |
|
CodePipeline Perubahan Status Eksekusi Tahap | CANCELED | Panggung dibatalkan karena struktur pipa diperbarui. |
FAILED | Panggung tidak selesai dengan sukses. | |
RESUMED | Tahap yang gagal telah dicoba ulang sebagai tanggapan atas RetryStageExecution API panggilan tersebut. |
|
STARTED | Panggung sedang berjalan. | |
STOPPED | Proses penghentian selesai, dan eksekusi panggung dihentikan. | |
STOPPING | Eksekusi tahap berhenti karena permintaan untuk berhenti dan menunggu atau berhenti dan meninggalkan eksekusi pipa. | |
SUCCEEDED | Panggung selesai dengan sukses. | |
CodePipeline Perubahan Status Eksekusi Tindakan | ABANDONED | Tindakan ini ditinggalkan karena permintaan untuk menghentikan dan meninggalkan eksekusi pipa. |
CANCELED | Tindakan dibatalkan karena struktur pipa diperbarui. | |
FAILED | Untuk tindakan persetujuan, FAILED status berarti tindakan ditolak oleh pengulas atau gagal karena konfigurasi tindakan yang salah. | |
STARTED | Tindakan sedang berjalan. | |
SUCCEEDED | Tindakan itu selesai dengan sukses. |
Peristiwa tingkat saluran pipa
Peristiwa tingkat pipeline dipancarkan ketika ada perubahan status untuk eksekusi pipeline.
Topik
STARTEDAcara pipa
Ketika eksekusi pipeline dimulai, ia memancarkan peristiwa yang mengirimkan pemberitahuan dengan konten berikut. Contoh ini untuk pipa yang dinamai "myPipeline"
di us-east-1
Wilayah. id
Bidang mewakili ID peristiwa, dan account
bidang mewakili ID akun tempat pipeline dibuat.
STOPPINGAcara pipa
Ketika eksekusi pipeline berhenti, ia memancarkan peristiwa yang mengirimkan pemberitahuan dengan konten berikut. Contoh ini untuk pipa yang dinamai myPipeline
di us-west-2
Wilayah.
{ "version": "0", "id": "01234567-EXAMPLE", "detail-type": "CodePipeline Pipeline Execution State Change", "source": "aws.codepipeline", "account": "123456789012", "time": "2020-01-24T22:02:20Z", "region": "us-west-2", "resources": [ "arn:aws:codepipeline:us-west-2:123456789012:myPipeline" ], "detail": { "pipeline": "myPipeline", "execution-id": "12345678-1234-5678-abcd-12345678abcd", "start-time": "2023-10-26T13:49:39.208Z", "state": "STOPPING", "version": 3.0, "pipeline-execution-attempt": 1.0 "stop-execution-comments": "Stopping the pipeline for an update" } }
SUCCEEDEDAcara pipa
Ketika eksekusi pipeline berhasil, ia memancarkan peristiwa yang mengirimkan pemberitahuan dengan konten berikut. Contoh ini untuk pipa yang dinamai myPipeline
di us-east-1
Wilayah.
Pipeline SUCCEEDED (contoh dengan tag Git)
Ketika eksekusi pipeline memiliki tahap yang telah dicoba ulang dan berhasil, ia memancarkan peristiwa yang mengirimkan pemberitahuan dengan konten berikut. Contoh ini adalah untuk pipeline bernama myPipeline
di eu-central-1
Wilayah di mana execution-trigger
dikonfigurasi untuk tag Git.
catatan
execution-trigger
Bidang akan memiliki salah satu tag-name
ataubranch-name
, tergantung pada jenis peristiwa yang memicu pipeline.
{ "version": "0", "id": "b128b002-09fd-4574-4eba-27152726c777", "detail-type": "CodePipeline Pipeline Execution State Change", "source": "aws.codepipeline", "account": "123456789012", "time": "2023-10-26T13:50:53Z", "region": "eu-central-1", "resources": [ "arn:aws:codepipeline:eu-central-1:123456789012:BuildFromTag" ], "detail": { "pipeline": "BuildFromTag", "execution-id": "e17b5773-cc0d-4db2-9ad7-594c73888de8", "start-time": "2023-10-26T13:49:39.208Z", "execution-trigger": { "author-display-name": "Mary Major", "full-repository-name": "mmajor/sample-project", "provider-type": "GitLab", "author-email": "email_address", "commit-message": "Update file README.md", "author-date": "2023-08-16T21:08:08Z", "tag-name": "gitlab-v4.2.1", "commit-id": "
commit_ID
", "connection-arn": "arn:aws:codestar-connections:eu-central-1:123456789012:connection/0f5b706a-1a1d-46c5-86b6-f177321bcfb2", "author-id": "Mary Major" }, "state": "SUCCEEDED", "version": 32.0, "pipeline-execution-attempt": 1.0 } }
FAILEDAcara pipa
Ketika eksekusi pipeline gagal, ia memancarkan peristiwa yang mengirimkan pemberitahuan dengan konten berikut. Contoh ini untuk pipa yang dinamai "myPipeline"
di us-west-2
Wilayah.
Pipeline FAILED (contoh dengan tag Git)
Kecuali gagal pada tahap sumber, untuk konfigurasi pipeline dengan pemicu, ia memancarkan peristiwa yang mengirimkan pemberitahuan dengan konten berikut. Contoh ini adalah untuk pipeline bernama myPipeline
di eu-central-1
Wilayah di mana execution-trigger
dikonfigurasi untuk tag Git.
catatan
execution-trigger
Bidang akan memiliki salah satu tag-name
ataubranch-name
, tergantung pada jenis peristiwa yang memicu pipeline.
Acara tingkat panggung
Peristiwa tingkat tahap dipancarkan ketika ada perubahan status untuk eksekusi tahap.
Topik
STARTEDAcara panggung
Ketika eksekusi tahap dimulai, ia memancarkan peristiwa yang mengirimkan pemberitahuan dengan konten berikut. Contoh ini untuk pipa yang disebutkan "myPipeline"
di us-east-1
Wilayah, untuk panggungProd
.
STOPPINGAcara panggung
Ketika eksekusi panggung berhenti, ia memancarkan peristiwa yang mengirimkan pemberitahuan dengan konten berikut. Contoh ini untuk pipa yang disebutkan myPipeline
di us-west-2
Wilayah, untuk panggungDeploy
.
{ "version": "0", "id": "01234567-EXAMPLE", "detail-type": "CodePipeline Stage Execution State Change", "source": "aws.codepipeline", "account": "123456789012", "time": "2020-01-24T22:02:20Z", "region": "us-west-2", "resources": [ "arn:aws:codepipeline:us-west-2:123456789012:myPipeline" ], "detail": { "pipeline": "myPipeline", "execution-id": "12345678-1234-5678-abcd-12345678abcd", "start-time": "2023-10-26T13:49:39.208Z", "stage": "Deploy", "state": "STOPPING", "version": 3.0, "pipeline-execution-attempt": 1.0 } }
STOPPEDAcara panggung
Ketika eksekusi panggung dihentikan, ia memancarkan peristiwa yang mengirimkan pemberitahuan dengan konten berikut. Contoh ini untuk pipa yang disebutkan myPipeline
di us-west-2
Wilayah, untuk panggungDeploy
.
{ "version": "0", "id": "01234567-EXAMPLE", "detail-type": "CodePipeline Stage Execution State Change", "source": "aws.codepipeline", "account": "123456789012", "time": "2020-01-31T18:21:39Z", "region": "us-west-2", "resources": [ "arn:aws:codepipeline:us-west-2:123456789012:myPipeline" ], "detail": { "pipeline": "myPipeline", "execution-id": "12345678-1234-5678-abcd-12345678abcd", "start-time": "2023-10-26T13:49:39.208Z", "stage": "Deploy", "state": "STOPPED", "version": 3.0, "pipeline-execution-attempt": 1.0 } }
Acara coba lagi tahap RESUMED demi tahap
Ketika eksekusi panggung dilanjutkan dan memiliki tahap yang telah dicoba lagi, ia memancarkan peristiwa yang mengirimkan pemberitahuan dengan konten berikut.
Ketika sebuah panggung telah dicoba lagi, stage-last-retry-attempt-time
bidang akan ditampilkan, seperti yang ditunjukkan pada contoh. Bidang ditampilkan pada semua acara panggung jika percobaan ulang dilakukan.
catatan
stage-last-retry-attempt-time
Bidang akan hadir di semua acara tahap berikutnya setelah tahap telah dicoba lagi.
{ "version": "0", "id": "38656bcd-a798-5f92-c738-02a71be484e1", "detail-type": "CodePipeline Stage Execution State Change", "source": "aws.codepipeline", "account": "123456789012", "time": "2023-10-26T14:14:56Z", "region": "eu-central-1", "resources": [ "arn:aws:codepipeline:eu-central-1:123456789012:BuildFromTag" ], "detail": { "pipeline": "BuildFromTag", "execution-id": "05dafb6a-5a56-4951-a858-968795364846", "stage-last-retry-attempt-time": "2023-10-26T14:14:56.305Z", "stage": "Build", "state": "RESUMED", "version": 32.0, "pipeline-execution-attempt": 2.0 } }
Acara tingkat aksi
Peristiwa tingkat aksi dipancarkan ketika ada perubahan status untuk eksekusi tindakan.
STARTEDAcara aksi
Ketika eksekusi tindakan dimulai, ia memancarkan peristiwa yang mengirimkan pemberitahuan dengan konten berikut. Contoh ini untuk pipeline yang dinamai myPipeline
di us-east-1
Wilayah, untuk tindakan myAction
penerapan.
SUCCEEDEDAcara aksi
Ketika eksekusi tindakan berhasil, ia memancarkan peristiwa yang mengirimkan pemberitahuan dengan konten berikut. Contoh ini untuk pipeline yang dinamai "myPipeline"
di us-west-2
Wilayah, untuk aksi sumber"Source"
. Untuk jenis acara ini, ada dua region
bidang yang berbeda. region
Bidang acara menentukan Wilayah untuk acara pipeline. region
Bidang di bawah detail
bagian menentukan Wilayah untuk tindakan.
FAILEDAcara aksi
Ketika eksekusi tindakan gagal, ia memancarkan peristiwa yang mengirimkan pemberitahuan dengan konten berikut. Contoh ini untuk pipa yang dinamai "myPipeline"
di us-west-2
Wilayah, untuk tindakan"Deploy"
.
ABANDONEDAcara aksi
Ketika eksekusi tindakan ditinggalkan, ia memancarkan peristiwa yang mengirimkan pemberitahuan dengan konten berikut. Contoh ini untuk pipa yang dinamai "myPipeline"
di us-west-2
Wilayah, untuk tindakan"Deploy"
.
{ "version": "0", "id": "01234567-EXAMPLE", "detail-type": "CodePipeline Action Execution State Change", "source": "aws.codepipeline", "account": "123456789012", "time": "2020-01-31T18:21:39Z", "region": "us-west-2", "resources": [ "arn:aws:codepipeline:us-west-2:123456789012:myPipeline" ], "detail": { "pipeline": "myPipeline", "execution-id": "12345678-1234-5678-abcd-12345678abcd", "stage": "Deploy", "action-execution-id": "47f821c5-a902-44b2-ae61-b878d31ecd21", "action": "Deploy", "state": "ABANDONED", "region": "us-west-2", "type": { "owner": "AWS", "provider": "CodeDeploy", "category": "Deploy", "version": "1" }, "version": 3.0, "pipeline-execution-attempt": 1.0 } }
Buat Aturan yang Mengirim Pemberitahuan pada Acara Pipeline
Aturan mengawasi peristiwa tertentu dan kemudian mengarahkannya ke AWS target yang Anda pilih. Anda dapat membuat aturan yang melakukan AWS tindakan secara otomatis ketika AWS tindakan lain terjadi, atau aturan yang melakukan AWS tindakan secara teratur pada jadwal yang ditetapkan.
Topik
Mengirim Pemberitahuan Saat Status Pipeline Berubah (Konsol)
Langkah-langkah ini menunjukkan cara menggunakan EventBridge konsol untuk membuat aturan untuk mengirim pemberitahuan perubahan CodePipeline.
Untuk membuat EventBridge aturan yang menargetkan pipeline Anda dengan sumber Amazon S3
Buka EventBridge konsol Amazon di https://console.aws.amazon.com/events/
. -
Di panel navigasi, pilih Aturan. Biarkan bus default dipilih atau pilih bus acara. Pilih Buat aturan.
-
Di Nama, masukkan nama untuk aturan Anda.
-
Di bawah Jenis aturan, pilih Aturan dengan pola acara. Pilih Berikutnya.
-
Di bawah Pola acara, pilih AWS layanan.
-
Dari daftar drop-down Jenis Acara, pilih tingkat perubahan status untuk notifikasi.
-
Untuk aturan yang berlaku untuk peristiwa tingkat pipeline, pilih Perubahan Status Eksekusi CodePipeline Pipeline.
-
Untuk aturan yang berlaku untuk peristiwa tingkat tahap, pilih Perubahan Status Eksekusi CodePipeline Tahap.
-
Untuk aturan yang berlaku untuk peristiwa tingkat tindakan, pilih Perubahan Status Eksekusi CodePipeline Tindakan.
-
-
Tentukan perubahan status yang berlaku untuk aturan:
-
Untuk aturan yang berlaku untuk semua perubahan status, pilih Status apa pun.
-
Untuk aturan yang berlaku untuk beberapa perubahan status saja, pilih Status spesifik, lalu pilih satu atau beberapa nilai status dari daftar.
-
-
Untuk pola acara yang lebih detail daripada yang diizinkan oleh penyeleksi, Anda juga dapat menggunakan opsi Edit pola di jendela Pola acara untuk menunjuk pola peristiwa dalam JSON format.
catatan
Jika tidak ditentukan lain, maka pola acara dibuat untuk semua pipelines/stages/actions dan status.
Untuk pola acara yang lebih rinci, Anda dapat menyalin dan menempelkan contoh pola peristiwa berikut ke dalam jendela pola Peristiwa.
-
Gunakan contoh pola peristiwa ini untuk menangkap tindakan penerapan dan pembuatan yang gagal di semua pipeline.
{ "source": [ "aws.codepipeline" ], "detail-type": [ "CodePipeline Action Execution State Change" ], "detail": { "state": [ "FAILED" ], "type": { "category": ["Deploy", "Build"] } } }
-
Gunakan contoh pola peristiwa ini untuk menangkap semua tindakan persetujuan yang ditolak atau gagal di semua pipeline.
{ "source": [ "aws.codepipeline" ], "detail-type": [ "CodePipeline Action Execution State Change" ], "detail": { "state": [ "FAILED" ], "type": { "category": ["Approval"] } } }
-
Gunakan contoh pola peristiwa ini untuk menangkap semua peristiwa dari pipeline yang ditentukan.
{ "source": [ "aws.codepipeline" ], "detail-type": [ "CodePipeline Pipeline Execution State Change", "CodePipeline Action Execution State Change", "CodePipeline Stage Execution State Change" ], "detail": { "pipeline": ["myPipeline", "my2ndPipeline"] } }
-
-
Pilih Berikutnya.
-
Di jenis Target, pilih AWS layanan.
-
Di Pilih target, pilih CodePipeline. Di Pipeline ARN, masukkan pipa ARN untuk pipa yang akan dimulai dengan aturan ini.
catatan
Untuk mendapatkan pipelineARN, jalankan get-pipeline perintah. Pipa ARN muncul di output. Itu dibangun dalam format ini:
arn:aws:codepipeline:
region
:account
:pipeline-name
Contoh pipaARN:
arn:aws:codepipeline:us-east- 2:80398: EXAMPLE MyFirstPipeline
-
Untuk membuat atau menentukan peran IAM layanan yang memberikan EventBridge izin untuk memanggil target yang terkait dengan EventBridge aturan Anda (dalam hal ini, targetnya adalah): CodePipeline
-
Pilih Buat peran baru untuk sumber daya khusus ini untuk membuat peran layanan yang memberikan EventBridge izin untuk memulai eksekusi pipeline Anda.
-
Pilih Gunakan peran yang ada untuk memasukkan peran layanan yang memberikan EventBridge izin untuk memulai eksekusi pipeline Anda.
-
-
Pilih Berikutnya.
-
Pada halaman Tag, pilih Berikutnya.
-
Pada halaman Tinjau dan buat, tinjau konfigurasi aturan. Jika Anda puas dengan aturan, pilih Create rule (Buat aturan).
Kirim Pemberitahuan Saat Status Pipeline Berubah (CLI)
Langkah-langkah ini menunjukkan cara menggunakan aturan CLI untuk membuat CloudWatch Peristiwa untuk mengirim pemberitahuan perubahan CodePipeline.
Untuk menggunakan aturan AWS CLI untuk membuat aturan, panggil put-rule perintah, dengan menentukan:
-
Nama yang secara unik mengidentifikasi aturan yang Anda buat. Nama ini harus unik di semua pipeline yang Anda buat CodePipeline terkait dengan AWS akun Anda.
-
Pola acara untuk bidang sumber dan detail yang digunakan oleh aturan. Untuk informasi selengkapnya, lihat Amazon EventBridge dan Pola Acara.
Untuk membuat EventBridge aturan dengan CodePipeline sebagai sumber acara
-
Panggil put-rule perintah untuk membuat aturan yang menentukan pola acara. (Lihat tabel sebelumnya untuk status valid.)
Contoh perintah berikut digunakan --event-pattern untuk membuat aturan yang disebut
“MyPipelineStateChanges”
yang memancarkan CloudWatch peristiwa ketika eksekusi pipeline gagal untuk pipeline bernama "myPipeline.”aws events put-rule --name "MyPipelineStateChanges" --event-pattern "{\"source\":[\"aws.codepipeline\"],\"detail-type\":[\"CodePipeline Pipeline Execution State Change\"],\"detail\":{\"pipeline\":[\"myPipeline\"],\"state\":[\"FAILED\"]}}"
-
Panggil put-targets perintah dan sertakan parameter berikut:
-
--rule
Parameter digunakan dengan yangrule_name
Anda buat dengan menggunakanput-rule. -
--targets
Parameter digunakan denganId
daftar target dalam daftar target dan SNS topik Amazon.ARN
Contoh perintah berikut menentukan bahwa untuk aturan yang dipanggil
MyPipelineStateChanges
, targetId
terdiri dari nomor satu, menunjukkan bahwa dalam daftar target untuk aturan, ini adalah target 1. Perintah sample juga menentukan contohARN
untuk SNS topik Amazon.aws events put-targets --rule MyPipelineStateChanges --targets Id=1,Arn=arn:aws:sns:us-west-2:11111EXAMPLE:MyNotificationTopic
-
-
Tambahkan izin EventBridge untuk menggunakan layanan target yang ditunjuk untuk memanggil notifikasi. Untuk informasi selengkapnya, lihat Menggunakan kebijakan berbasis sumber daya untuk Amazon. EventBridge