Dapatkan Kubernetes Ingress Log untuk Debugging

Dapatkan Kubernetes Ingress Log Untuk Debugging



Apakah Anda tahu apa itu Ingress Log Get Kubernetes untuk debugging? Masalah jaringan semakin menantang untuk didiagnosis karena penerapan tumbuh semakin besar. Tutorial ini menunjukkan cara menggunakan plugin kubectl ingress-nginx untuk men-debug akses ke aplikasi Anda melalui pengontrol masuknya. Mari kita lihat dulu definisi ingress Kubernetes yang penting untuk memahami topik utama dengan lebih baik.

Apa itu Ingress Kubernetes?

Definisi masuknya adalah 'masuk' dalam arti literal.







Di komunitas Kubernetes, itu juga benar. Trafik yang masuk ke cluster disebut ingress, sedangkan traffic yang keluar dari cluster disebut egress.




Sebagai sumber daya asli Kubernetes, ingress dapat dibandingkan dengan pod, penerapan, dll. Anda dapat mengikuti konfigurasi perutean DNS menggunakan ingress. Pengontrol masuknya adalah yang melakukan perutean. Itu dilakukan dengan membaca aturan perutean langsung dari objek masuknya yang disimpan di etcd. Tanpa masuknya Kubernetes, Anda dapat mengekspos aplikasi ke dunia luar dengan menyertakan Service Type Load Balancer dalam penerapan.



Bagaimana Cara Kerja Kubernetes Ingress?

Ada dua hal penting yang perlu Anda perjelas. Ini adalah:





Resource Ingress Kubernetes

Sumber daya ini bertugas memelihara semua aturan perutean DNS di cluster. Aturan perutean DNS ditentukan dalam sumber daya Ingress Kubernetes, sumber daya asli Kubernetes. Dengan kata lain, Anda memetakan traffic DNS eksternal ke tujuan layanan Kubernetes internal.



Pengontrol Ingress Kubernetes

Dengan mendapatkan akses ke aturan DNS yang diterapkan oleh sumber daya masuknya, pengontrol masuknya Kubernetes (Nginx/HAProxy, dll.) bertanggung jawab atas perutean.

Implementasi Ingress Controller bukanlah bawaan dari Kubernetes. Akibatnya, ini tidak bisa menjadi default cluster.

Agar aturan masuknya berfungsi, kita harus mengonfigurasi pengontrol masuknya. Ada banyak pengontrol masuknya sumber terbuka dan bisnis di pasar. Versi cluster dari server proxy web terbalik berfungsi sebagai pengontrol masuknya. Server proxy terbalik berbasis Kubernetes ini diekspos ke layanan penyeimbang muatan.

Apa itu Ingress Controller?

Program yang menjalankan cluster yang disebut Ingress Controller mengonfigurasi penyeimbang beban HTTP mengikuti sumber daya Ingress. Penyeimbang muatan dapat berupa perangkat keras yang diterapkan secara eksternal atau penyeimbang muatan cloud, atau dapat berfungsi sebagai perangkat lunak di dalam kluster. Implementasi Ingress Controller yang berbeda diperlukan untuk berbagai load balancer.

Saat menggunakan NGINX, load balancer dan ingress controller keduanya di-deploy dalam sebuah pod.

Harap perhatikan bahwa pengontrol masuknya aktif harus ada di kluster agar sumber daya Ingress berfungsi.

Pengontrol masuknya tidak diluncurkan secara otomatis dengan sebuah klaster, berbeda dengan jenis pengontrol lain yang berfungsi sebagai komponen biner kube-controller-manager.

Prasyarat:

Anda memerlukan klaster Kubernetes, dan Anda harus mengonfigurasi alat baris perintah kubectl untuk terhubung dengan klaster Anda. Anda dapat mengeluarkan perintah ke klaster Kubernetes menggunakan alat baris perintah kubectl. Aplikasi dapat digunakan, sumber daya klaster dapat diperiksa dan dikelola, dan log dapat dilihat menggunakan kubectl.

Jika saat ini Anda tidak memiliki klaster, Minikube dapat digunakan untuk membuatnya. Minikube adalah Kubernetes lokal yang bertujuan untuk mempermudah pembelajaran dan pengembangan Kubernetes.

Kubernetes dapat diakses hanya dengan satu perintah jika Anda memiliki lingkungan mesin virtual atau lingkungan wadah Docker (atau kompatibel serupa). Mari kita mulai proses langkah demi langkah sekarang:

Langkah 1: Jalankan Minikube

Dengan menggunakan alat minikube, Anda dapat menjalankan Kubernetes secara lokal. Minikube menjalankan kluster Kubernetes lokal all-in-one atau multi-node di komputer Anda untuk pekerjaan pengembangan harian atau untuk menguji Kubernetes (termasuk Windows, PC Linux, dan macOS). Berikut adalah perintah untuk memulai minikube:

> mulai minikube



Langkah 2: Aktifkan Ingress Controller

Kami akan mendemonstrasikan cara mengaktifkan pengontrol NGINX Ingress pada langkah ini. Jalankan perintah berikut:

> addon minikube memungkinkan jalan masuk



Langkah 3: Verifikasi Jika Pengontrol Ingress NGINX Berfungsi atau Tidak

Sekarang, penting untuk memverifikasi apakah pengontrol NGINX aktif atau tidak. Perintah berikut dapat digunakan untuk mengonfirmasi bahwa:

> kubectl dapatkan pod -n masuknya-nginx



Perlu diketahui bahwa Anda mungkin tidak memperhatikan bahwa pod ini berfungsi dengan baik hingga satu menit. Output ditampilkan pada gambar sebelumnya.

Langkah 4: Buat Aplikasi Hello World

Di sini, kami menggunakan perintah berikut untuk membuat penerapan:

> kubectl membuat web penerapan --gambar =gcr.io / google-samples / halo-aplikasi: 1.0



Perintah yang dijalankan dan hasilnya dilampirkan pada gambar sebelumnya. Di output, 'hello-app' dapat dilihat.

Langkah 5: Ekspos Deployment

Sekarang, kami akan menunjukkan kepada Anda perintah untuk mengekspos penerapan tertentu. Perintah tersebut disebutkan sebagai berikut:

> penerapan kubectl expose Kalsoom  - -Tipe = NodePort --Pelabuhan = 8080



Anda dapat melihat output “service/kalsoom expose” pada gambar sebelumnya.

Langkah 6: Kunjungi Layanan melalui NodePort

Ini adalah langkah penting di mana kami menunjukkan kepada Anda bagaimana Anda dapat mengunjungi layanan yang dibuat melalui NodePort. Perintah untuk mencapai tujuan ini diberikan sebagai berikut:

> layanan minikube Kalsoom  --url



Perintah beserta outputnya dilampirkan pada gambar sebelumnya.

Sekarang, alamat IP Minikube dan NodePort memudahkan untuk melihat contoh aplikasi. Anda dapat menggunakan sumber Ingress untuk mengakses aplikasi pada langkah berikut.

Langkah 7: Buat Ingress

Di sini, kami membuat Ingress yang mengirimkan lalu lintas ke Layanan Anda. Perintah tersebut disebutkan sebagai berikut:

> kubectl berlaku -f https: // k8s.io / contoh / melayani / jaringan / contoh-ingress.yaml



Seperti yang Anda lihat, perintah berhasil dijalankan.

Langkah 8: Verifikasi Alamat IP

Kami memeriksa apakah alamat IP diatur atau tidak. Untuk itu, kami menggunakan perintah yang diberikan berikut ini:

> kubectl masuk



Pada output, Anda akan melihat alamat IPv4 di kolom ADDRESS.

Kesimpulan

Ikhtisar logging NGINX Ingress Controller disediakan di artikel ini. Singkatnya, log akses dan kesalahan untuk NGINX bersama dengan log dari proses Ingress Controller yang membuat konfigurasi NGINX dan memuat ulang NGINX untuk menerapkannya, disediakan oleh NGINX Ingress Controller.