Node Problem Detector adalah library open source yang memantau kondisi node dan mendeteksi masalah node umum, seperti masalah hardware, kernel, atau runtime container. Di Google Distributed Cloud, layanan ini berjalan sebagai layanan systemd di setiap node.
Mulai dari rilis Google Distributed Cloud 1.10.0, Pendeteksi Masalah Node diaktifkan secara default.
Jika Anda memerlukan bantuan tambahan, hubungi Cloud Customer Care. Anda juga dapat melihat bagian Mendapatkan dukungan untuk mengetahui informasi selengkapnya tentang sumber dukungan, termasuk yang berikut:
- Persyaratan untuk membuka kasus dukungan.
- Alat untuk membantu Anda memecahkan masalah, seperti konfigurasi lingkungan, log, dan metrik.
- Komponen yang didukung.
Masalah apa yang dideteksinya?
Node Problem Detector dapat mendeteksi jenis masalah berikut:
- Masalah runtime container, seperti daemon runtime yang tidak responsif
- Masalah hardware, seperti kegagalan CPU, memori, atau disk
- Masalah kernel, seperti kondisi kebuntuan kernel atau sistem file yang rusak
Proses ini berjalan di node dan melaporkan masalah ke server Kubernetes API sebagai NodeCondition
atau sebagai Event
.
NodeCondition
adalah masalah yang membuat node tidak dapat menjalankan pod, sedangkan
Event
adalah masalah sementara yang memiliki efek terbatas pada pod, tetapi
cukup penting untuk dilaporkan.
Tabel berikut menjelaskan NodeConditions
yang ditemukan oleh Node Problem Detector dan apakah NodeConditions
tersebut dapat diperbaiki secara otomatis atau tidak:
Kondisi | Alasan | Perbaikan otomatis didukung1 |
---|---|---|
KernelDeadlock |
Proses kernel macet menunggu proses kernel lain untuk melepaskan resource yang diperlukan. | Tidak |
ReadonlyFilesystem |
Cluster tidak dapat menulis ke sistem file karena masalah, seperti disk penuh. | Tidak |
FrequentKubeletRestart |
kubelet sering dimulai ulang, sehingga mencegah node menjalankan pod secara efektif. | Tidak |
FrequentDockerRestart |
Daemon Docker telah dimulai ulang lebih dari 5 kali dalam 20 menit. | Tidak |
FrequentContainerdRestart |
Runtime container telah dimulai ulang lebih dari 5 kali dalam 20 menit. | Tidak |
FrequentUnregisterNetDevice |
Node sering mengalami pembatalan pendaftaran perangkat jaringan. | Tidak |
KubeletUnhealthy |
Node tidak berfungsi dengan baik atau tidak merespons bidang kontrol. | Tidak |
ContainerRuntimeUnhealthy |
Runtime container tidak berfungsi dengan benar, sehingga mencegah pod berjalan atau dijadwalkan di node. | Tidak |
CorruptDockerOverlay2 |
Ada masalah atau inkonsistensi sistem file dalam direktori driver penyimpanan overlay2 Docker. | Tidak |
OrphanContainers 2 |
Pod khusus untuk penampung telah dihapus, tetapi penampung yang sesuai masih ada di node. | Tidak |
FailedCgroupRemoval 2 |
Beberapa cgroup dalam status dibekukan. | Ya |
1 Untuk versi 1.32 dan yang lebih baru, kemampuan untuk memperbaiki masalah yang terdeteksi secara otomatis didukung untuk kondisi tertentu.
2 Didukung untuk versi 1.32 dan yang lebih baru.
Beberapa contoh jenis Events
yang dilaporkan oleh Node Problem Detector adalah:
Warning TaskHung node/vm-worker-1-user-a12fabb4a99cb92-ddfce8832fd90f6f.lab.anthos kernel: task docker:7 blocked for more than 300 seconds.
Warning KernelOops node/vm-worker-1-user-a12fabb4a99cb92-ddfce8832fd90f6f.lab.anthos kernel: BUG: unable to handle kernel NULL pointer dereference at 00x0.
Masalah apa yang diperbaiki?
Mulai versi 1.32, saat Node Problem Detector menemukan NodeConditions
tertentu, alat ini dapat
memperbaiki masalah yang sesuai secara otomatis di node. Mulai versi 1.32,
NodeCondition
yang mendukung perbaikan otomatis hanyalah
FailedCgroupRemoval
.
Cara melihat masalah yang terdeteksi
Jalankan perintah kubectl describe
berikut untuk mencari NodeConditions
dan
Events
:
kubectl describe node NODE_NAME \
--kubeconfig=KUBECONFIG
Ganti kode berikut:
NODE_NAME
: nama node yang Anda periksa.KUBECONFIG
: jalur file kubeconfig cluster.
Cara mengaktifkan dan menonaktifkan Pendeteksi Masalah Node
Secara default, Node Problem Detector diaktifkan, tetapi dapat dinonaktifkan di resource ConfigMap node-problem-detector-config
. Kecuali jika Anda menonaktifkannya secara eksplisit, Node Problem Detector terus memantau node untuk kondisi tertentu yang menunjukkan masalah pada node.
Untuk menonaktifkan Node Problem Detector pada cluster tertentu, gunakan langkah-langkah berikut:
Edit resource ConfigMap
node-problem-detector-config
:kubectl edit configmap node-problem-detector-config \ --kubeconfig=KUBECONFIG \ --namespace=CLUSTER_NAMESPACE
Ganti kode berikut:
KUBECONFIG
: jalur file kubeconfig cluster.CLUSTER_NAMESPACE
: namespace cluster tempat Anda ingin mengaktifkan Node Problem Detector.
Perintah ini akan otomatis memulai editor teks tempat Anda dapat mengedit resource
node-problem-detector-config
.Tetapkan
data.enabled
kefalse
dalam definisi resourcenode-problem-detector-config
.apiVersion: v1 kind: ConfigMap metadata: creationTimestamp: "2025-04-19T21:36:44Z" name: node-problem-detector-config ... data: enabled: "false"
Awalnya, ConfigMap
node-problem-detector-config
tidak memiliki kolomdata
, jadi Anda mungkin perlu menambahkannya.Untuk memperbarui resource, simpan perubahan Anda dan tutup editor.
Untuk mengaktifkan kembali Pendeteksi Masalah Node, lakukan langkah-langkah sebelumnya, tetapi tetapkan data.enabled
ke
true
dalam definisi resource node-problem-detector-config
.
Cara mengaktifkan dan menonaktifkan perbaikan otomatis
Mulai versi 1.32, Pendeteksi Masalah Node memeriksa NodeConditions
tertentu dan
secara otomatis memperbaiki masalah yang sesuai di node. Secara default,
perbaikan otomatis diaktifkan untuk NodeConditions
yang didukung, tetapi dapat
dinonaktifkan di resource ConfigMap node-problem-detector-config
.
Untuk menonaktifkan perilaku perbaikan otomatis pada cluster tertentu, gunakan langkah-langkah berikut:
Edit resource ConfigMap
node-problem-detector-config
:kubectl edit configmap node-problem-detector-config \ --kubeconfig=KUBECONFIG \ --namespace=CLUSTER_NAMESPACE
Ganti kode berikut:
KUBECONFIG
: jalur file kubeconfig cluster.CLUSTER_NAMESPACE
: namespace cluster tempat Anda ingin mengaktifkan Node Problem Detector.
Perintah ini akan otomatis memulai editor teks tempat Anda dapat mengedit resource
node-problem-detector-config
.Tetapkan
data.check-only
ketrue
dalam definisi resourcenode-problem-detector-config
.apiVersion: v1 kind: ConfigMap metadata: creationTimestamp: "2025-04-19T21:36:44Z" name: node-problem-detector-config ... data: enabled: "true" check-only: "true"
Awalnya, ConfigMap
node-problem-detector-config
tidak memiliki kolomdata
, jadi Anda mungkin perlu menambahkannya. Menyetelcheck-only
ke"true"
akan menonaktifkan perbaikan otomatis untuk semua kondisi yang didukung.Untuk memperbarui resource, simpan perubahan Anda dan tutup editor.
Untuk mengaktifkan kembali perbaikan otomatis untuk semua NodeConditions
yang mendukungnya, tetapkan
data.check-only
ke "false"
di ConfigMap node-problem-detector-config
.
Cara menghentikan dan memulai ulang Pendeteksi Masalah Node
Node Problem Detector berjalan sebagai layanan systemd
di setiap node. Untuk mengelola Node Problem Detector untuk node tertentu, gunakan SSH untuk mengakses node, dan jalankan perintah systemctl
berikut.
Untuk menonaktifkan Node Problem Detector, jalankan perintah berikut:
systemctl stop node-problem-detector
Untuk memulai ulang Node Problem Detector, jalankan perintah berikut:
systemctl restart node-problem-detector
Untuk memeriksa apakah Node Problem Detector berjalan di node tertentu, jalankan perintah berikut:
systemctl is-active node-problem-detector
Fitur yang tidak didukung
Google Distributed Cloud tidak mendukung penyesuaian Node Problem Detector berikut:
- Mengekspor laporan Node Problem Detector ke sistem pemantauan lain, seperti Stackdriver atau Prometheus.
- Menyesuaikan
NodeConditions
atauEvents
yang akan dicari. - Menjalankan skrip pemantauan yang ditentukan pengguna.
Langkah berikutnya
Jika Anda memerlukan bantuan tambahan, hubungi Cloud Customer Care. Anda juga dapat melihat bagian Mendapatkan dukungan untuk mengetahui informasi selengkapnya tentang sumber dukungan, termasuk yang berikut:
- Persyaratan untuk membuka kasus dukungan.
- Alat untuk membantu Anda memecahkan masalah, seperti konfigurasi lingkungan, log, dan metrik.
- Komponen yang didukung.