Topik impor Amazon Managed Streaming for Apache Kafka (Amazon MSK) memungkinkan Anda terus menyerap data dari Amazon MSK sebagai sumber eksternal dan ke Pub/Sub. Kemudian, Anda dapat melakukan streaming data ke salah satu tujuan yang didukung Pub/Sub.
Dokumen ini menunjukkan cara membuat dan mengelola topik impor Amazon MSK. Untuk membuat topik standar, lihat Membuat topik standar.
Untuk mengetahui informasi selengkapnya tentang topik impor, lihat Tentang topik impor.
Sebelum memulai
Ketahui lebih lanjut proses publikasi Pub/Sub.
Konfigurasikan peran dan izin yang diperlukan untuk mengelola topik impor Amazon MSK, termasuk hal berikut:
Siapkan workload identity federation sehingga Google Cloud dapat mengakses layanan streaming eksternal.
Peran dan izin yang diperlukan
Untuk mendapatkan izin yang
Anda perlukan untuk membuat dan mengelola topik impor Amazon MSK,
minta administrator untuk memberi Anda
peran IAM Pub/Sub Editor (roles/pubsub.editor
) pada topik atau project Anda.
Untuk mengetahui informasi selengkapnya tentang cara memberikan peran, lihat Mengelola akses ke project, folder, dan organisasi.
Peran bawaan ini berisi izin yang diperlukan untuk membuat dan mengelola topik impor Amazon MSK. Untuk melihat izin yang benar-benar diperlukan, luaskan bagian Izin yang diperlukan:
Izin yang diperlukan
Izin berikut diperlukan untuk membuat dan mengelola topik impor Amazon MSK:
-
Buat topik impor:
pubsub.topics.create
-
Menghapus topik impor:
pubsub.topics.delete
-
Mendapatkan topik impor:
pubsub.topics.get
-
Cantumkan topik impor:
pubsub.topics.list
-
Memublikasikan ke topik impor:
pubsub.topics.publish
-
Memperbarui topik impor:
pubsub.topics.update
-
Dapatkan kebijakan IAM untuk topik impor:
pubsub.topics.getIamPolicy
-
Konfigurasikan kebijakan IAM untuk topik impor:
pubsub.topics.setIamPolicy
Anda mungkin juga bisa mendapatkan izin ini dengan peran khusus atau peran bawaan lainnya.
Anda dapat mengonfigurasi kontrol akses di tingkat project dan tingkat resource individual.
Menyiapkan identitas gabungan untuk mengakses Amazon MSK
Workload Identity Federation memungkinkan Google Cloud layanan mengakses workload yang berjalan di luar Google Cloud. Dengan federasi identitas, Anda tidak perlu mempertahankan atau meneruskan kredensial ke Google Cloud untuk mengakses resource di cloud lain. Sebagai gantinya, Anda dapat menggunakan identitas workload itu sendiri untuk melakukan autentikasi ke Google Cloud dan mengakses resource.
Membuat akun layanan di Google Cloud
Ini langkah opsional. Jika sudah memiliki akun layanan, Anda dapat menggunakannya dalam prosedur ini, bukan membuat akun layanan baru. Jika Anda menggunakan akun layanan yang ada, buka Mencatat ID unik akun layanan untuk langkah berikutnya.
Untuk topik impor Amazon MSK, Pub/Sub menggunakan akun layanan sebagai identitas untuk mengakses resource dari AWS.
Untuk mengetahui informasi selengkapnya tentang cara membuat akun layanan, termasuk prasyarat, peran dan izin yang diperlukan, serta panduan penamaan, lihat Membuat akun layanan. Setelah membuat akun layanan, Anda mungkin perlu menunggu selama 60 detik atau lebih sebelum menggunakan akun layanan. Perilaku ini terjadi karena operasi baca pada akhirnya konsisten; perlu waktu hingga akun layanan baru terlihat.
Catat ID unik akun layanan
Anda memerlukan ID unik akun layanan untuk menyiapkan peran di konsol AWS.
Di konsol Google Cloud, buka halaman detail Service account.
Klik akun layanan yang baru saja Anda buat atau yang ingin Anda gunakan.
Dari halaman Detail akun layanan, catat nomor ID Unik.
Anda memerlukan ID ini sebagai bagian dari alur kerja untuk menyiapkan peran di konsol AWS.
Menambahkan peran pembuat token akun layanan ke akun layanan Pub/Sub
Peran pembuat token akun layanan (roles/iam.serviceAccountTokenCreator
)
memungkinkan akun utama membuat kredensial jangka pendek
untuk akun layanan. Token atau kredensial ini digunakan untuk meniru identitas akun layanan.
Untuk informasi selengkapnya tentang peniruan akun layanan, lihat Peniruan akun layanan.
Anda juga dapat menambahkan peran penayang Pub/Sub (roles/pubsub.publisher
)
selama prosedur ini. Untuk mengetahui informasi selengkapnya tentang peran dan alasan Anda menambahkannya,
lihat Menambahkan peran penayang Pub/Sub ke akun layanan Pub/Sub.
Di konsol Google Cloud, buka halaman IAM.
Klik kotak centang Sertakan pemberian peran yang disediakan Google.
Cari akun layanan yang memiliki format
service-{PROJECT_NUMBER}@gcp-sa-pubsub.iam.gserviceaccount.com
.Untuk akun layanan ini, klik tombol Edit Principal.
Jika diperlukan, klik Tambahkan peran lain.
Telusuri dan klik Peran pembuat token akun layanan (
roles/iam.serviceAccountTokenCreator
).Klik Simpan.
Membuat kebijakan di AWS
Anda memerlukan kebijakan di AWS untuk mengizinkan Pub/Sub mengautentikasi ke AWS sehingga Pub/Sub dapat menyerap data dari Amazon MSK.
- Untuk mengetahui metode dan informasi selengkapnya tentang cara membuat kebijakan di AWS, lihat Membuat kebijakan IAM.
Untuk membuat kebijakan di AWS, lakukan langkah-langkah berikut:
Login ke AWS Management Console, lalu buka konsol IAM.
Di panel navigasi konsol untuk IAM, klik Access Management > Policies.
Klik Create policy.
Untuk Klik layanan, klik MSK.
Untuk Action allowed, klik Read > GetBootstrapBrokers.
Tindakan ini memberikan izin untuk mendapatkan broker bootstrap yang digunakan Pub/Sub untuk terhubung ke cluster MSK.
Klik Tambahkan izin lainnya.
Untuk Pilih layanan, klik Apache Kafka API for MSK.
Untuk Action allowed, pilih hal berikut:
List > DescribeTopic
Tindakan ini memberikan izin untuk mengizinkan topik penyerapan Pub/Sub mendapatkan detail tentang topik Amazon MSK Kafka.
Read > ReadData
Tindakan ini memberikan izin untuk membaca data dari topik Kafka Amazon MSK.
Tulis > Hubungkan
Tindakan ini memberikan izin untuk terhubung dan mengautentikasi ke cluster Amazon MSK Kafka.
Untuk Resource, tentukan cluster ARN (jika Anda ingin membatasi kebijakan ke cluster tertentu, yang direkomendasikan).
Klik Tambahkan izin lainnya.
Untuk Select a service, klik STS.
Untuk Action allowed, klik Write > AssumeRoleWithWebIdentity.
Tindakan ini memberikan izin untuk mendapatkan kumpulan kredensial keamanan sementara untuk Pub/Sub agar dapat melakukan autentikasi ke Amazon MSK menggunakan federasi identitas.
Klik Berikutnya.
Masukkan nama dan deskripsi kebijakan.
Klik Create policy.
Membuat peran di AWS menggunakan kebijakan kepercayaan kustom
Anda harus membuat peran di AWS agar Pub/Sub dapat mengautentikasi ke AWS untuk menyerap data dari Amazon MSK.
Login ke AWS Management Console, lalu buka konsol IAM.
Di panel navigasi konsol untuk IAM, klik Roles.
Klik Buat peran.
Untuk Pilih entitas tepercaya, klik Kebijakan kepercayaan kustom.
Di bagian Custom trust policy, masukkan atau tempelkan kode berikut:
{ "Version": "2012-10-17", "Statement": [ { "Effect": "Allow", "Principal": { "Federated": "accounts.google.com" }, "Action": "sts:AssumeRoleWithWebIdentity", "Condition": { "StringEquals": { "accounts.google.com:sub": "<SERVICE_ACCOUNT_UNIQUE_ID>" } } } ] }
Ganti
<SERVICE_ACCOUNT_UNIQUE_ID>
dengan ID unik akun layanan yang Anda catat di Mencatat ID unik akun layanan.Klik Berikutnya.
Untuk Tambahkan izin, telusuri dan klik kebijakan kustom yang baru saja Anda buat.
Klik Berikutnya.
Masukkan nama dan deskripsi peran.
Klik Buat peran.
Menambahkan peran penayang Pub/Sub ke akun utama Pub/Sub
Untuk mengaktifkan publikasi, Anda harus menetapkan peran penayang ke akun layanan Pub/Sub agar Pub/Sub dapat memublikasikan ke topik impor Amazon MSK.
Mengaktifkan publikasi dari semua topik
Gunakan metode ini jika Anda belum membuat topik impor Amazon MSK.
Di konsol Google Cloud, buka halaman IAM.
Klik kotak centang Sertakan pemberian peran yang disediakan Google.
Cari akun layanan yang memiliki format
service-{PROJECT_NUMBER}@gcp-sa-pubsub.iam.gserviceaccount.com
.Untuk akun layanan ini, klik tombol Edit Principal.
Jika diperlukan, klik Tambahkan peran lain.
Telusuri dan klik Peran penayang Pub/Sub (
roles/pubsub.publisher
).Klik Simpan.
Mengaktifkan publikasi dari satu topik
Gunakan metode ini hanya jika topik impor Amazon MSK sudah ada.
In the Google Cloud console, activate Cloud Shell.
At the bottom of the Google Cloud console, a Cloud Shell session starts and displays a command-line prompt. Cloud Shell is a shell environment with the Google Cloud CLI already installed and with values already set for your current project. It can take a few seconds for the session to initialize.
Jalankan perintah
gcloud pubsub topics add-iam-policy-binding
:gcloud pubsub topics add-iam-policy-binding TOPIC_ID \ --member="serviceAccount:service-PROJECT_NUMBER@gcp-sa-pubsub.iam.gserviceaccount.com" \ --role="roles/pubsub.publisher"
Ganti kode berikut:
TOPIC_ID
: ID topik topik impor Amazon MSK.PROJECT_NUMBER
: nomor project. Untuk melihat nomor project, lihat Mengidentifikasi project.
Menambahkan peran pengguna akun layanan ke akun layanan
Peran Pengguna Akun Layanan (roles/iam.serviceAccountUser
) mencakup izin iam.serviceAccounts.actAs
yang memungkinkan akun utama melampirkan akun layanan ke setelan penyerapan topik impor Amazon MSK dan menggunakan akun layanan tersebut untuk identitas gabungan.
Di konsol Google Cloud, buka halaman IAM.
Untuk akun utama yang mengeluarkan panggilan pembuatan atau pembaruan topik, klik tombol Edit Principal.
Jika diperlukan, klik Tambahkan peran lain.
Telusuri dan klik Peran pengguna akun layanan (
roles/iam.serviceAccountUser
).Klik Simpan.
Menggunakan topik impor Amazon MSK
Anda dapat membuat topik impor baru atau mengedit topik yang ada.
Pertimbangan
Membuat topik dan langganan secara terpisah, meskipun dilakukan secara cepat, dapat menyebabkan hilangnya data. Ada periode singkat saat topik tersedia tanpa langganan. Jika ada data yang dikirim ke topik selama waktu ini, data tersebut akan hilang. Dengan membuat topik terlebih dahulu, membuat langganan, lalu mengonversi topik menjadi topik impor, Anda menjamin bahwa tidak ada pesan yang terlewat selama proses impor.
Jika perlu membuat ulang topik Kafka dari topik impor yang ada dengan nama yang sama, Anda tidak dapat hanya menghapus topik Kafka dan membuatnya ulang. Tindakan ini dapat membatalkan validasi pengelolaan offset Pub/Sub, yang dapat menyebabkan hilangnya data. Untuk mengurangi hal ini, ikuti langkah-langkah berikut:
- Hapus topik impor Pub/Sub.
- Hapus topik Kafka.
- Buat topik Kafka.
- Buat topik impor Pub/Sub.
Data dari topik Kafka Amazon MSK selalu dibaca dari offset paling awal.
Membuat topik impor Amazon MSK
Untuk mengetahui lebih lanjut properti yang terkait dengan topik, lihat Properti topik.
Pastikan Anda telah menyelesaikan prosedur berikut:
Untuk membuat topik impor Amazon MSK, ikuti langkah-langkah berikut:
Konsol
Di konsol Google Cloud, buka halaman Topics.
Klik Create topic.
Di kolom Topic ID, masukkan ID untuk topik impor Amazon MSK Anda. Untuk informasi selengkapnya tentang topik penamaan, lihat panduan penamaan.
Pilih Tambahkan langganan default.
Pilih Aktifkan penyerapan.
Untuk sumber transfer, pilih Amazon MSK.
Masukkan detail berikut:
Cluster ARN: ARN Amazon MSK yang Anda transfer ke Pub/Sub. Format ARN adalah sebagai berikut:
arn:aws:kafka:${Region}:${Account}:cluster/${ClusterName}/${ClusterId}
.Topic: Nama topik Kafka Amazon MSK yang Anda serap ke Pub/Sub.
AWS Role ARN: ARN peran AWS. Format ARN peran adalah sebagai berikut:
arn:aws:iam:${Account}:role/${RoleName}
.Akun layanan: Akun layanan yang Anda buat di Membuat akun layanan di Google Cloud.
Klik Create topic.
gcloud
-
In the Google Cloud console, activate Cloud Shell.
At the bottom of the Google Cloud console, a Cloud Shell session starts and displays a command-line prompt. Cloud Shell is a shell environment with the Google Cloud CLI already installed and with values already set for your current project. It can take a few seconds for the session to initialize.
Jalankan perintah
gcloud pubsub topics create
:gcloud pubsub topics create TOPIC_ID \ --aws-msk-ingestion-cluster-arn MSK_CLUSTER_ARN \ --aws-msk-ingestion-topic MSK_TOPIC \ --aws-msk-ingestion-aws-role-arn MSK_ROLE_ARN \ --aws-msk-ingestion-service-account PUBSUB_SERVICE_ACCOUNT
Ganti kode berikut:
TOPIC_ID
: nama atau ID topik Pub/Sub Anda.MSK_CLUSTER_ARN
: ARN untuk cluster Amazon MSK yang Anda transfer ke Pub/Sub. Format ARN adalah sebagai berikut:arn:aws:kafka:${Region}:${Account}:cluster/${ClusterName}/${ClusterId}
.MSK_TOPIC
: nama topik Kafka Amazon MSK yang Anda transfer ke Pub/Sub.MSK_ROLE_ARN
: ARN peran AWS. Format ARN peran adalah sebagai berikut:arn:aws:iam:${Account}:role/${RoleName}
.PUBSUB_SERVICE_ACCOUNT
: akun layanan yang Anda buat di Membuat akun layanan di Google Cloud.
Go
Sebelum mencoba contoh ini, ikuti petunjuk penyiapan Go di panduan memulai Pub/Sub menggunakan library klien. Untuk mengetahui informasi selengkapnya, lihat dokumentasi referensi API Go Pub/Sub.
Untuk melakukan autentikasi ke Pub/Sub, siapkan Kredensial Default Aplikasi. Untuk mengetahui informasi selengkapnya, lihat Menyiapkan autentikasi untuk lingkungan pengembangan lokal.
Java
Sebelum mencoba contoh ini, ikuti petunjuk penyiapan Java di panduan memulai Pub/Sub menggunakan library klien. Untuk mengetahui informasi selengkapnya, lihat dokumentasi referensi API Java Pub/Sub.
Untuk melakukan autentikasi ke Pub/Sub, siapkan Kredensial Default Aplikasi. Untuk mengetahui informasi selengkapnya, lihat Menyiapkan autentikasi untuk lingkungan pengembangan lokal.
Node.js
Sebelum mencoba contoh ini, ikuti petunjuk penyiapan Node.js di panduan memulai Pub/Sub menggunakan library klien. Untuk mengetahui informasi selengkapnya, lihat dokumentasi referensi API Node.js Pub/Sub.
Untuk melakukan autentikasi ke Pub/Sub, siapkan Kredensial Default Aplikasi. Untuk mengetahui informasi selengkapnya, lihat Menyiapkan autentikasi untuk lingkungan pengembangan lokal.
Python
Sebelum mencoba contoh ini, ikuti petunjuk penyiapan Python di panduan memulai Pub/Sub menggunakan library klien. Untuk mengetahui informasi selengkapnya, lihat dokumentasi referensi API Python Pub/Sub.
Untuk melakukan autentikasi ke Pub/Sub, siapkan Kredensial Default Aplikasi. Untuk mengetahui informasi selengkapnya, lihat Menyiapkan autentikasi untuk lingkungan pengembangan lokal.
C++
Sebelum mencoba contoh ini, ikuti petunjuk penyiapan C++ di panduan memulai Pub/Sub menggunakan library klien. Untuk mengetahui informasi selengkapnya, lihat dokumentasi referensi API C++ Pub/Sub.
Untuk melakukan autentikasi ke Pub/Sub, siapkan Kredensial Default Aplikasi. Untuk mengetahui informasi selengkapnya, lihat Menyiapkan autentikasi untuk lingkungan pengembangan lokal.
Node.js (TypeScript)
Sebelum mencoba contoh ini, ikuti petunjuk penyiapan Node.js di panduan memulai Pub/Sub menggunakan library klien. Untuk mengetahui informasi selengkapnya, lihat dokumentasi referensi API Node.js Pub/Sub.
Untuk melakukan autentikasi ke Pub/Sub, siapkan Kredensial Default Aplikasi. Untuk mengetahui informasi selengkapnya, lihat Menyiapkan autentikasi untuk lingkungan pengembangan lokal.
Untuk mengetahui informasi selengkapnya tentang ARN, lihat Amazon Resource Name (ARN) dan ID IAM.
Jika Anda mengalami masalah, lihat Memecahkan masalah topik impor Amazon MSK.
Mengedit topik impor Amazon MSK
Untuk mengedit setelan sumber data penyerapan topik impor Amazon MSK, ikuti langkah-langkah berikut:
Konsol
Di konsol Google Cloud, buka halaman Topics.
Klik topik impor Amazon MSK.
Di halaman detail topik, klik Edit.
Perbarui kolom yang ingin diubah.
Klik Perbarui.
gcloud
-
In the Google Cloud console, activate Cloud Shell.
At the bottom of the Google Cloud console, a Cloud Shell session starts and displays a command-line prompt. Cloud Shell is a shell environment with the Google Cloud CLI already installed and with values already set for your current project. It can take a few seconds for the session to initialize.
Jalankan perintah
gcloud pubsub topics update
dengan semua flag yang disebutkan dalam contoh berikut:gcloud pubsub topics update TOPIC_ID \ --aws-msk-ingestion-cluster-arn MSK_CLUSTER_ARN \ --aws-msk-ingestion-topic MSK_TOPIC \ --aws-msk-ingestion-aws-role-arn MSK_ROLE_ARN \ --aws-msk-ingestion-service-account PUBSUB_SERVICE_ACCOUNT
Ganti kode berikut:
- TOPIC_ID: nama atau ID topik Pub/Sub Anda.
- MSK_CLUSTER_ARN: ARN untuk cluster Amazon MSK yang Anda transfer ke Pub/Sub. Format ARN
adalah sebagai berikut:
arn:aws:kafka:${Region}:${Account}:cluster/${ClusterName}/${ClusterId}
. - MSK_TOPIC: nama topik Amazon MSK Kafka yang Anda serap ke Pub/Sub.
- MSK_ROLE_ARN: ARN peran AWS. Format ARN peran adalah sebagai berikut:
arn:aws:iam:${Account}:role/${RoleName}
. - PUBSUB_SERVICE_ACCOUNT: akun layanan yang Anda buat di Membuat akun layanan di Google Cloud.
Kuota dan batas
Throughput penayang untuk topik impor dibatasi oleh kuota publikasi topik. Untuk mengetahui informasi selengkapnya, lihat Kuota dan batas Pub/Sub.
Langkah berikutnya
Pilih jenis langganan untuk topik Anda.
Pelajari cara memublikasikan pesan ke topik.
Buat atau ubah topik dengan gcloud CLI, REST API, atau Library klien.