Kubernetes opetusohjelma aloittelijoille: perusteet, ominaisuudet, Archirakenne

Ennen kuin aloitamme tämän Kubernetes-opetusohjelman, opimme:

Mikä on Kubernetes?

Kubernetes on Google-alustalle kehitetty kontinhallintajärjestelmä. Kubernetes auttaa hallitsemaan konttisovelluksia erilaisissa fyysisissä, virtuaalisissa ja pilviympäristöissä. Google Kubernetes on erittäin joustava konttityökalu, joka toimittaa johdonmukaisesti monimutkaisia ​​sovelluksia, jotka toimivat satojen tai tuhansien yksittäisten palvelimien ryhmissä.

Miksi tarvitset kontteja?

Nykypäivän internetin käyttäjä ei koskaan hyväksy seisokkeja. Siksi kehittäjien on löydettävä tapa suorittaa ylläpito ja päivitys keskeyttämättä palveluitaan.

Siksi kontti, joka on eristetty ympäristö. Se sisältää kaiken tarvittavan sovelluksen toimintaan. Sen avulla kehittäjän on helppo muokata ja ottaa sovelluksia käyttöön. Lisäksi säiliöstä on tullut suosituin menetelmä verkkosovellusten pakkaamiseen, käyttöönottoon ja päivittämiseen.

Mitä tehtäviä Kubernetes suorittaa?

Kubernetes on Linux-ydin, jota käytetään hajautetuissa järjestelmissä. Se auttaa sinua olemaan abstrakti solmujen (palvelinten) taustalla olevasta laitteistosta ja tarjoaa yhtenäisen käyttöliittymän sovelluksille, jotka kuluttavat jaettua resurssia.

Miksi käyttää Kubernetesia?

Kubernetes auttaa hallitsemaan pilvisovellusten ja mikropalvelujen resurssien allokointia ja liikenteen hallintaa. Se auttaa myös yksinkertaistamaan palvelukeskeisen infrastruktuurin eri puolia. Kubernetesin avulla voit varmistaa, missä ja milloin säilötyt sovellukset toimivat, ja auttaa sinua löytämään resursseja ja työkaluja, joiden kanssa haluat työskennellä.

Kubernetesin ominaisuudet

Tässä ovat Kubernetesin keskeiset ominaisuudet:

  • Automaattinen ajoitus
  • Itseparantumisominaisuudet
  • Automaattiset julkaisut ja palautukset
  • Vaakasuora skaalaus ja kuormituksen tasapainotus
  • Tarjoaa ympäristön johdonmukaisuuden kehitystä, testausta ja tuotantoa varten
  • Infrastruktuuri on löyhästi kytketty jokaiseen komponenttiin voi toimia erillisenä yksikkönä
  • Tarjoaa suuremman resurssien käytön tiheyden
  • Tarjoaa yritysvalmiita ominaisuuksia
  • Sovelluskeskeinen hallinta
  • Automaattisesti skaalautuva infrastruktuuri
  • Voit luoda ennakoitavan infrastruktuurin

Kubernetesin perusteet

Nyt tässä Kubernetes-opetusohjelmassa opimme joitain tärkeitä Kubernetesin perusteita:

  • Cluster

    Se on kokoelma isäntiä (palvelimia), joka auttaa sinua yhdistämään niiden käytettävissä olevat resurssit. Se sisältää RAM-muistin, suorittimen, RAM-muistin, levyn ja niiden laitteet käyttökelpoiseen pooliin.

  • Master

    Master on kokoelma komponentteja, jotka muodostavat Kubernetesin ohjauspaneelin. Näitä komponentteja käytetään kaikissa klusteripäätöksissä. Se sisältää sekä ajoituksen että vastaamisen klusteritapahtumiin.

  • Solmu

    Se on yksi isäntä, joka pystyy toimimaan fyysisellä tai virtuaalikone. Solmun tulee suorittaa sekä kube-proxy, minikube että kubelet, joita pidetään klusterin osana.

  • nimiavaruus

    Se on looginen klusteri tai ympäristö. Se on laajalti käytetty menetelmä, jota käytetään pääsyn rajaamiseen tai klusterin jakamiseen.

Kubernetes Archirakenne

Alla on yksityiskohtainen Kubernetes-arkkitehtuurikaavio:

Kubernetes Architecture Kaavio
Kubernetes Architecture Kaavio

Master-solmu

Pääsolmu on ensimmäinen ja elintärkein komponentti, joka vastaa Kubernetes-klusterin hallinnasta. Se on lähtöpiste kaikenlaisille hallinnollisille tehtäville. Klusterissa voi olla useampi kuin yksi pääsolmu vikasietoisuuden tarkistamiseksi.

Pääsolmussa on useita komponentteja, kuten API-palvelin, ohjaimen hallinta, ajoitus ja ETCD. Katsotaanpa niitä kaikkia.

API-palvelin: API-palvelin toimii syöttöpisteenä kaikille REST-komentoille, joita käytetään klusterin ohjaamiseen.

Scheduler

Ajastin ajoittaa tehtävät orjasolmulle. Se tallentaa jokaisen orjasolmun resurssien käyttötiedot. Se vastaa työtaakan jakamisesta.

Se auttaa myös sinua seuraamaan, kuinka työkuormaa käytetään klusterin solmuissa. Se auttaa sinua kohdistamaan työtaakan käytettävissä oleviin resursseihin ja hyväksymään työtaakan.

jne

etcd-komponentit tallentavat määritystiedot ja wright-arvot. Se kommunikoi useimpien komponenttien kanssa vastaanottaakseen komentoja ja toimiakseen. Se hallitsee myös verkkosääntöjä ja portin edelleenlähetystoimintaa.

Työntekijä-/orjasolmut

Työntekijäsolmut ovat toinen olennainen komponentti, joka sisältää kaikki tarvittavat palvelut säilöjen välisen verkottumisen hallintaan, kommunikointiin pääsolmun kanssa, jonka avulla voit määrittää resursseja ajoitetuille säilöille.

  • Kubelet: hakee Pod-kokoonpanon API-palvelimelta ja varmistaa, että kuvatut säilöt ovat käytössä.
  • Docker-säiliö: Satamatyöläinen säilö toimii kussakin työntekijäsolmussa, joka suorittaa määritetyt podit
  • Kube-välityspalvelin: Kube-välityspalvelin toimii kuormituksen tasaajana ja verkon välityspalvelimena palvelun suorittamiseksi yksittäisessä työntekijäsolmussa
  • Podit: Pod on yhdistelmä yksittäisiä tai useita säiliöitä, jotka loogisesti kulkevat yhdessä solmuissa

Muut keskeiset terminologiat

Replikoinnin ohjaimet

Replikointiohjain on objekti, joka määrittää pod-mallin. Se myös ohjaa parametreja identtisten Pod-kopioiden skaalaamiseksi vaakasuunnassa lisäämällä tai vähentämällä käynnissä olevien kopioiden määrää.

Replikointisarjat

Replikointijoukot ovat vuorovaikutus replikointiohjaimen suunnittelussa, jossa on joustavuutta siinä, kuinka ohjain tunnistaa ryhmät, joita sen on tarkoitus hallita. Se korvaa replikointiohjaimet niiden paremman replikointivalinnan ansiosta.

käyttöönottoja

Käyttöönotto on yleinen työtaakka, joka voidaan luoda ja hallita suoraan. Käyttöönotto käyttää replikointijoukkoa rakennuspalikkana, joka lisää elinkaarihallinnan ominaisuuden.

Tilalliset joukot

Se on erikoistunut pod-ohjain, joka tarjoaa järjestystä ja ainutlaatuisuutta. Sitä käytetään pääasiassa hienorakeiseen hallintaan, jota tarvitset erityisesti käyttöönottojärjestyksen, vakaan verkottumisen ja pysyvien tietojen suhteen.

Daemon-sarjat

Daemon-sarjat ovat toinen pod-ohjaimen erikoistunut muoto, joka suorittaa podin kopion jokaisessa klusterin solmussa. Tämäntyyppinen pod-ohjain on tehokas tapa ottaa käyttöön podeja, jonka avulla voit suorittaa ylläpitoa ja tarjota palveluja itse solmuille.

Kubernetes vs. Docker Swarm

Tässä on tärkeitä eroja Kubernetes vs Docker.

Parametri Docker-parvi Kubernetes
Skaalaus Ei automaattista skaalausta Automaattinen skaalaus
Kuormituksen tasapainoittaminen Tekee automaattisen kuorman tasauksen Määritä kuormituksen tasapainotusasetukset manuaalisesti
Tallennustilan jakaminen Jakaa tallennustilavuudet minkä tahansa muun kontin kanssa Jakaa tallennustilavuudet useiden saman kotelon sisällä olevien säiliöiden kesken
Kirjautumis- ja seurantatyökalun käyttö Käytä 3iard juhlatyökalu, kuten ELK Tarjoa sisäänrakennettu työkalu kirjaamiseen ja seurantaan.
Asennus Helppoa & nopeaa Monimutkaista ja aikaa vievää
GUI GUI ei ole saatavilla GUI on saatavilla
skaalautuvuus Skaalaus on nopeampaa kuin K8S, mutta klusterin vahvuus ei ole yhtä vahva Skaalaus on hidasta Swarmiin verrattuna, mutta takaa vahvemman klusterin tilan Kuormituksen tasapainotus vaatii manuaalisen huoltomäärityksen
Kuormituksen tasapainoittaminen Tarjoaa sisäänrakennetun kuormituksen tasaustekniikan Prosessin ajoitus palvelujen ylläpitämiseksi päivityksen aikana
Päivitykset ja palautukset Tietomäärien kirjaaminen ja seuranta Progressiiviset päivitykset ja palvelun kunnon seuranta. Jaettu vain saman Podin sisäänrakennettujen loki- ja seurantatyökalujen säiliöiden kanssa.

Kubernetesin edut

  • Helppo palvelun organisointi pussien avulla
  • Sen on kehittänyt Google, joka tuo pöytään vuosien arvokkaan alan kokemuksen
  • Suurin yhteisö kontin orkestrointityökalujen joukossa
  • Tarjoaa erilaisia ​​tallennusvaihtoehtoja, mukaan lukien paikalliset, SAN-verkot ja julkiset pilvet
  • Noudattaa muuttumattoman infrastruktuurin periaatteita
  • Kubernetes voi käyttää paikan päällä paljasmetallia, OpenStackia ja julkisia pilviä Google, Azure, AWS, Jne
  • Auttaa sinua välttämään toimittajan lukitusongelmia, koska se voi käyttää mitä tahansa toimittajakohtaisia ​​sovellusliittymiä tai palveluita paitsi silloin, kun Kubernetes tarjoaa abstraktion, esim. kuormituksen tasapainotinta ja tallennustilaa.
  • Säiliöinti kubernetesin avulla mahdollistaa pakettiohjelmiston palvelevan näitä tavoitteita. Se mahdollistaa sovellukset, jotka on julkaistava ja päivitettävä ilman seisokkeja.
  • Kubernetes antaa sinun varmistaa, että konttisovellukset toimivat missä ja milloin haluat, ja auttaa sinua löytämään resursseja ja työkaluja, joita haluat työskennellä.

Kubernetesin haitat

  • Kubenetes-kojelauta ei ole niin hyödyllinen kuin sen pitäisi olla
  • Kubernetes on hieman monimutkainen ja tarpeeton ympäristöissä, joissa kaikki kehitys tehdään paikallisesti.
  • Turvallisuus ei ole kovin tehokasta.

Yhteenveto

  • Container auttaa organisaatiota suorittamaan ylläpitoa ja päivitystä keskeyttämättä palveluita
  • Kubernetes on esimerkki Google-alustalla kehitetystä kontinhallintajärjestelmästä.
  • Kubernetesin käytön suurin etu on, että sillä voidaan käyttää paikallista OpenStackia, julkisia Google-pilviä, Azure, AWS jne.
  • Kubernetes tarjoaa automaattisia ajoitus- ja itsekorjautumisominaisuuksia.
  • Cluster, isäntä, solmu ja nimiavaruus ovat tärkeitä kubernetesin perustietoja
  • Pääsolmu ja työsolmu ovat tärkeitä Kubernetes-arkkitehtuurin osia.
  • Replikointiohjaimet, replikointijoukot, käyttöönotot, tilalliset joukot, demonijoukot ovat muita tärkeitä Kubernetesissa käytettyjä termejä.
  • Docker-parvi ei salli automaattista skaalausta, kun taas Kubernetes sallii automaattisen skaalauksen.
  • Kubenetesin suurin haittapuoli on, että sen kojelauta ei ole kovin hyödyllinen ja tehokas