Berlangganan event Cloud Assistant untuk membangun alur respons O&M otomatis. Misalnya, Anda dapat langsung menerima peringatan ketika tugas otomatis—seperti menginstal perangkat lunak atau menjalankan skrip inspeksi—gagal. Pendekatan ini menggantikan polling manual yang mahal dan berlatensi tinggi.
Prosedur
Prosedur berikut menggunakan langganan ke event status tugas Cloud Assistant sebagai contoh. Untuk informasi selengkapnya, lihat Deskripsi event Cloud Assistant.
Gunakan EventBridge untuk berlangganan event Cloud Assistant
Sebelum memulai, pastikan Anda telah mengaktifkan EventBridge dan memberikan izin yang diperlukan.
Masuk ke Konsol EventBridge. Di panel navigasi sebelah kiri, klik Event Buses.
Di bilah menu atas, pilih wilayah.
Pada halaman Event Buses, klik default.
Pada halaman EventBridge, klik Event Rules di panel navigasi sebelah kiri, lalu klik Create Rule.
Pada tab Configure Basic Info, masukkan nama di kotak teks Name dan deskripsi di kotak teks Description. Lalu, klik Next.
Pada tab Configure Event Pattern, konfigurasikan parameter berikut lalu klik Next.
Dari daftar drop-down Event Source, pilih acs.ecs.
Dari daftar drop-down Event Type, pilih jenis event Cloud Assistant yang ingin Anda langgani.
Event status tugas Cloud Assistant:
ecs:CloudAssistant:TaskCompleted.Pada bagian Event Pattern Debugging, lihat contoh jenis event yang dilanggani.
{ "id": "45ef4dewdwe1-7c35-447a-bd93-fab****", "source": "acs.ecs", "specversion": "1.0", "subject": "acs.ecs:cn-hangzhou:123456789098****:215672", "time": "2020-11-19T21:04:41+08:00", "type": "ecs:CloudAssistant:TaskCompleted", "aliyunaccountid": "123456789098****", "aliyunpublishtime": "2020-11-19T21:04:42Z", "aliyuneventbusname": "default", "aliyunregionid": "cn-hangzhou", "aliyunpublishaddr": "172.25.XX.XX", "data": { "commandId": "c-hz045**********", "commandName": "hello-linux.sh", "exitCode": "0", "finishTime": "2023-12-14T07:39:48Z", "instanceId": "i-bp114***************", "invocationStatus": "Success", "invokeId": "t-hz045**********", "ownerId": "158*************", "playerUid": "256***************", "repeatMode": "Once", "repeats": "1", "startTime": "2023-12-14T07:39:48Z", "errorCode": "0", "errorDesc": "" } }Di bawah contoh tersebut, klik Test untuk mensimulasikan pemicu event. Jika muncul pesan Match Succeeded. The event can be triggered., artinya event telah dikonfigurasi untuk dipicu sesuai harapan.
Konfigurasikan target event. Pilih Service Type dan konfigurasikan skenario dorong.
Untuk informasi selengkapnya, lihat Setel skenario dorong.
Gunakan Cloud Monitor untuk berlangganan event Cloud Assistant
Masuk ke Konsol Cloud Monitor.
Di panel navigasi sebelah kiri, pilih .
Pada tab Subscription Policy, klik Create Subscription Policy.
Pada halaman Create Subscription Policy, konfigurasikan parameter untuk berlangganan event Cloud Assistant.
Contoh ini hanya menampilkan parameter yang terkait dengan event Cloud Assistant. Untuk informasi selengkapnya, lihat Parameter kebijakan langganan.
Subscription Type: Pilih System Event.
Subscription Scope:
Product: Pilih Elastic Compute Service (ECS).
Event Type: Pilih Notification.
Event Name: Pilih Cloud Assistant task status event.
Setelah konfigurasi selesai, klik Submit.
Saat event terkait dipicu, Anda akan menerima notifikasi. Anda juga dapat memanggil operasi DescribeSystemEventAttribute untuk mengkueri detail event sistem.
Deskripsi event Cloud Assistant
Event status tugas Cloud Assistant
Deskripsi event
Perintah dan skrip memerlukan waktu untuk dijalankan. Event status tugas Cloud Assistant membantu Anda melacak penyelesaian tugas. Anda dapat menggunakan event ini untuk tujuan berikut:
Menerima notifikasi saat tugas Cloud Assistant gagal atau selesai. Anda dapat menggunakan notifikasi tersebut untuk peringatan atau operasi lanjutan.
Polling menghabiskan kuota panggilan API Anda. Untuk menghindarinya, Anda dapat menggunakan langganan event.
Mencegah gangguan akibat rilis aplikasi, yang dapat terjadi selama proses polling panjang. Penggunaan event menyederhanakan alur kerja Anda.
Kondisi pemicu dan batasan
Kondisi pemicu: Saat Anda memanggil operasi RunCommand atau InvokeCommand untuk menjalankan tugas, Cloud Assistant memantau status tugas tersebut. Cloud Assistant mengirimkan event status tugas saat tugas selesai.
Batasan:
Event status tugas Cloud Assistant hanya dikirim saat tugas pada instans ECS memasuki salah satu status akhir berikut (InvocationStatus):
Aborted: Tugas gagal dikirim.
Success: Tugas berhasil.
Failed: Tugas gagal.
Invalid: Konten tugas tidak valid.
Timeout: Tugas melebihi batas waktu.
Cancelled: Tugas dibatalkan.
Terminated: Tugas dihentikan.
Operasi DescribeInvocations dan DescribeInvocationResults mengembalikan data dalam format
array<object>. Namun, event status tugas hanya melaporkan status satu tugas pada satu instans, bukan beberapa tugas sekaligus.
Field event
Field | Description | Example |
instanceId | ID instans. | i-bp114*************** |
invokeId | ID eksekusi perintah. | t-hz045********** |
commandId | ID perintah. | c-hz045********** |
commandName | Nama perintah. | ACS-ECS-ResetPassword-for-linux.sh |
ownerUid | Akun pemilik instans tempat perintah dijalankan. | 158************* |
playerUid | ID akun yang mengasumsikan role untuk menjalankan perintah. | 256*************** |
repeatMode | Mode eksekusi perintah. Parameter ini diabaikan jika `InstanceId` juga ditentukan. Nilai yang valid:
| Once |
repeats | Jumlah kali perintah telah dijalankan pada instans.
| 0 |
invocationStatus | Status eksekusi perintah.
| Success |
exitCode | Exit code dari proses perintah. | 0 |
startTime | Waktu mulai tugas. | 2023-12-20T06:15:55Z |
finishTime | Waktu akhir tugas. | 2023-12-20T06:15:59Z |
errorCode | Kode kesalahan yang dikembalikan jika perintah gagal dikirim atau dijalankan. | 0 |
errorDesc | Detail kegagalan pengiriman atau eksekusi perintah. | - |
Event heartbeat pertama Cloud Assistant
Deskripsi event
Heartbeat Cloud Assistant merupakan salah satu cara untuk menentukan status sistem operasi instans. Heartbeat pertama menunjukkan kapan sistem operasi telah dimulai. Anda dapat menggunakan informasi ini untuk memeriksa kesehatan instans atau menentukan kapan harus mengirim perintah Cloud Assistant.
Menggunakan event heartbeat pertama alih-alih melakukan polling operasi DescribeCloudAssistantStatus menyelesaikan permasalahan berikut:
Mem-polling DescribeCloudAssistantStatus untuk memeriksa apakah status telah berubah menjadi `true` bersifat kompleks. Interval polling yang tidak tepat dapat menghasilkan terlalu banyak permintaan, sehingga memicu pembatasan kecepatan atau memberi beban pada sistem.
Waktu startup sistem operasi instans dapat sangat bervariasi. Beberapa instans Windows dapat membutuhkan waktu hingga 5 menit untuk memulai, sehingga sulit mengontrol durasi total polling.
Status yang dikembalikan oleh DescribeCloudAssistantStatus dapat mengalami keterlambatan. Terdapat jeda 2 menit antara saat heartbeat berhenti dan saat status berubah. Hal ini menyulitkan DescribeCloudAssistantStatus dalam mendeteksi restart instans.
Kondisi pemicu dan batasan
Kondisi pemicu: Saat Cloud Assistant melaporkan heartbeat, Cloud Assistant mengirimkan event heartbeat pertama jika mendeteksi bahwa ini adalah heartbeat pertama setelah client Cloud Assistant dimulai.
Batasan versi Cloud Assistant:
Instans Windows: Versi Cloud Assistant Agent harus lebih baru dari 1.0.0.149.
Instans Linux: Versi Cloud Assistant Agent harus lebih baru dari 1.0.2.569.
Versi Cloud Assistant yang lebih lama tidak melaporkan heartbeat setiap menit atau tidak melaporkan bidang indeks. Akibatnya, versi tersebut tidak dapat mengidentifikasi secara akurat heartbeat pertama setelah startup. Versi lama ini tidak didukung.
Field event
Field | Description | Example |
bizEventId | ID event. | ea33c3e2-aaf0-****-****-5d49b1ecce99 |
vmName | ID instans yang terkait dengan event. | i-bp19**************** |
extensions | Informasi bisnis tambahan. | - |
azone | Zona. | cn-shenzhen-e |
region | Wilayah. | cn-shenzhen |
agentVersion | Versi Cloud Assistant Agent. | 2.2.3.529 |
uptime | Lama waktu sistem operasi telah berjalan, dalam milidetik. | 19000 |
Event hasil pengiriman output eksekusi tugas Cloud Assistant
Deskripsi event
Saat Anda menjalankan perintah, maksimal 24 KB output perintah disimpan. Output yang melebihi batas ini akan dipotong.
Jika Anda ingin mendapatkan output lengkap atau menyimpan output secara persisten, Anda dapat mengonfigurasi agar output dikirimkan ke path OSS saat eksekusi perintah mencapai status akhir.
Anda dapat menggunakan event ini untuk tujuan berikut:
Menerima notifikasi dan detail tentang pengiriman output. Saat Anda menerima notifikasi sukses, Anda dapat mengunduh file output dari Bucket OSS yang sesuai. Ini menghindari polling operasi DescribeInvocations untuk mendapatkan hasil dan meningkatkan efisiensi.
Saat pengiriman gagal, Anda dapat memperoleh alasan kegagalan secara detail dari event tersebut.
Kondisi pemicu dan batasan
Kondisi pemicu: Saat Anda menggunakan RunCommand atau InvokeCommand untuk menjalankan tugas dan menentukan parameter OssOutputDelivery yang valid, event ini dikirim saat tugas mencapai status akhir.
Batasan:
Event hanya dikirim saat tugas pada instans memasuki salah satu status akhir berikut (InvocationStatus):
Aborted: Tugas gagal dikirim.
Success: Tugas berhasil.
Failed: Tugas gagal.
Invalid: Konten tugas tidak valid.
Timeout: Tugas melebihi batas waktu.
Cancelled: Tugas dibatalkan.
Terminated: Tugas dihentikan.
Batasan versi Cloud Assistant:
Instans Windows: Versi Cloud Assistant Agent harus lebih baru dari 2.1.4.1007.
Instans Linux: Versi Cloud Assistant Agent harus lebih baru dari 2.2.4.1007.
Field event
Field | Description |
instanceId | ID instans. |
invokeId | ID eksekusi perintah. |
ownerUid | Akun pemilik instans tempat perintah dijalankan. |
playerUid | ID akun yang mengasumsikan role untuk menjalankan perintah. |
repeatMode | Mode eksekusi perintah. Nilai yang valid:
|
repeats | Jumlah kali perintah telah dijalankan pada instans.
|
ossOutputDelivery | Konfigurasi OSS untuk pengiriman output perintah. |
ossOutputUri | URI file OSS tempat output perintah dikirimkan. |
status | Status pengiriman.
|
statusCode | Kode status pengiriman. Parameter ini hanya dikembalikan saat status bernilai `Failed`. |
errorCode | Kode kesalahan kegagalan pengiriman. Parameter ini hanya dikembalikan saat status bernilai `Failed`. Nilai yang mungkin:
|
errorInfo | Detail kesalahan kegagalan pengiriman. Parameter ini hanya dikembalikan saat status bernilai `Failed`. |
Rekomendasi untuk lingkungan produksi
Idempotensi: Sistem event dapat mengirimkan event yang sama beberapa kali karena masalah jaringan atau retry. Logika pemrosesan Anda harus idempoten. Artinya, memproses event yang sama beberapa kali menghasilkan hasil yang sama seperti memprosesnya sekali. Anda dapat menggunakan
idataudata.bizEventIddari event sebagai pengenal unik. Sebelum memproses event, periksa apakah ID ini sudah pernah diproses.Retry dan dead-letter queue: Saat Anda mengonfigurasi target event EventBridge, kami sangat menyarankan agar Anda mengonfigurasi Retry Policy dan Dead-Letter Queue. Jika fungsi pemrosesan gagal sementara, EventBridge akan mencoba ulang secara otomatis. Jika upaya retry gagal, event akan dikirim ke antrian pesan gagal, seperti antrian MNS. Anda kemudian dapat menyelidiki dan memulihkan event secara manual untuk mencegah kehilangan data.
Monitoring dan alerting: Pantau fungsi pemrosesan event itu sendiri. Pantau tingkat keberhasilan eksekusi, durasi, dan log kesalahan, serta atur peringatan. Hal ini memungkinkan Anda segera melakukan intervensi jika logika pemrosesan terus-menerus gagal.
FAQ
Mengapa saya tidak menerima notifikasi event setelah berlangganan event Cloud Assistant menggunakan EventBridge?
Periksa prasyarat: Pastikan versi Cloud Assistant Agent memenuhi persyaratan.
Periksa aturan EventBridge:
Masuk ke Konsol EventBridge. Pastikan Event Pattern aturan tersebut benar. Nilai
sourceharusacs.ecs, dan nilaitypeharus jenis event yang benar.Gunakan fitur Event Pattern Debugging untuk menguji apakah aturan tersebut cocok dengan sampel JSON event nyata.
Periksa kondisi target event:
Pada halaman detail aturan event di Konsol EventBridge, lihat catatan pemanggilan dan log kesalahan target event.
Pastikan layanan target, seperti Function Compute atau webhook, berjalan normal dan dapat dijangkau melalui jaringan.