Panduan ini menjelaskan cara mengonfigurasi filter saat Anda menggunakan Monitoring API. Anda menggunakan filter untuk menentukan resource yang dimonitor, jenis metrik, definisi grup, dan deret waktu. Anda juga dapat menggunakan filter untuk mengonfigurasi kebijakan pemberitahuan yang memantau proses yang berjalan di sistem Anda. Untuk informasi tentang filter tersebut, lihat Filter kesehatan proses.
Sebelum memulai
Jika Anda tidak terbiasa dengan metrik, deret waktu, dan resource yang dimonitor, lihat Metrik, deret waktu, dan resource.
Jika Anda belum memahami label, lihat Label untuk mengetahui pengantarnya.
Menggunakan filter
Anda dapat menggunakan filter di Monitoring API untuk melakukan hal berikut:
- Pilih data deret waktu tertentu yang
ditampilkan dari permintaan API
list
. Filter dapat memilih deret waktu berdasarkan project, grup, properti resource yang dipantau, dan properti metrik data. Untuk mengetahui informasi dan contoh selengkapnya, lihat Mengambil data deret waktu.
Tetapkan resource ke
Group
berdasarkan properti resource dan project tempat resource tersebut berada. Untuk mengetahui informasi dan contoh selengkapnya, lihat Menentukan keanggotaan grup.Pilih resource dalam grup berdasarkan properti resource. Untuk informasi dan contoh selengkapnya, lihat Mencantumkan anggota grup.
Mencantumkan jenis metrik tertentu. Untuk informasi dan contoh selengkapnya, lihat Mencantumkan deskripsi metrik.
Mencantumkan jenis resource tertentu yang dimonitor. Untuk informasi dan contoh selengkapnya, lihat Mencantumkan deskripsi resource yang dipantau.
Pemilih filter
Filter terdiri dari minimal satu pemilih, yang merupakan kata kunci filter. Contoh berikut mengilustrasikan berbagai pemilih:
-
project
: Cocok jika metrik project yang ditentukan terlihat oleh project cakupan cakupan metrik yang disebutkan dalam parametername
.Gunakan pemilih
project
jika project Google Cloud dapat melihat metrik beberapa project Google Cloud atau akun AWS dan Anda hanya menginginkan metrik untuk satu project. Misalnya, jika cakupan metrik untukProject-A
menyertakanProject-B
, pencocokan akan terjadi saatname
memiliki nilaiProject-A
dan Anda menggunakan filter berikut:project = "Project-B"
-
group
: Mencocokkan resource yang termasuk dalam satuGroup
.Filter berikut cocok dengan grup dengan ID
group-id
:group.id = "group-id"
-
resource
: Mencocokkan resource yang dimonitor dari jenis tertentu atau memiliki nilai label tertentu.-
Filter berikut cocok dengan semua resource yang dipantau yang merupakan instance virtual machine (VM) Compute Engine:
resource.type = "gce_instance"
-
Filter berikut cocok dengan semua resource yang zonanya dimulai dengan
europe-
:resource.labels.zone = starts_with("europe-")
-
-
metric
: Mencocokkan jenis metrik atau deret waktu tertentu dengan label tertentu yang cocok dengan nilai tertentu.-
Filter berikut cocok dengan jenis metrik tertentu:
metric.type = "compute.googleapis.com/instance/cpu/usage_time"
-
Filter berikut mencocokkan deret waktu dengan label bernama
instance_name
, yang nilainya diawali dengangke-hipster
ataugke-nginx
:metric.labels.instance_name = monitoring.regex.full_match("gke-(hipster|nginx).*")
-
Tabel berikut menunjukkan pemilih yang diizinkan dalam filter berdasarkan panggilan Monitoring API:
Tujuan filter | Pemilih project |
Pemilih group |
Pemilih resource |
Pemilih metric |
---|---|---|---|---|
Menentukan grup | ya | ya* | ||
Membuat daftar anggota grup | ya | ya | ||
Mencantumkan deret waktu | ya | ya | ya | ya † |
Membuat daftar deskriptor metrik | ya | ya | ||
Mencantumkan deskriptor resource yang dimonitor | ya |
† Saat mencantumkan deret waktu, Anda harus menentukan tepat satu jenis metrik.
Bagian berikut menunjukkan contoh penggunaan umum filter pemantauan. Lihat Sintaksis filter untuk diskusi lengkap tentang objek dan operator filter yang tersedia.
Mengambil data deret waktu
Metode:
projects.timeSeries.list
Objek filter:
project
, group.id
, resource.type
, resource.labels.[KEY]
, metric.type
,
metric.labels.[KEY]
Deret waktu adalah daftar titik data berstempel waktu dari jenis metrik dari resource tertentu yang dimonitor. Untuk mengetahui detailnya, lihat Model metrik. Jenis metrik ditentukan oleh deskripsi metrik, dan resource yang dimonitor ditentukan oleh deskripsi resource yang dimonitor.
Filter yang ditentukan ke metode timeSeries.list
harus menyertakan pemilih metric
, dan pemilih tersebut harus menentukan tepat satu jenis metrik:
- Untuk menampilkan semua deret waktu untuk jenis metrik tertentu:
metric.type = "compute.googleapis.com/instance/cpu/usage_time"
Untuk menampilkan semua deret waktu untuk grup tertentu. Pemilih
group
hanya berfungsi dengan data deret waktu yang diselaraskan; lihat Pemilih grup untuk mengetahui informasi selengkapnya:metric.type = "compute.googleapis.com/instance/cpu/usage_time" AND group.id = "2468013579"
Untuk menampilkan semua deret waktu dari instance Compute Engine tertentu, gunakan filter berikut:
metric.type = "compute.googleapis.com/instance/cpu/usage_time" AND metric.labels.instance_name = "my-instance-name"
Menampilkan semua deret waktu dari instance Compute Engine yang namanya dimulai dengan
frontend-
, gunakan filter berikut:metric.type = "compute.googleapis.com/instance/cpu/usage_time" AND metric.labels.instance_name = starts_with("frontend-")
Menampilkan semua deret waktu dari instance Compute Engine yang namanya dimulai dengan
gke-hipster
ataugke-nginx
, gunakan filter berikut:metric.type = "compute.googleapis.com/instance/cpu/usage_time" AND metric.labels.instance_name = monitoring.regex.full_match("^gke-(hipster|nginx).*")
Menentukan keanggotaan grup
Metode:
projects.groups
Objek filter: project
, resource.type
, resource.labels.key
,
metadata.system_labels.[KEY]
, metadata.user_labels.[KEY]
Grup dapat berisi berapa pun resource, seperti yang ditentukan oleh filter. Keanggotaan grup bersifat dinamis; lebih banyak atau lebih sedikit resource mungkin cocok dengan filter setiap kali filter dievaluasi. Parameter name
dalam
objek Group
menentukan grup dan
project cakupan cakupan metrikmetrics-scope-concept.
Jika pemilih project
digunakan dalam filter, pemilih tersebut harus menentukan project yang metriknya terlihat oleh project cakupan.
resource.type = "gce_instance" AND resource.labels.zone = starts_with("europe-")
Mencantumkan anggota grup
Metode:
projects.groups.members.list
Objek filter: project
, resource.type
, resource.labels.[KEY]
Gunakan filter untuk membatasi anggota grup yang Anda ambil. Parameter name
menentukan project cakupan cakupan metrik dan grup yang ditentukan dalam project tersebut. Jika pemilih project
digunakan dalam filter, pemilih tersebut harus menentukan project yang metriknya terlihat oleh project cakupan.
- Untuk menampilkan daftar semua resource topik Pub/Sub yang termasuk dalam project
my-project
, gunakan filter berikut:project = "my-project" AND resource.type = "pubsub_topic"
Mencantumkan deskriptor metrik
Metode:
projects.metricDescriptors.list
Objek filter: project
, metric.type
Gunakan filter untuk membatasi deskripsi metrik yang Anda ambil:
- Untuk hanya menampilkan deskripsi metrik Compute Engine,
gunakan filter berikut:
metric.type = starts_with("compute.googleapis.com")
Lihat Daftar metrik untuk mengetahui daftar lengkap jenis metrik yang tersedia. Untuk mengetahui ringkasan cara penamaan metrik, lihat Konvensi penamaan metrik.
Mencantumkan deskripsi resource yang dimonitor
Metode:
projects.monitoredResourceDescriptors.list
Filter objek: resource.type
Gunakan filter untuk membatasi deskripsi resource yang dipantau yang Anda ambil:
- Untuk hanya mengambil deskripsi resource yang dipantau Pub/Sub,
gunakan filter berikut:
resource.type = starts_with("pubsub")
Lihat Daftar resource yang dimonitor untuk mengetahui daftar lengkap jenis resource yang dimonitor yang ditentukan oleh Monitoring.
Contoh
Dalam contoh pemfilteran, kami menggunakan deskripsi metrik, deskripsi resource yang dipantau, dan instance virtual machine berikut, yang disederhanakan untuk ilustrasi:
# Metric descriptor: { "name": "projects/my-project-id/metricDescriptors/compute.googleapis.com%2Finstance%2Fdisk%2Fread_bytes_count" "type": "compute.googleapis.com/instance/disk/read_bytes_count", "labels": [ { "key": "device_name", "description": "The name of the disk device." } ] } # Monitored resource descriptor: { "name": "monitoredResourceDescriptors/gce_instance" "type": "gce_instance", "labels": [ { "key": "instance_id", "description": "The instance ID provide by Google Compute Engine." }, { "key": "zone", "description": "The Google Cloud Platform zone hosting the instance." } ] } # Resource descriptor for a virtual machine instance. { "type": "gce_instance", "instance_id": "1472038649266883453", "zone": "us-east-1b", "disks": [ "log_partition" ], "machine_type": "n1-standard-2", "tags": { "environment": "bleeding-edge", "role": "frobulator" }, "project_id": "my-project-id" }
Contoh pengambilan metrik
Untuk meminta penggunaan bandwidth pembacaan disk untuk semua instance dan semua perangkat, tentukan filter sebagai berikut. Filter ini menampilkan, untuk setiap instance, deret waktu terpisah yang melaporkan bandwidth baca untuk setiap perangkat:
metric.type = "compute.googleapis.com/instance/disk/read_bytes_count"
Untuk menyaring permintaan guna membuat kueri bandwidth baca hanya untuk perangkat disk yang dikenal sebagai "log_partition" di setiap instance, tentukan filter sebagai berikut. Filter ini menampilkan, untuk setiap instance, maksimal satu deret waktu, bergantung pada apakah perangkat dengan nama tersebut ada di instance tersebut:
metric.type = "compute.googleapis.com/instance/disk/read_bytes_count" AND metric.labels.device_name = "log_partition"
Untuk membatasi permintaan ke satu instance, tentukan instance tersebut:
resource.type = "gce_instance" AND resource.labels.instance_id = "1472038649266883453" AND metric.type = "compute.googleapis.com/instance/disk/read_bytes_count" AND metric.labels.device_name = "log_partition"
Memfilter dengan grup
Contoh berikut mengilustrasikan penggunaan pemilih grup dalam filter untuk membatasi resource yang dipantau ke resource dalam grup tertentu. Lihat Selektor resource untuk definisi grup untuk mengetahui informasi tentang pemilih yang digunakan untuk menentukan keanggotaan grup.
{ "name": "projects/my-test-project/groups/024681012", "display_name": "My Redis Cluster", "filter": "metadata.user_labels.role=redis" }
Dalam panggilan ke metode projects.timeSeries.list
, filter berikut meminta penggunaan bandwidth baca disk untuk semua instance Compute Engine dalam grup tertentu. Grup harus ditentukan dalam project cakupan cakupan metrik yang ditentukan dalam parameter name
metode:
resource.type = "gce_instance" AND group.id = "024681012" AND metric.type = "compute.googleapis.com/instance/disk/read_bytes_count"
Referensi: sintaksis filter
Untuk mengetahui ringkasan filter beserta contohnya, lihat Menggunakan filter.
Filter pemantauan adalah string yang terdiri dari maksimal empat jenis pemilih:
<monitoring_filter> ::= <project_selector> AND <group_selector> AND <resource_selector> AND <metric_selector>
Filter cocok dengan item jika semua pemilih yang disertakan cocok dengan item tersebut.
Seperti yang dijelaskan di bagian berikut, beberapa pemilih dapat memiliki beberapa
perbandingan yang digabungkan dengan AND
atau OR
. Urutan pemilih dalam
filter tidak penting, tetapi perbandingan untuk pemilih yang berbeda tidak boleh
tercampur.
Bergantung pada tujuan filter, pemilih tertentu mungkin diperlukan, opsional, atau dilarang. Misalnya, filter yang digunakan untuk mencantumkan deret waktu harus berisi pemilih metrik. Namun, filter yang menentukan resource dalam grup tidak dapat berisi pemilih metrik, karena grup tidak berisi jenis metrik atau deret waktu.
Perbandingan
Filter dan pemilihnya dibuat dari perbandingan. Setiap perbandingan memiliki bentuk berikut:
-
[OBJECT]: memilih nilai yang akan diuji; salah satu dari berikut:
project group.id metric.type metric.labels.[KEY] resource.type resource.labels.[KEY] metadata.system_labels.[KEY] metadata.user_labels.[KEYSTRING]
[KEY] adalah nama, seperti
zone
atauinstance_id
.[KEYSTRING] dapat berupa nama, tetapi jika berisi karakter khusus, nama tersebut harus diapit tanda kutip (
"
). -
[OPERATOR]: operator perbandingan; salah satu dari yang berikut:
= # equality (case-sensitive) > < >= <= # numeric ordering != # not equal : # "has" substring match and test for key (case-sensitive)
-
[VALUE]: nilai literal atau panggilan fungsi bawaan; salah satu dari hal berikut:
<string> # "a Unicode string". Don't use apostrophes (`'`) to quote strings. <bool> # true or false <number> # 0, -2, 123456, 3.14156 <function> # operators on the right side of '=' or '!=': # starts_with(<string>) # ends_with(<string>) # has_substring(<string> [, ignore_case=false]) # one_of(<string>,...,<string>) for up to 100 strings # monitoring.regex.full_match(<RE2-string>)
Kecuali jika digunakan dalam metode
timeSeries.list
, filterhas_substring
menggunakan argumen kedua opsional, yang menentukan apakah pencocokan mengabaikan huruf besar/kecil atau tidak. Nilai defaultnya adalahfalse
, sehingga kecocokan default peka huruf besar/kecil:- Peka huruf besar/kecil:
display_name=has_substring("Demo")
- Peka huruf besar/kecil:
display_name=has_substring("Demo", false)
- Tidak peka huruf besar/kecil:
display_name=has_substring("Demo", true)
Saat digunakan dalam metode
timeSeries.list
, hanya formulirhas_substring(<string>)
yang didukung.Filter
monitoring.regex.full_match
menggunakan string ekspresi reguler dalam sintaksis RE2. - Peka huruf besar/kecil:
Anda dapat menggunakan operator berikut untuk mengelompokkan atau mengubah perbandingan. OR
memiliki
prioritas yang lebih tinggi daripada AND
. Operator harus ditulis dalam huruf besar:
(...) # grouping comparisons AND # conjunction (optional but recommended) OR # disjunction
Operator AND
dapat dihilangkan di antara operator, tetapi akan lebih jelas dan
kurang rentan terhadap error jika disertakan.
Perbandingan x = one_of("a", "b", "c")
setara dengan hal berikut:
(x = "a" OR x = "b" OR x = "c")
NOT
,
sebelum perbandingan, tetapi tidak dengan operator exists (:
) atau sebelum
ekspresi dalam tanda kurung:
NOT # negates the following comparison
Pemilih filter
Gunakan pemilih untuk membatasi pilihan filter ke item tertentu.
Di bagian berikut, tanda kurung kurawal digunakan untuk menunjukkan pengulangan. Misalnya,
notasi <x> {OR <y>}
berarti Anda dapat menulis salah satu
hal berikut:
<x> <x> OR <y> <x> OR <y> OR <y> <x> OR <y> OR <y> OR <y> ...
Pemilih project
Pemilih project membatasi pemilihan filter untuk item yang termasuk dalam satu project atau salah satu dari sekumpulan project. Setiap project dapat ditentukan berdasarkan ID atau nomornya:
<project_selector> ::= project '=' (<number> | <string>) {OR project '=' (<number> | <string>)}
Jika pemilih project Anda memiliki lebih dari satu perbandingan, sertakan seluruh pemilih dalam tanda kurung untuk keterbacaan yang lebih baik. Contoh:
(project=12345 OR project="my-project-id") AND resource.type="gce_instance"
Pemilih grup
Pemilih grup membatasi pemilihan filter untuk item yang termasuk dalam satu grup:
<group_selector> ::= group.id '=' <string>
Misalnya, filter berikut dapat digunakan untuk mengambil deret waktu dari setiap instance VM dalam grup:
group.id = 12345 AND resource.type = "gce_instance" AND metric.type = "compute.googleapis.com/instance/disk/read_bytes_count"
Pemilih grup hanya diizinkan dalam filter yang diteruskan ke metode projects.timeSeries.list
. Selain itu,
pemilihan grup memerlukan data yang diselaraskan; yaitu, panggilan projects.timeSeries.list
harus menyertakan nilai untuk kolom
perSeriesAligner
dan alignmentPeriod
. Hal ini karena keanggotaan grup
itu sendiri adalah jenis deret waktu yang harus digabungkan dengan data metrik, dan
menyediakan parameter perataan memberi Anda kontrol atas cara penggabungan tersebut terjadi.
Untuk informasi selengkapnya tentang parameter perataan, lihat
Menggabungkan data.
Pemilih resource
Pemilih aset membatasi pemilihan filter ke resource—atau item yang terkait dengan resource—yang memiliki jenis resource atau nilai label tertentu:
<resource_selector> ::= <resource_type_expression> | <resource_label_expression> | <resource_type_expression> AND <resource_label_expression> <resource_type_expression> ::= resource.type '=' <string> | resource.type ':' <string> | resource.type '=' starts_with '(' <string>')' | resource.type '=' ends_with '(' <string> ')' <r_label_comparison> ::= resource.labels.[KEY] '=' (<string> | <bool>) | resource.labels.[KEY] ':' <string> | resource.labels.[KEY] '=' (starts_with | ends_with) '(' <string> ')' | resource.labels.[KEY] ('=' | '>' | '<' | '>=' | '<=') <number> <resource_label_expression> ::= <r_label_comparison> {AND <r_label_comparison>} | <r_label_comparison> {OR <r_label_comparison>}
Jika Anda menggunakan lebih dari satu <r_label_comparison>
dalam pemilih, masukkan semuanya dalam tanda kurung agar lebih mudah dibaca.
Misalnya, filter berikut dapat digunakan untuk menentukan grup yang menyertakan semua instance VM Compute Engine di Amerika Serikat dan Eropa.
resource.type = "gce_instance" AND (resource.labels.zone = starts_with("us-") OR resource.labels.zone = starts_with("europe-"))
Pemilih resource untuk definisi grup
Pemilih resource yang digunakan untuk menentukan keanggotaan grup menggunakan ekstensi ke sintaksis <resource_selector>
:
Anda menyertakan filter berdasarkan nilai label sistem metadata,
metadata.system_labels.[KEY]
, dan label pengguna metadata,metadata.user_labels.[KEYSTRING]
. Sebaiknya kutip kunci untukmetadata.user_labels
karena kunci tersebut dapat berisi karakter khusus seperti tanda hubung.Jika pemilih berisi filter metadata dan filter resource, Anda harus menggabungkannya dengan
AND
; Anda tidak dapat menggunakanOR
. Misalnya, diagram dengan pemilih berikut menampilkan penggunaan CPU untuk semua instance VM dengan jenis mesine2-medium
ataue2-micro
:metric.type="compute.googleapis.com/instance/cpu/utilization" resource.type="gce_instance" AND (metadata.system_labels."machine_type"="e2-medium" OR metadata.system_labels."machine_type"="e2-micro")
Anda dapat menggunakan operator tidak sama dengan (
!=
) untuk membandingkan jenis resource, label resource, dan metadata. Operator ini dapat digunakan saat membandingkan string, angka, Boolean, atau fungsi substring. Misalnya,resource.type!=starts_with("gce")
bernilai benar jika jenis resource tidak dimulai dengan"gce"
.Anda dapat menggunakan satu operator
NOT
sebelum perbandingan resource. Misalnya,NOT resource.labels.zone="europe"
bernilai benar jika zona resource tidak menyertakan"europe"
. Anda tidak dapat menggunakanNOT
sebelum operator ada (:
) atau ekspresi dalam tanda kurung.Anda dapat menggunakan operator "exists" (
:
) untuk menguji keberadaan kunci. Misalnya, perbandinganresource.labels:zone
bernilai benar jika kunci labelzone
ada dalam resource.
Misalnya, salah satu kunci metadata resource platform untuk instance VM adalah
spot_instance
. Pemilih filter berikut memilih instance yang merupakan instance spot:
resource.type = "gce_instance" AND metadata.system_labels.spot_instance = true
Pemilih metrik
Pemilih metrik menentukan metrik atau deskripsi metrik tertentu dengan membatasi
jenis metrik dan label metrik. Saat digunakan dengan
metode projects.timeSeries.list
, pemilih metrik harus menentukan satu jenis metrik:
<metric_selector> ::= <metric_name_expression> [AND <metric_label_expression>] <metric_name_expression> ::= metric.type '=' <string> | metric.type ':' <string> | metric.type '=' starts_with '(' <string> ')' | metric.type '=' ends_with '(' <string> ')' <metric_label_comparison> ::= metric.labels.[KEY] '=' <string> | <bool> | metric.labels.[KEY] ':' <string> | metric.labels.[KEY] '=' starts_with '(' <string> ')' | metric.labels.[KEY] '=' ends_with '(' <string> ')' | metric.labels.[KEY] ('=' | '>' | '<' | '>=' | '<=') <number> <metric_label_expression> ::= <metric_label_comparison> {[AND] <metric_label_comparison>} | <metric_label_comparison> {OR <metric_label_comparison>}
Misalnya, filter berikut dapat digunakan untuk mengambil deret waktu untuk instance database tertentu:
metric.type = "cloudsql.googleapis.com/database/state" AND (metric.labels.resource_type = "instance" AND metric.labels.resource_id = "abc-123456")