Kubernetes arhitektura se zasniva na konceptu klijent-server. Kubernetes klaster se sastoji od najmanje jednog glavnog i više radnih čvorišta odnosno takozvanih „nodova“.
Takođe je moguće imati multi-master podešavanje za visoku dostupnost, ali podrazumevano postoji jedan glavni čvor (Master Node) koji deluje i kao kontrolni čvor i tačka kontakta.
U ovom delu, kao i u svim ostalim tekstovima ćemo koristiti za Kubernetes izvorne termine na engleskom, kako bi čitaoci ili oni koji se budu upustili u Kubernetes posao, lakše razumeli tehničke specifikacije i objašnjenja. Tako ćemo koristiti termine poput Master Nodes, Worker Nodes, Slave Nodes itd ..
Svakako ćemo objasniti šta svaki od ovih termina znači i gde se nalazi u arhitekturi.
Sama potreba da našu kompleksnu aplikaciju učinimo visoko dostupnom, skalabilnom, prenosivom i primenljivom u malim modulima nezavisno dovela je do rođenja Kubernetesa
Sada ćemo videti kakva je Kubernetes arhitektura i koje su ključne komponente.
Arhitektura Kubernetes klastera
Osnovna arhitektura Kubernetes klastera ima dva glavna čvora:
- Master Node (glavno čvorište)
- Worker Node ili Slave Node (radna čvorišta i podređena čvorišta)
Ako pogledate zvaničnu dokumentaciju Kubernetesa, postaje prilično teško pohvatati koncepte za njih.
Zato ćemo pokušati da pojednostavimo glavne principe arhitekture od kojih možete početi sa radom.
Hajde da prvo razumemo kako funkcionišu working i slave nodovi (radna i podređena čvorišta) i koje su ključne komponente working nodova (radnih čvorišta).
Worker Node u Kubernetes klasteru:
Master Node
Glavni čvor, odnosno Master Node, je takođe poznat kao kontrolna oblast koja je odgovorna za efikasno upravljanje radnim/podređenim čvorovima (worker/slave nodovima).
Oni stupaju u interakciju sa radnim čvorištem za…
- Zakazivanje Pod-ova
- Nadzor radnih nodova ili Pod-ova
- Pokretanje ili restartovanje Pod-ova
- Upravljanje novim radnim nodovima koji se pridružuju klasteru
Procesi Master Noda:
Svaki Master node u K8s klasteru pokreće sledeće ključne procese.
Dakle, šta god želeli da uradite ..
- da rasporedite novu aplikaciju
- da zakažete novi Pod
- kreirate neki novi servis
- postavite novi upit za dostupnost vašeg worker noda
Moraćete da uputite zahtev API serveru glavnog čvora (Master noda) koji zauzvrat potvrđuje vaše zahteve pre nego što dobijete pristup procesima u radnim čvorovima.
Kube-apiserver je dizajniran da skalira horizontalno — tj. skalira se postavljanjem više instanci. Možete pokrenuti nekoliko instanci kube-apiserver-a i balansirati saobraćaj između tih instanci.
——-
kube-scheduler u Kubernetes Master Nodu:
Svaki put kada K8s administrator/programer želi da zakažete novi Pod na radnom čvoru, potrebno je da pošalje zahtev glavnom API serveru koji će zauzvrat uputiti poziv procesu kube-scheduler-a.
Kube-scheduler će ovde pametno odlučiti na koji radni čvor treba da se postavi ovaj Pod.
Dakle, možemo da definišemo kube-scheduler kao:
Ključna komponenta kontrolne oblasti koja prati novostvorene Pod-ove bez dodeljenog radnog čvora i bira radni čvor na kome će biti zakazani i pokrenuti…
Ili kao odluku na koji radni čvor (worker node) treba da se prilagodi novokreirani Pod na osnovu dostupnosti nivoa resursa svakog noda, pa tako kube-scheduler vrši upit na nivou resursa i donosi odluke o planiranju, odnosno zakazivanju.
Pravo izvršenje odluke na nivou zakazivanja se vrši kubelet procesom u datom radnom čvoru
Ključni i odlučujući faktori u vezi sa rasporedom Pod-ova uključuju:
- Individualni i kolektivni zahtevi za resursima
- Ograničenja hardvera, softvera ili politike
- Specifikacije afiniteta čvorova i anti-afiniteta,
- Lokalitet podataka, interferencija između radnih opterećenja i rokova.
Razumećemo ova navedena ograničenja i politike kasnije dok budemo napredovali da detaljnije pokrijemo Kubernetes.
kube-controller-manager(kubectl):
Jedan od kritičnih procesa na Master nodu koji prati status svih grešaka na nivou radnog čvora. Pomno prati događaj kao što je
- Pad ili nedostupnost bilo kog modula u radnom čvoru (Worker Nodu) …
tako da u tom smislu zahteva od kube-scheduler-a da ponovo pokrene ili ponovo zakaže sve pale ili neuspele Pod-ove, nakon što otkrije takav događaj.
Ova komponenta glavnog kontrolnog planera ima sledeće tipove kontrolera:
- Kontroler noda: Odgovoran je da reaguje kada se bilo koji worker node pokvari
- Kontroler replika: obezbeđuje da se uvek vodi računa o zahtevu i da se održi tačan broj replika bilo koje količine Pod-ova
- Kontroler krajnjih tačaka (Endpoint): Popunjava objekat do Entrypoint-a, odnosno pridružuje Servise i Pod-ove
- Servisni nalog i kontroleri tokena: Kreiranje podrazumevanog naloga i API pristupnog tokena za nova pristupna imena kreirana u worker nodu.
Etcd u Kubernetes Master Nodu:
etcd u glavnoj kontrolnoj oblasti je odgovoran za skladištenje svake vrste promena na nivou klastera u obliku parova ključ-vrednost (key-value)
Može se slobodno reći da je kao mozak Kubernetes klastera koji vodi evidenciju o svim detaljima i promenama koje se dešavaju u klasteru.
Na primer, ako se bilo koji Pod sruši u worker nodu i mora se ponovo rasporediti, isti se čuva u etcd kao par ključ-vrednost, a takođe se evidentira i događaj koji se ponovo zakazuje za Pod.
Dakle, podaci se odnose na neka od ključnih pitanja kao što su:
– Koje vrste resursa su dostupne u nodu?
– Da li se stanje klastera promenilo zbog kvara nekog noda?
– Da li je na klasteru sve u redu?
Tako da svi podaci koji se čuvaju ovde se zapravo čuvaju kako bi se osiguralo da je naš Kubernetes klaster „svestan“ istog da bi preduzeo bolje radnje u skladu sa izvršnom radnjom.
Beleška!
Podaci na nivou aplikacije kao što je DB se ne čuvaju u etcd-u.
Kubernetes komponente:
Sada kada smo razumeli arhitektonske procese Kubernetes klastera, vreme je da pogledamo neke od ključnih komponenti Kubernetesa koje pomažu u orkestraciji kontejnera na nivou proizvoda.
Ovde ćemo samo navesti te komponente i ući ćemo u detalje svake od njih u drugom delu koji ćemo uskoro pripremiti.
U drugom delu ćemo pričati o ključnim komponentama i konceptima Kubernetesa
Neke od ključnih komponenti K8s su:
Pods:
Services & Ingress:
ConfigMaps:
Secrets:
Volume:
Deployments:
Statefulsets:
Beleška:
Master Node – Glavno čvorište
Node – jedan od glavnih delova Kubernetesa
Worker node – radno čvorište
Worker slave – podređeno čvorište
Pods – najmanje jedinice u Kubernets arhitekturi
etcd – skladištenje podataka u Klasteru
kube-controller-manager – vrste kontrolera
kube-scheduler – zakazivanje i planiranje u Kalsteru
kube-proxy – je mrežni proksi koji radi na svakom čvoru u vašem klasteru
kubelet – je primarni „agent čvora“ koji radi na svakom čvoru
Container Runtime – dužina vremena pokretanja kontejenra