OpenShift - Arsitektur
OpenShift adalah sistem berlapis di mana setiap lapisan terikat erat dengan lapisan lain menggunakan cluster Kubernetes dan Docker. Arsitektur OpenShift dirancang sedemikian rupa sehingga dapat mendukung dan mengelola kontainer Docker, yang dihosting di atas semua lapisan menggunakan Kubernetes. Berbeda dengan OpenShift V2 versi sebelumnya, versi baru OpenShift V3 mendukung infrastruktur dalam container. Dalam model ini, Docker membantu pembuatan container ringan berbasis Linux dan Kubernetes mendukung tugas mengatur dan mengelola container di banyak host.
Komponen OpenShift
Salah satu komponen utama arsitektur OpenShift adalah mengelola infrastruktur dalam container di Kubernetes. Kubernetes bertanggung jawab atas Deployment dan Management infrastruktur. Di cluster Kubernetes mana pun, kita dapat memiliki lebih dari satu master dan beberapa node, yang memastikan tidak ada titik kegagalan dalam penyiapan.
Komponen Mesin Kubernetes Master
Etcd- Ini menyimpan informasi konfigurasi, yang dapat digunakan oleh masing-masing node di cluster. Ini adalah penyimpanan nilai kunci ketersediaan tinggi yang dapat didistribusikan di antara beberapa node. Ini seharusnya hanya dapat diakses oleh server API Kubernetes karena mungkin memiliki informasi sensitif. Ini adalah Toko nilai kunci terdistribusi yang dapat diakses oleh semua.
API Server- Kubernetes adalah server API yang menyediakan semua operasi pada cluster menggunakan API. Server API mengimplementasikan antarmuka yang berarti berbagai alat dan pustaka dapat dengan mudah berkomunikasi dengannya. Kubeconfig adalah sebuah paket bersama dengan alat sisi server yang dapat digunakan untuk komunikasi. Ini mengekspos Kubernetes API ”.
Controller Manager- Komponen ini bertanggung jawab atas sebagian besar kolektor yang mengatur status cluster dan melakukan tugas. Ini dapat dianggap sebagai daemon yang berjalan dalam loop non-terminating dan bertanggung jawab untuk mengumpulkan dan mengirim informasi ke server API. Ini berfungsi untuk mendapatkan status bersama dari cluster dan kemudian membuat perubahan untuk membawa status server saat ini ke keadaan yang diinginkan. Pengontrol kunci adalah pengontrol replikasi, pengontrol titik akhir, pengontrol namespace, dan pengontrol akun layanan. Manajer pengontrol menjalankan berbagai jenis pengontrol untuk menangani node, titik akhir, dll.
Scheduler- Ini adalah komponen kunci dari master Kubernetes. Ini adalah layanan di master yang bertanggung jawab untuk mendistribusikan beban kerja. Ini bertanggung jawab untuk melacak penggunaan beban kerja pada node cluster dan kemudian menempatkan beban kerja di sumber daya mana yang tersedia dan menerima beban kerja. Dengan kata lain, ini adalah mekanisme yang bertanggung jawab untuk mengalokasikan pod ke node yang tersedia. Penjadwal bertanggung jawab atas penggunaan beban kerja dan mengalokasikan sebuah pod ke node baru.
Komponen Kubernetes Node
Berikut adalah komponen kunci dari server Node, yang diperlukan untuk berkomunikasi dengan master Kubernetes.
Docker - Persyaratan pertama dari setiap node adalah Docker yang membantu dalam menjalankan wadah aplikasi yang dienkapsulasi dalam lingkungan operasi yang relatif terisolasi tetapi ringan.
Kubelet Service- Ini adalah layanan kecil di setiap node, yang bertanggung jawab untuk menyampaikan informasi ke dan dari layanan bidang kontrol. Ini berinteraksi dengan toko etcd untuk membaca detail konfigurasi dan nilai Wright. Ini berkomunikasi dengan komponen master untuk menerima perintah dan bekerja. Proses kubelet kemudian memikul tanggung jawab untuk menjaga status kerja dan server node. Ia mengatur aturan jaringan, penerusan port, dll.
Kubernetes Proxy Service- Ini adalah layanan proxy yang berjalan di setiap node dan membantu menyediakan layanan untuk host eksternal. Ini membantu dalam meneruskan permintaan ke penampung yang benar. Layanan Kubernetes Proxy mampu melakukan load balancing primitif. Itu memastikan bahwa lingkungan jaringan dapat diprediksi dan dapat diakses tetapi pada saat yang sama juga diisolasi. Ia mengelola pod pada node, volume, rahasia, membuat pemeriksaan kesehatan container baru, dll.
OpenShift Container Registry terintegrasi
Registri kontainer OpenShift adalah unit penyimpanan bawaan dari Red Hat, yang digunakan untuk menyimpan gambar Docker. Dengan versi terintegrasi terbaru dari OpenShift, ia telah hadir dengan antarmuka pengguna untuk melihat gambar di penyimpanan internal OpenShift. Registri ini mampu menyimpan gambar dengan tag tertentu, yang nantinya digunakan untuk membuat container darinya.
Istilah yang Sering Digunakan
Image- Gambar Kubernetes (Docker) adalah blok bangunan utama dari Infrastruktur yang Dikemaskan. Saat ini, Kubernetes hanya mendukung image Docker. Setiap container di pod memiliki image Docker yang berjalan di dalamnya. Saat mengonfigurasi pod, properti image di file konfigurasi memiliki sintaks yang sama dengan perintah Docker.
Project - Mereka dapat didefinisikan sebagai versi domain yang diganti namanya yang ada di versi OpenShift V2 sebelumnya.
Container - Mereka adalah yang dibuat setelah gambar di-deploy pada node cluster Kubernetes.
Node- Node adalah mesin yang berfungsi di cluster Kubernetes, yang juga dikenal sebagai minion untuk master. Mereka adalah unit kerja yang dapat berupa instance fisik, VM, atau cloud.
Pod- Pod adalah kumpulan container dan penyimpanannya di dalam node cluster Kubernetes. Dimungkinkan untuk membuat sebuah pod dengan banyak kontainer di dalamnya. Misalnya, menyimpan container database dan container server web di dalam pod.