Dokumen ini menjelaskan cara menjalankan OpenTelemetry Collector Buatan Google di Google Kubernetes Engine untuk mengumpulkan log, metrik, dan trace OTLP dari aplikasi berinstrumen, lalu mengekspor data tersebut ke Google Cloud.
Sebelum memulai
Untuk menjalankan OpenTelemetry Collector Buatan Google, Anda memerlukan resource berikut:
Project Google Cloud dengan Cloud Monitoring API, Cloud Trace API, dan Cloud Logging API diaktifkan.
Jika Anda tidak memiliki project Google Cloud, lakukan hal berikut:
Di konsol Google Cloud, buka New Project:
Di kolom Project Name, masukkan nama project Anda, lalu klik Create.
Buka Penagihan:
Pilih project yang baru saja Anda buat jika belum dipilih di bagian atas halaman.
Anda akan diminta untuk memilih profil pembayaran yang sudah ada atau membuat yang baru.
Monitoring API, Trace API, dan Logging API diaktifkan secara default untuk project baru.
Jika Anda sudah memiliki project Google Cloud, pastikan Monitoring API, Trace API, dan Logging API diaktifkan:
Cluster Kubernetes. Jika Anda tidak memiliki cluster Kubernetes, ikuti petunjuk di Memulai cepat untuk GKE.
Alat command line berikut:
gcloud
kubectl
Alat
gcloud
dankubectl
adalah bagian dari Google Cloud CLI. Untuk mengetahui informasi tentang cara menginstalnya, lihat Mengelola komponen Google Cloud CLI. Untuk melihat komponen gcloud CLI yang telah Anda instal, jalankan perintah berikut:gcloud components list
Mengonfigurasi izin untuk Kolektor
Jika telah menonaktifkan identitas workload GKE, Anda dapat melewati bagian ini.
Untuk memastikan bahwa akun layanan kubernetes OpenTelemetry Collector memiliki izin yang diperlukan untuk mengekspor telemetri, minta administrator untuk memberikan akun layanan kubernetes OpenTelemetry Collector peran IAM berikut di project Anda:
-
Monitoring Metric Writer (
roles/monitoring.metricWriter
) -
Logging Log Writer (
roles/logging.logWriter
) -
Agen Cloud Trace (
roles/cloudtrace.agent
)
Untuk mengetahui informasi selengkapnya tentang cara memberikan peran, lihat Mengelola akses ke project, folder, dan organisasi.
Administrator Anda mungkin juga dapat memberikan izin yang diperlukan kepada akun layanan kubernetes OpenTelemetry Collector melalui peran kustom atau peran bawaan lainnya.
Untuk mengonfigurasi izin, gunakan perintah
add-iam-policy-binding
berikut:
gcloud projects add-iam-policy-binding projects/PROJECT_ID \ --role=roles/logging.logWriter \ --member=principal://iam.googleapis.com/projects/PROJECT_NUMBER/locations/global/workloadIdentityPools/PROJECT_ID.svc.id.goog/subject/ns/opentelemetry/sa/opentelemetry-collector gcloud projects add-iam-policy-binding projects/PROJECT_ID \ --role=roles/monitoring.metricWriter \ --member=principal://iam.googleapis.com/projects/PROJECT_NUMBER/locations/global/workloadIdentityPools/PROJECT_ID.svc.id.goog/subject/ns/opentelemetry/sa/opentelemetry-collector gcloud projects add-iam-policy-binding projects/PROJECT_ID \ --role=roles/cloudtrace.agent \ --member=principal://iam.googleapis.com/projects/PROJECT_NUMBER/locations/global/workloadIdentityPools/PROJECT_ID.svc.id.goog/subject/ns/opentelemetry/sa/opentelemetry-collector
Sebelum menjalankan perintah, ganti variabel berikut:
- PROJECT_ID: ID project.
- PROJECT_NUMBER: Nomor project Google Cloud.
Men-deploy Kolektor
Pipeline Collector dapat di-deploy langsung dari contoh yang telah diperiksa dan disediakan oleh repo Proses Transfer Kubernetes OTLP Mandiri. Anda dapat men-deploy langsung dari GitHub dengan perintah berikut setelah mengganti PROJECT_ID dengan ID project Google Cloud Anda:
export GCLOUD_PROJECT=PROJECT_ID kubectl kustomize https://github.com/GoogleCloudPlatform/otlp-k8s-ingest.git/k8s/base | envsubst | kubectl apply -f -
Sebelum menjalankan perintah, ganti variabel berikut:
- PROJECT_ID: ID project.
Mengonfigurasi Kolektor
Kami menyediakan konfigurasi OpenTelemetry Collector untuk Anda gunakan dengan Collector buatan Google. Konfigurasi ini dirancang untuk mengirimkan metrik, log, dan trace OTLP dengan volume tinggi dengan metadata GKE dan Kubernetes yang konsisten. Konfigurasi ini juga dirancang untuk mencegah masalah penyerapan umum. Anda dapat menambahkan ke konfigurasi, tetapi sebaiknya jangan menghapus elemen.
Bagian ini menjelaskan konfigurasi yang disediakan, komponen utama seperti eksportir, pemroses, penerima, dan komponen lain yang tersedia.
Konfigurasi Kolektor yang disediakan
Anda dapat menemukan konfigurasi Kolektor untuk lingkungan Kubernetes di repositoriotlp-k8s-ingest
:
Pengekspor
Konfigurasi Pengumpul mencakup eksportir berikut:
Pengekspor
googlecloud
, untuk log dan trace. Eksporter ini dikonfigurasi dengan nama log default.Ekspor
googlemanagedprometheus
, untuk metrik. Eksporter ini tidak memerlukan konfigurasi apa pun, tetapi ada opsi konfigurasi. Untuk informasi tentang opsi konfigurasi untuk eksportirgooglemanagedprometheus
, lihat Memulai OpenTelemetry Collector dalam dokumentasi Google Cloud Managed Service for Prometheus.
Prosesor
Konfigurasi Pengumpul mencakup pemroses berikut:
batch
: Dikonfigurasi untuk mengelompokkan permintaan telemetri pada Google Cloud jumlah maksimum entri per permintaan, atau pada Google Cloud interval minimum setiap 5 detik (mana saja yang tercapai lebih dahulu).memory_limiter
: Memasang batas penggunaan memori Pengumpul untuk mencegah error kehabisan memori dengan menghapus titik data saat batas terlampaui.resourcedetection
: Mendeteksi label resource Google Cloud secara otomatis sepertiproject_id
dancluster_name
.k8sattributes
: Menautkan atribut resource Kubernetes ke label telemetri secara otomatis.transform
: Mengganti nama label metrik yang bentrok dengan label di Google Cloud resource yang dimonitor.
Penerima
Konfigurasi Pengumpul hanya menyertakan
penerima otlp
.
Untuk informasi tentang cara melengkapi aplikasi Anda dengan instrumentasi untuk mengirim pelacakan dan metrik OTLP ke endpoint OTLP Pengumpul, lihat Memilih pendekatan instrumentasi.
Komponen yang tersedia
OpenTelemetry Collector Buatan Google berisi komponen yang diperlukan sebagian besar pengguna untuk
memungkinkan pengalaman yang kaya dalam Google Cloud Observability. Untuk mengetahui daftar lengkap
komponen yang tersedia, lihat
Components
di repositori opentelemetry-operations-collector
.
Untuk meminta perubahan atau penambahan pada komponen yang tersedia,
buka permintaan fitur.
di repositori opentelemetry-operations-collector
.
Membuat telemetri
Bagian ini menjelaskan cara men-deploy aplikasi contoh dan mengarahkan aplikasi tersebut ke endpoint OTLP Pengumpul, serta melihat telemetri diGoogle Cloud. Aplikasi contoh adalah generator kecil yang mengekspor rekaman aktivitas, log, dan metrik ke Kolektor.
Jika sudah memiliki aplikasi yang dilengkapi dengan OpenTelemetry SDK, Anda dapat mengarahkan aplikasi ke endpoint Pengumpul.
Untuk men-deploy aplikasi contoh, jalankan perintah berikut:
kubectl apply -f https://raw.githubusercontent.com/GoogleCloudPlatform/otlp-k8s-ingest/main/sample/app.yaml
Untuk mengarahkan aplikasi yang ada yang menggunakan OpenTelemetry SDK ke endpoint
Collector, tetapkan variabel lingkungan OTEL_EXPORTER_OTLP_ENDPOINT
ke
http://opentelemetry-collector.opentelemetry.svc.cluster.local:4317
.
Setelah beberapa menit, telemetri yang dihasilkan oleh aplikasi mulai mengalir melalui Collector ke konsol Google Cloud untuk setiap sinyal.
Melihat telemetri
OpenTelemetry Collector Buatan Google mengirimkan metrik, log, dan trace dari aplikasi yang diinstrumentasikan ke Google Cloud Observability. Kolektor juga mengirimkan metrik pengamatan mandiri. Bagian berikut menjelaskan cara melihat telemetri ini.
Melihat metrik
Kolektor OpenTelemetry Buatan Google mengumpulkan metrik Prometheus yang dapat Anda lihat menggunakan Metrics Explorer. Metrik yang dikumpulkan bergantung pada instrumentasi aplikasi, meskipun Pengumpul buatan Google juga menulis beberapa metrik mandiri.
Untuk melihat metrik yang dikumpulkan oleh OpenTelemetry Collector Buatan Google, lakukan tindakan berikut:-
Di konsol Google Cloud, buka halaman leaderboard Metrics explorer:
Jika Anda menggunakan kotak penelusuran untuk menemukan halaman ini, pilih hasil yang subjudulnya adalah Monitoring.
- Di toolbar konsol Google Cloud, pilih project Google Cloud Anda. Untuk konfigurasi App Hub, pilih project host App Hub atau project pengelolaan folder yang mengaktifkan aplikasi.
- Pada elemen Metric, luaskan menu Select a metric,
masukkan
Prometheus Target
di panel filter, lalu gunakan submenu untuk memilih jenis dan metrik resource tertentu:- Di menu Active resources, pilih Prometheus Target.
- Untuk memilih metrik, gunakan menu Kategori metrik aktif dan Metrik aktif.
Metrik yang dikumpulkan oleh OpenTelemetry Collector Buatan Google memiliki
awalan
prometheus.googleapis.com
. - Klik Terapkan.
- Konfigurasi cara data dilihat.
Jika pengukuran untuk metrik bersifat kumulatif, Metrics Explorer akan otomatis menormalisasi data yang diukur menurut periode penyelarasan, sehingga diagram akan menampilkan rasio. Untuk mengetahui informasi selengkapnya, lihat Jenis, tipe, dan konversi.
Saat nilai bilangan bulat atau ganda diukur, seperti dengan metrik
counter
, Metrics Explorer akan otomatis menjumlahkan semua deret waktu. Untuk mengubah perilaku ini, tetapkan menu pertama entri Aggregation ke None.Untuk informasi selengkapnya tentang cara mengonfigurasi diagram, lihat Memilih metrik saat menggunakan Metrics Explorer.
Melihat trace Anda
Untuk melihat data rekaman aktivitas, lakukan hal berikut:
-
Di konsol Google Cloud, buka halaman Trace Explorer:
Anda juga dapat menemukan halaman ini menggunakan kotak penelusuran.
- Di toolbar konsol Google Cloud, pilih project Google Cloud Anda. Untuk konfigurasi App Hub, pilih project host App Hub atau project pengelolaan folder yang mengaktifkan aplikasi.
- Di bagian tabel halaman, pilih baris.
Pada diagram Gantt di panel Trace details, pilih rentang.
Panel akan terbuka dan menampilkan informasi tentang permintaan yang dilacak. Detail ini mencakup metode, kode status, jumlah byte, dan agen pengguna pemanggil.
Untuk melihat log yang terkait dengan rekaman aktivitas ini, pilih tab Logs & Events.
Tab ini menampilkan setiap log. Untuk melihat detail entri log, luaskan entri log. Anda juga dapat mengklik View Logs dan melihat log menggunakan Logs Explorer.
Untuk informasi selengkapnya tentang cara menggunakan Cloud Trace Explorer, lihat Menemukan dan menjelajahi trace.
Melihat log
Dari Logs Explorer, Anda dapat memeriksa log, dan juga dapat melihat rekaman aktivitas terkait, jika ada.
-
Di konsol Google Cloud, buka halaman Logs Explorer:
Jika Anda menggunakan kotak penelusuran untuk menemukan halaman ini, pilih hasil yang subjudulnya adalah Logging.
Temukan entri log dari aplikasi berinstrumen Anda. Untuk melihat detailnya, luaskan entri log.
Klik
Traces pada entri log dengan pesan trace, lalu pilih View trace details.
Panel Trace details akan terbuka dan menampilkan rekaman aktivitas yang dipilih.
Untuk mengetahui informasi selengkapnya tentang cara menggunakan Logs Explorer, lihat Melihat log menggunakan Logs Explorer.
Mengamati dan men-debug Pengumpul
OpenTelemetry Collector Buatan Google secara otomatis memberikan metrik pengamatan mandiri untuk membantu Anda memantau performanya dan memastikan uptime berkelanjutan pipeline penyerapan OTLP.
Untuk memantau Kolektor, instal contoh dasbor untuk Kolektor. Dasbor ini menawarkan insight sekilas tentang beberapa metrik dari Pengumpul, termasuk waktu aktif, penggunaan memori, dan panggilan API ke Google Cloud Observability.
Untuk menginstal dasbor, lakukan hal berikut:
-
Di konsol Google Cloud, buka halaman
Dasbor:
Jika Anda menggunakan kotak penelusuran untuk menemukan halaman ini, pilih hasil yang subjudulnya adalah Monitoring.
- Klik Dashboard Templates.
- Telusuri dasbor OpenTelemetry Collector.
- Opsional: Untuk melihat pratinjau dasbor, pilih dasbor.
Klik playlist_add Tambahkan dasbor ke daftar Anda, lalu selesaikan dialog.
Dialog ini memungkinkan Anda memilih nama dasbor, dan menambahkan label ke dasbor.
Untuk informasi selengkapnya tentang cara menginstal dasbor, lihat Menginstal template dasbor.