Dokumen ini menjelaskan cara membuat metrik yang ditentukan pengguna dan cara menulis data metrik ini menggunakan Cloud Monitoring API. Metrik yang ditentukan pengguna menggunakan elemen yang sama dengan yang digunakan metrik Cloud Monitoring bawaan:
- Kumpulan titik data.
- Informasi jenis metrik, yang memberi tahu Anda apa yang diwakili oleh titik data.
- Informasi resource yang dipantau, yang memberi tahu Anda tempat titik data berasal.
Metrik buatan pengguna, yang terkadang disebut metrik kustom, dapat digunakan dengan cara yang sama seperti metrik bawaan. Artinya, Anda dapat membuat diagram dan pemberitahuan untuk data metrik ini.
Metrik berbasis log adalah class dalam metrik yang ditentukan pengguna, tetapi Anda tidak dapat membuatnya menggunakan Cloud Monitoring API. Metrik berbasis log memperoleh data metrik dari entri log, tetapi Monitoring API tidak menyediakan cara untuk menentukan cara mengekstrak data metrik dari entri log. Sebagai gantinya, gunakan Cloud Logging untuk membuat metrik berbasis log. Saat Anda membuat metrik berbasis log, Logging akan membuat struktur yang dijelaskan dalam dokumen ini dan mengirim data metrik ke Cloud Monitoring untuk Anda. Untuk informasi tentang cara membuat metrik berbasis log, lihat dokumen berikut:
Untuk melengkapi aplikasi Anda, sebaiknya gunakan framework instrumentasi netral vendor yang bersifat open source, seperti OpenTelemetry, bukan API atau library klien khusus vendor dan produk. Untuk informasi tentang cara melengkapi aplikasi Anda, lihat Instrumentasi dan observabilitas.
Sebelum memulai
Untuk mempelajari struktur yang mendasari semua metrik, lihat Metrik, deret waktu, dan resource.
Untuk menggunakan Cloud Monitoring, Anda harus memiliki project Google Cloud dengan penagihan yang diaktifkan. Jika perlu, lakukan hal berikut:
-
In the Google Cloud console, on the project selector page, select or create a Google Cloud project.
-
Make sure that billing is enabled for your Google Cloud project.
- Pastikan Monitoring API diaktifkan. Untuk mengetahui detailnya, lihat Mengaktifkan Monitoring API.
- Untuk aplikasi yang berjalan di luar Google Cloud, project Google Cloud Anda harus mengautentikasi aplikasi menggunakan Kredensial Default Aplikasi (ADC) lokal. Untuk mengetahui informasi selengkapnya, lihat Menyiapkan ADC untuk penyedia cloud lokal atau penyedia cloud lainnya.
Membuat jenis metrik yang ditentukan pengguna
Untuk membuat metrik buatan pengguna, Anda dapat menentukan objek MetricDescriptor
yang menentukan berbagai informasi tentang metrik, atau menulis data metrik. Saat Anda menulis data metrik,
Monitoring akan membuat deskripsi metrik untuk Anda berdasarkan
struktur data yang Anda berikan.
Untuk informasi tentang cara mendesain deskripsi metrik, lihat
Deskripsi metrik untuk metrik yang ditentukan pengguna.
Pembuatan deskripsi metrik secara otomatis
Jika Anda menulis data metrik saat deskripsi metrik untuk metrik yang ditentukan pengguna tersebut belum ada, deskripsi metrik akan dibuat secara otomatis. Namun, deskripsi metrik baru ini mungkin tidak persis seperti yang Anda inginkan; pembuatan otomatis deskripsi metrik melibatkan beberapa asumsi dan default.
Cloud Monitoring membuat MetricDescriptor
baru saat
objek TimeSeries
yang disertakan dalam panggilan ke
timeSeries.create
mereferensikan
objek Metric
yang menentukan
nama jenis metrik yang tidak ada.
Cloud Monitoring menggunakan aturan berikut untuk mengisi
MetricDescriptor
:
type
: Jenis disalin dari kolomtype
objekMetric
.name
: Nama dibuat dari project ID dalam panggilan metode dan nilaitype
dalam objekMetric
.labels
: Label yang muncul di objekMetric
. Setiap deskripsi label dalam deskripsi metrik baru memiliki kolom berikut:key
: kunci label dalam objekMetric
.valueType
:STRING
description
: tidak ditetapkan
metricKind
: Jenis metrik ditetapkan keGAUGE
kecuali jika Anda menentukan parametermetricKind
dari objekTimeSeries
. Saat Anda menentukanmetricKind
, metrik baru akan memiliki jenis tersebut. Anda hanya dapat menentukan jenisGAUGE
danCUMULATIVE
.valueType
: Jenis nilai diambil dari nilai yang diketik dariPoint
yang ditulis. Jenis nilai harusBOOL
,INT64
,DOUBLE
, atauDISTRIBUTION
. Saat Anda menentukan jenis nilai di kolomvalueType
dariTimeSeries
, jenis tersebut harus cocok dengan jenisPoint
.unit
: tidak ditetapkandescription
:"Auto created custom metric."
.displayName
: tidak ditetapkan
Dalam satu panggilan timeSeries.create
, Anda dapat
menyertakan beberapa objek TimeSeries
yang merujuk ke jenis metrik yang sama yang tidak ada. Dalam hal ini,
label dalam deskripsi metrik baru terdiri dari gabungan semua label
dalam objek Metric
di semua deret waktu dalam panggilan ini ke
create
.
Langkah berikutnya: Lihat Menulis metrik yang ditentukan pengguna.
Pembuatan deskripsi metrik secara manual
Untuk membuat deskripsi metrik, lakukan hal berikut:
Tentukan struktur deskripsi metrik Anda. Untuk mendapatkan bantuan dalam membuat pilihan ini, Anda dapat menelusuri metrik bawaan dan melihat data deret waktunya:
Pilih nama metrik untuk metrik yang ditentukan pengguna.
Pilih nama tampilan dan deskripsi untuk metrik Anda. Nama tampilan digunakan di konsol Google Cloud .
Pilih satu atau beberapa project tempat Anda akan menentukan metrik yang ditentukan pengguna dan menulis data deret waktunya. Jika Anda memerlukan metrik yang sama di beberapa project, buat definisi metrik yang identik di setiap project.
Tentukan jenis metrik, jenis nilai, dan (opsional) satuan. Tidak semua jenis nilai dan jenis metrik didukung untuk metrik yang ditentukan pengguna. Untuk informasi selengkapnya tentang kolom ini, lihat Jenis nilai dan jenis metrik.
Pilih label metrik—nama, jenis nilai, dan deskripsinya.
Menentukan resource yang dipantau tempat data metrik ditulis. Pilih dari daftar berikut:
aws_ec2_instance
: Instance Amazon EC2.dataflow_job
: Tugas Dataflow.gae_instance
: Instance App Engine.gce_instance
: instance Compute Engine.generic_node
: Node komputasi yang ditentukan pengguna.generic_task
: Tugas yang ditentukan pengguna.gke_container
: Instance penampung GKE.global
: Gunakan resource ini jika tidak ada jenis resource lain yang sesuai. Untuk sebagian besar kasus penggunaan,generic_node
ataugeneric_task
adalah pilihan yang lebih baik daripadaglobal
.k8s_cluster
: Cluster Kubernetes.k8s_container
: Container Kubernetes.k8s_node
: Node Kubernetes.k8s_pod
: Pod Kubernetes.
Buat objek
MetricDescriptor
, lalu teruskan sebagai argumen ke panggilan ke metodemetricDescriptors.create
.
Biasanya, memanggil
metricDescriptors.create
menggunakan nama jenis
yang sama dengan deskripsi metrik yang ada akan menyebabkan error. Namun, jika semua kolom objek MetricDescriptor
baru cocok persis dengan kolom deskripsi yang ada, hal ini bukan merupakan error, tetapi tidak berpengaruh.
Dalam contoh berikut, Anda akan membuat metrik pengukur.
Protokol
Untuk membuat deskripsi metrik, gunakan
metode metricDescriptors.create
.
Anda dapat menjalankan metode ini menggunakan widget API Explorer di halaman referensi metode. Lihat APIs Explorer untuk
informasi selengkapnya.
Berikut adalah contoh parameter untuk
metricDescriptors.create
:
- name (URL):
projects/[PROJECT_ID]
Isi permintaan: berikan objek
MetricDescriptor
seperti berikut:{ "name": "", "description": "Daily sales records from all branch stores.", "displayName": "Sales", "type": "custom.googleapis.com/stores/sales", "metricKind": "GAUGE", "valueType": "DOUBLE", "unit": "{USD}", "labels": [ { "key": "store_id", "valueType": "STRING", "description": "The ID of the store." }, ], }
Berikan nilai ini ke kolom di widget, menggunakan project ID Anda
sebagai pengganti [PROJECT_ID
]:
Klik tombol Execute untuk menjalankan metode.
Saat membuat metrik baru, kolom name
di
MetricDescriptor
akan diabaikan dan dapat dihilangkan. Metode create
menampilkan
deskripsi metrik baru dengan kolom name
yang diisi, yang dalam contoh
ini adalah sebagai berikut:
"name": "projects/[PROJECT_ID]/metricDescriptors/custom.googleapis.com/stores/daily_sales"
Misalnya, jika ingin mendapatkan deskripsi metrik, Anda dapat menggunakan nama ini.
C#
Untuk melakukan autentikasi ke Monitoring, siapkan Kredensial Default Aplikasi. Untuk mengetahui informasi selengkapnya, lihat Menyiapkan autentikasi untuk lingkungan pengembangan lokal.
Go
Untuk melakukan autentikasi ke Monitoring, siapkan Kredensial Default Aplikasi. Untuk mengetahui informasi selengkapnya, lihat Menyiapkan autentikasi untuk lingkungan pengembangan lokal.
Java
Untuk melakukan autentikasi ke Monitoring, siapkan Kredensial Default Aplikasi. Untuk mengetahui informasi selengkapnya, lihat Menyiapkan autentikasi untuk lingkungan pengembangan lokal.
Node.js
Untuk melakukan autentikasi ke Monitoring, siapkan Kredensial Default Aplikasi. Untuk mengetahui informasi selengkapnya, lihat Menyiapkan autentikasi untuk lingkungan pengembangan lokal.
PHP
Untuk melakukan autentikasi ke Monitoring, siapkan Kredensial Default Aplikasi. Untuk mengetahui informasi selengkapnya, lihat Menyiapkan autentikasi untuk lingkungan pengembangan lokal.
Python
Untuk melakukan autentikasi ke Monitoring, siapkan Kredensial Default Aplikasi. Untuk mengetahui informasi selengkapnya, lihat Menyiapkan autentikasi untuk lingkungan pengembangan lokal.
Ruby
Untuk melakukan autentikasi ke Monitoring, siapkan Kredensial Default Aplikasi. Untuk mengetahui informasi selengkapnya, lihat Menyiapkan autentikasi untuk lingkungan pengembangan lokal.
Lihat Memecahkan masalah panggilan API jika Anda mengalami kesulitan.
Langkah berikutnya: Lihat Menulis metrik yang ditentukan pengguna.
Menulis metrik yang ditentukan pengguna
Anda hanya dapat menulis data ke jenis metrik untuk metrik yang ditentukan pengguna. Untuk menulis data,
gunakan metode timeSeries.create
.
Jika deret waktu ada, metode ini akan menambahkan titik data baru ke deret waktu yang ada. Jika
deret waktu tidak ada, metode ini akan membuatnya dan menambahkan data.
Anda menulis titik data dengan meneruskan daftar objek TimeSeries
ke
timeSeries.create
.
Ukuran daftar maksimum adalah 200
dan setiap objek dalam daftar harus menentukan deret waktu yang berbeda:
- Nilai kolom
metric
danresource
mengidentifikasi objekTimeSeries
tertentu. Kolom ini mewakili jenis metrik data dan resource yang dipantau tempat data dikumpulkan. - Hapus kolom
metricKind
danvalueType
; kolom tersebut diabaikan saat menulis titik data. Setiap objek
TimeSeries
hanya boleh berisi satu objekPoint
:- Nilai titik dan interval waktu harus konsisten dengan definisi jenis metrik. Untuk mengetahui informasi tentang interval waktu untuk berbagai jenis metrik, lihat
TimeInterval
. - Interval waktu titik harus lebih lambat dari titik yang sudah ada dalam deret waktu.
- Waktu akhir interval tidak boleh lebih dari 25 jam yang lalu atau lebih dari lima menit ke depan.
- Nilai titik dan interval waktu harus konsisten dengan definisi jenis metrik. Untuk mengetahui informasi tentang interval waktu untuk berbagai jenis metrik, lihat
Untuk menulis lebih dari satu titik ke deret waktu yang sama, gunakan panggilan terpisah ke metode
timeSeries.create
untuk setiap titik. Jangan menulis data ke deret waktu tunggal lebih cepat dari satu titik setiap 5 detik. Saat Anda menambahkan titik data ke deret waktu yang berbeda, tidak ada batasan kapasitas.
Protokol
Untuk menulis data metrik, gunakan metode
timeSeries.create
.
Anda dapat menjalankan metode ini menggunakan widget API Explorer di halaman referensi metode. Lihat APIs Explorer
untuk informasi selengkapnya.
Untuk menulis titik ke metrik stores/daily_sales
yang dibuat di
Pembuatan deskripsi metrik secara manual:
- Buka halaman referensi untuk
timeSeries.create
. - Berikan parameter di bawah ke widget API Explorer.
- Klik tombol Execute.
Gunakan parameter contoh berikut:
- name:
projects/[PROJECT_ID]
isi permintaan: sertakan daftar objek
TimeSeries
. Contoh berikut hanya memiliki satu deret waktu dalam daftar.{ "timeSeries": [ { "metric": { "type": "custom.googleapis.com/my_metric", "labels": { "my_label": "my_value" } }, "resource": { "type": "gce_instance", "labels": { "project_id": "[PROJECT_ID]", "instance_id": "1234567890123456789", "zone": "us-central1-f" } }, "points": [ { "interval": { "endTime": "2018-06-01T10:00:00-04:00" }, "value": { "doubleValue": 123.45 } } ] } ] }
C#
Untuk melakukan autentikasi ke Monitoring, siapkan Kredensial Default Aplikasi. Untuk mengetahui informasi selengkapnya, lihat Menyiapkan autentikasi untuk lingkungan pengembangan lokal.
Go
Untuk melakukan autentikasi ke Monitoring, siapkan Kredensial Default Aplikasi. Untuk mengetahui informasi selengkapnya, lihat Menyiapkan autentikasi untuk lingkungan pengembangan lokal.
Java
Untuk melakukan autentikasi ke Monitoring, siapkan Kredensial Default Aplikasi. Untuk mengetahui informasi selengkapnya, lihat Menyiapkan autentikasi untuk lingkungan pengembangan lokal.
Node.js
Untuk melakukan autentikasi ke Monitoring, siapkan Kredensial Default Aplikasi. Untuk mengetahui informasi selengkapnya, lihat Menyiapkan autentikasi untuk lingkungan pengembangan lokal.
PHP
Untuk melakukan autentikasi ke Monitoring, siapkan Kredensial Default Aplikasi. Untuk mengetahui informasi selengkapnya, lihat Menyiapkan autentikasi untuk lingkungan pengembangan lokal.
Python
Untuk melakukan autentikasi ke Monitoring, siapkan Kredensial Default Aplikasi. Untuk mengetahui informasi selengkapnya, lihat Menyiapkan autentikasi untuk lingkungan pengembangan lokal.
Ruby
Untuk melakukan autentikasi ke Monitoring, siapkan Kredensial Default Aplikasi. Untuk mengetahui informasi selengkapnya, lihat Menyiapkan autentikasi untuk lingkungan pengembangan lokal.
Lihat Memecahkan masalah panggilan API jika Anda mengalami kesulitan.
Menghapus metrik buatan pengguna
Untuk menghapus metrik yang ditentukan pengguna, hapus deskripsi metriknya. Anda tidak dapat menghapus data deret waktu yang disimpan di project Google Cloud ; tetapi, menghapus deskripsi metrik akan membuat data tidak dapat diakses. Masa berlaku data akan berakhir dan dihapus sesuai dengan kebijakan retensi data.
Anda tidak dapat menghapus deskripsi metrik untuk metrik bawaan.
Untuk menghapus deskripsi metrik, panggil metode
metricDescriptors.delete
.
Protokol
Untuk menghapus deskripsi metrik, gunakan
metode metricDescriptors.delete
.
Anda dapat menjalankan metode ini menggunakan widget API Explorer di halaman referensi metode. Lihat APIs Explorer
untuk informasi selengkapnya.
Untuk menghapus metrik stores/daily_sales
yang dibuat di
Pembuatan deskripsi metrik secara manual:
- Buka
halaman referensi untuk
metricDescriptors.delete
: Berikan nama deskriptor metrik ke widget API Explorer:
name:
projects/[PROJECT_ID]/metricDescriptors/custom.googleapis.com/stores/daily_sales
Klik tombol Execute.
C#
Untuk melakukan autentikasi ke Monitoring, siapkan Kredensial Default Aplikasi. Untuk mengetahui informasi selengkapnya, lihat Menyiapkan autentikasi untuk lingkungan pengembangan lokal.
Go
Untuk melakukan autentikasi ke Monitoring, siapkan Kredensial Default Aplikasi. Untuk mengetahui informasi selengkapnya, lihat Menyiapkan autentikasi untuk lingkungan pengembangan lokal.
Java
Untuk melakukan autentikasi ke Monitoring, siapkan Kredensial Default Aplikasi. Untuk mengetahui informasi selengkapnya, lihat Menyiapkan autentikasi untuk lingkungan pengembangan lokal.
Node.js
Untuk melakukan autentikasi ke Monitoring, siapkan Kredensial Default Aplikasi. Untuk mengetahui informasi selengkapnya, lihat Menyiapkan autentikasi untuk lingkungan pengembangan lokal.
PHP
Untuk melakukan autentikasi ke Monitoring, siapkan Kredensial Default Aplikasi. Untuk mengetahui informasi selengkapnya, lihat Menyiapkan autentikasi untuk lingkungan pengembangan lokal.
Python
Untuk melakukan autentikasi ke Monitoring, siapkan Kredensial Default Aplikasi. Untuk mengetahui informasi selengkapnya, lihat Menyiapkan autentikasi untuk lingkungan pengembangan lokal.
Ruby
Untuk melakukan autentikasi ke Monitoring, siapkan Kredensial Default Aplikasi. Untuk mengetahui informasi selengkapnya, lihat Menyiapkan autentikasi untuk lingkungan pengembangan lokal.
Lihat Memecahkan masalah panggilan API jika Anda mengalami kesulitan.
Mengubah metrik yang ditentukan pengguna
Untuk mengubah metrik buatan pengguna, Anda harus memperbarui objek MetricDescriptor
yang menentukan metrik.
Satu-satunya modifikasi yang didukung adalah menambahkan label.
Untuk menambahkan label ke metrik yang ditentukan pengguna yang ada, gunakan metode timeSeries.create
dan sertakan label baru dengan data deret waktu. Label ditambahkan ke deskripsi metrik saat label yang Anda coba tulis valid dan jumlah total label kurang dari 30.
Data deret waktu kemudian ditulis seolah-olah label sudah ada sejak awal.
Jika ingin melakukan lebih dari sekadar menambahkan label baru, Anda harus menghapus dan membuat ulang deskripsi metrik. Dalam hal ini, Anda akan kehilangan semua data deret waktu yang sebelumnya dikumpulkan untuk deskripsi metrik lama. Lihat Menghapus metrik yang ditentukan pengguna untuk mengetahui informasi selengkapnya.
Anda tidak dapat mengganti nama metrik.