Dokumen ini memberikan ringkasan tentang langganan push, alur kerjanya, dan properti terkait.
Dalam pengiriman push, Pub/Sub memulai permintaan ke aplikasi pelanggan Anda untuk mengirim pesan. Pesan dikirim ke server atau webhook yang dapat dialamatkan secara publik, seperti permintaan POST HTTPS.
Langganan push meminimalkan dependensi pada library klien khusus Pub/Sub dan mekanisme autentikasi. Alat ini juga berfungsi baik dengan teknologi layanan serverless dan penskalaan otomatis, seperti fungsi Cloud Run, Cloud Run, dan Google Kubernetes Engine.
Sebelum memulai
Sebelum membaca dokumen ini, pastikan Anda memahami hal-hal berikut:
Cara kerja Pub/Sub dan berbagai istilah Pub/Sub.
Berbagai jenis langganan yang didukung Pub/Sub dan alasan Anda mungkin ingin menggunakan langganan push.
Alur kerja langganan push
Dalam langganan push, server Pub/Sub memulai permintaan ke klien pelanggan Anda untuk mengirim pesan.
Gambar berikut menunjukkan alur kerja antara klien pelanggan dan langganan push.
Berikut adalah deskripsi singkat alur kerja yang mereferensikan Gambar 3:
- Server Pub/Sub mengirimkan setiap pesan sebagai permintaan HTTPS ke
klien pelanggan di endpoint yang telah dikonfigurasi sebelumnya. Permintaan ini ditampilkan sebagai
PushRequest
dalam gambar. - Endpoint mengonfirmasi pesan dengan menampilkan kode status keberhasilan HTTP. Respons yang tidak berhasil menunjukkan bahwa Pub/Sub harus mengirim ulang pesan. Respons ini ditampilkan sebagai
PushResponse
dalam gambar. - Pub/Sub secara dinamis menyesuaikan kecepatan permintaan push berdasarkan kecepatan penerimaan respons berhasil.
Properti langganan push
Properti yang Anda konfigurasikan untuk langganan push menentukan cara Anda menulis pesan ke langganan. Untuk mengetahui informasi selengkapnya, lihat properti langganan.
Cara endpoint push menerima pesan
Saat Pub/Sub mengirimkan pesan ke endpoint push, Anda dapat memilih untuk mengirimnya dalam bentuk gabungan atau tidak digabungkan. Secara default, pesan dikirim dalam bentuk gabungan.
- Dibungkus. Pub/Sub mengirim pesan dalam isi JSON permintaan
POST
. - Dibuka. Pub/Sub mengirim data pesan mentah langsung sebagai isi HTTP.
Contoh berikut menunjukkan isi yang digabungkan dari permintaan POST
JSON ke endpoint push yang berisi string Hello there
di kolom message.data
Isi permintaan POST adalah objek JSON. Data pesan berada di
kolom message.data
dan dienkode dengan base64.
Contoh permintaan dengan nilai minimum
{ "message": { "data": "SGVsbG8gQ2xvdWQgUHViL1N1YiEgSGVyZSBpcyBteSBtZXNzYWdlIQ==", "messageId": "2070443601311540", "message_id": "2070443601311540", "publishTime": "2021-02-26T19:13:55.749Z", "publish_time": "2021-02-26T19:13:55.749Z" }, "subscription": "projects/myproject/subscriptions/mysubscription" }
Contoh permintaan dengan nilai maksimum
Perhatikan bahwa contoh ini menunjukkan nilai maksimum saat ini, yang mungkin berubah dari waktu ke waktu. Selain itu, peta atribut dapat berisi berbagai nilai.
{ "deliveryAttempt": 5, "message": { "attributes": { "key": "value" }, "data": "SGVsbG8gQ2xvdWQgUHViL1N1YiEgSGVyZSBpcyBteSBtZXNzYWdlIQ==", "messageId": "2070443601311540", "message_id": "2070443601311540", "orderingKey": "key", "publishTime": "2021-02-26T19:13:55.749Z", "publish_time": "2021-02-26T19:13:55.749Z" }, "subscription": "projects/myproject/subscriptions/mysubscription" }
Untuk menerima pesan dari langganan push, gunakan webhook dan proses permintaan POST
yang dikirim Pub/Sub ke endpoint push. Untuk mengetahui informasi selengkapnya tentang cara memproses permintaan POST
ini di App Engine, lihat Menulis dan merespons pesan Pub/Sub.
Setelah Anda menerima permintaan push, tampilkan kode status HTTP. Untuk mengonfirmasi pesan, tampilkan salah satu kode status berikut:
102
200
201
202
204
Untuk mengirim konfirmasi negatif untuk pesan, tampilkan kode status lain. Jika Anda mengirim konfirmasi negatif atau batas waktu konfirmasi berakhir, Pub/Sub akan mengirim ulang pesan. Anda tidak dapat mengubah batas waktu konfirmasi setiap pesan yang Anda terima dari langganan push.
Autentikasi untuk langganan push
Jika langganan push menggunakan autentikasi, layanan Pub/Sub akan menandatangani JWT dan mengirim JWT dalam header otorisasi permintaan push.
Untuk mengetahui informasi selengkapnya tentang cara menyiapkan autentikasi, lihat Melakukan autentikasi permintaan push.
Menghentikan dan melanjutkan pengiriman pesan
Untuk menghentikan sementara Pub/Sub agar tidak mengirim permintaan ke endpoint push, ubah langganan menjadi pull. Diperlukan waktu beberapa menit hingga perubahan diterapkan.
Untuk melanjutkan pengiriman push, tetapkan URL ke endpoint yang valid lagi. Untuk menghentikan pengiriman secara permanen, hapus langganan.
Backoff push
Jika pelanggan push mengirim terlalu banyak konfirmasi negatif, Pub/Sub mungkin mulai mengirimkan pesan menggunakan penundaan push. Saat menggunakan push backoff, Pub/Sub akan berhenti mengirimkan pesan selama jangka waktu yang telah ditentukan. Rentang waktu ini dapat berkisar antara 100 milidetik hingga 60 detik. Setelah waktu berlalu, Pub/Sub akan mulai mengirimkan pesan lagi.
Backoff push menggunakan algoritma backoff eksponensial untuk menentukan penundaan yang digunakan Pub/Sub di antara pengiriman pesan. Jumlah waktu ini dihitung berdasarkan jumlah konfirmasi negatif yang dikirim oleh subscriber push.
Misalnya, jika subscriber push menerima lima pesan per detik dan mengirim satu konfirmasi negatif per detik, Pub/Sub akan mengirimkan pesan kira-kira setiap 500 milidetik. Atau, jika pelanggan push mengirim lima konfirmasi negatif per detik, Pub/Sub akan mengirimkan pesan setiap 30 hingga 60 detik.
Perhatikan pertimbangan berikut tentang push backoff:
- Penundaan push tidak dapat diaktifkan atau dinonaktifkan. Anda juga tidak dapat mengubah nilai yang digunakan untuk menghitung penundaan.
- Mendorong pemicu backoff pada tindakan berikut:
- Saat konfirmasi negatif diterima.
- Saat batas waktu konfirmasi pesan berakhir.
- Penundaan push berlaku untuk semua pesan dalam langganan (global).
Rasio penayangan
Pub/Sub menyesuaikan jumlah permintaan push serentak menggunakan algoritma awal lambat. Jumlah maksimum permintaan push serentak yang diizinkan adalah periode push. Periode push akan bertambah jika pengiriman berhasil dan menurun jika pengiriman gagal. Sistem dimulai dengan ukuran jendela satu digit kecil.
Saat pelanggan mengonfirmasi pesan, periodenya akan meningkat secara eksponensial. Untuk langganan yang pelanggannya mengonfirmasi lebih dari 99% pesan dan rata-rata latensi permintaan push kurang dari satu detik, periode push harus diperluas cukup untuk mengimbangi throughput publikasi.
Latensi permintaan push mencakup hal berikut:
Latensi jaringan bolak-balik antara server Pub/Sub dan endpoint push
Waktu pemrosesan pelanggan
Setelah 3.000 pesan yang belum terkirim per region, periode akan meningkat secara linear untuk mencegah endpoint push menerima terlalu banyak pesan. Jika latensi rata-rata melebihi satu detik atau subscriber mengonfirmasi kurang dari 99% permintaan, periode akan berkurang hingga batas bawah 3.000 pesan yang belum terkirim.
Untuk informasi selengkapnya tentang metrik yang dapat Anda gunakan untuk memantau pengiriman push, lihat Memantau langganan push.
Kuota dan batas
Langganan push tunduk pada kumpulan kuota dan batas resource.
Langkah selanjutnya
Buat langganan push untuk topik Anda.
Buat atau ubah langganan dengan gcloud CLI.
Buat atau ubah langganan dengan REST API.
Buat atau ubah langganan dengan RPC API.