Postavite Kubernetes s Kubeadm-om na CentOS 7

Pregled

Ovaj članak treba vam pomoći da u kratkom roku pokrenete Kubernetes klaster s kubeadmom. Ovaj vodič će implementirati dva poslužitelja, jednog glavnog i jednog radnika, no možete postaviti onoliko poslužitelja koliko želite.

Što je kubeadm?

Kubeadm je alat koji je razvio Kubernetes koji vam omogućuje pokretanje i rad minimalnog održivog klastera slijedeći najbolje prakse. Samo će pokrenuti vaš klaster, a ne i osigurati strojeve. Stvari kao što su dodaci, Kubernetes nadzorna ploča, rješenja za praćenje i tako dalje nisu nešto što će kubeadm učiniti za vas.

Preduvjeti

Postoji nekoliko zahtjeva za poslužitelje koje ćemo postaviti. Jedan ili više strojeva koji imaju deb/rpm kompatibilan OS. Koristit ćemo CentOS.

  • 2 GB ili više RAM-a po stroju
  • 2 CPU-a ili više na glavnom

Potpuna mrežna povezanost između svih strojeva u klasteru

Dva poslužitelja raspoređena u ovom vodiču su sljedeća: - 1 CPU 2 GB RAM-a s CentOS 7 (radnički čvor) - 2 CPU 4 GB RAM-a s CentOS-om 7 (glavni čvor)

S ovom količinom RAM-a na oba poslužitelja, Kubernetes će imati dovoljno prostora za disanje.

Konfiguriranje radnika i gospodara

Evo koraka koje ćemo morati poduzeti i na glavnom i na radnom čvoru:

  • Yum ažuriranje i paketi
  • Instalirajte docker
  • Onemogući selinux
  • Onemogući zamjenu
  • Onemogućite vatrozid
  • Ažurirajte IPTables
  • Instalirajte kubelet/kubeadm/kubectl

Instalacija Dockera

U 1.14ovom vodiču koristit ćemo verziju Kubernetesa. Za ovu verziju Kubernetes preporučuje pokretanje Docker verzije 18.06.2. Svakako provjerite preporučenu verziju Dockera za svoju verziju Kuberenetesa

Dodavat ćemo Docker spremište u yum i posebno instalirati 18.06.2. Nakon što je Docker instaliran, morat ćemo konfigurirati docker demon na postavke koje preporučuje Kubernetes.

###Add yum-utils, if not installed already
yum install yum-utils

###Add Docker repository.
yum-config-manager --add-repo https://download.docker.com/linux/centos/docker-ce.repo

###Install Docker CE.
yum update && yum install docker-ce-18.06.2.ce

###Create /etc/docker directory.
mkdir /etc/docker

###Setup daemon.
cat > /etc/docker/daemon.json <<EOF
{
  "exec-opts": ["native.cgroupdriver=systemd"],
  "log-driver": "json-file",
  "log-opts": {
    "max-size": "100m"
  },
  "storage-driver": "overlay2",
  "storage-opts": [
    "overlay2.override_kernel_check=true"
  ]
}
EOF

mkdir -p /etc/systemd/system/docker.service.d

###Restart Docker
systemctl daemon-reload
systemctl enable docker.service
systemctl restart docker

Onemogućite SELinux

Budući da koristimo CentOS, moramo onemogućiti SELinux. Ovo je neophodno kako bi se kontejnerima omogućio pristup datotečnom sustavu domaćina.

setenforce 0
sed -i 's/^SELINUX=enforcing$/SELINUX=disable/' /etc/selinux/config

Onemogući zamjenu

Zamjena mora biti onemogućena kako bi kubelet ispravno radio.

sed -i '/swap/d' /etc/fstab
swapoff -a

Onemogućite vatrozid

Kubernetes koristi IPTables za rukovanje dolaznim i odlaznim prometom - tako da kako bismo izbjegli bilo kakve probleme, onemogućujemo firewalld.

systemctl disable firewalld
systemctl stop firewalld

Ažurirajte IPTables

Kubernetes preporučuje da osiguramo da net.bridge.bridge-nf-call-iptablesje postavljeno na 1. To je zbog problema u kojima je REHL/CentOS 7 imao problema s netočnim preusmjeravanjem prometa zbog zaobilaženja iptablesa.

cat <<EOF > /etc/sysctl.d/k8s.conf
net.bridge.bridge-nf-call-ip6tables = 1
net.bridge.bridge-nf-call-iptables = 1
EOF
sysctl --system

Instalirajte kubelet/kubeadm/kubectl

Morat ćemo dodati kubernetes repo u yum. Nakon što to učinimo, samo trebamo pokrenuti naredbu install i omogućiti kubelet.

cat <<EOF > /etc/yum.repos.d/kubernetes.repo
[kubernetes]
name=Kubernetes
baseurl=https://packages.cloud.google.com/yum/repos/kubernetes-el7-x86_64
enabled=1
gpgcheck=1
repo_gpgcheck=1
gpgkey=https://packages.cloud.google.com/yum/doc/yum-key.gpg https://packages.cloud.google.com/yum/doc/rpm-package-key.gpg
exclude=kube*
EOF

yum install -y kubelet kubeadm kubectl --disableexcludes=kubernetes
systemctl enable --now kubelet

Sada smo u potpunosti konfigurirali i glavni i radni čvor. Sada možemo inicijalizirati naš glavni čvor i pridružiti naše radne čvorove glavnom!

Napomena Ako želite dodati više radnih čvorova, gornji postupak bi se također morao obaviti na svim tim čvorovima.

Postavljanje glavnog čvora

Želimo inicijalizirati naš glavni čvor pokretanjem sljedeće naredbe. Želite zamijeniti IP adresu svog glavnog čvora u naredbi u nastavku. Dodatno, proslijedit ćemo pod-network-cidr kako bi nam kasnije bilo lakše kada instaliramo Flannel mrežni sloj.

kubeadm init --apiserver-advertise-address=YOUR_IP_HERE --pod-network-cidr=10.244.0.0/16

Ovo može potrajati neko vrijeme da se završi, ali nakon što se završi vidjet ćete nešto slično na kraju izlaza kao što je sljedeće.

kubeadm join YOUR_IP:6443 --token 4if8c2.pbqh82zxcg8rswui \
--discovery-token-ca-cert-hash sha256:a0b2bb2b31bf7b06bb5058540f02724240fc9447b0e457e049e59d2ce19fcba2

Ova naredba je ono što vaši radnički čvorovi trebaju izvršiti da bi se pridružili klasteru, pa je zabilježite.

Sljedeći je flanel. Flanel je ono što omogućuje komunikaciju mahuna i mahuna. Postoje razne druge vrste mrežnih slojeva koje možete instalirati, ali radi jednostavnosti ovaj vodič će koristiti flanel.

Kopirajte kube/configdatoteku na svoju $Homekako biste mogli izvršavati kubectlnaredbe.

mkdir $HOME/.kube
cp /etc/kubernetes/admin.conf $HOME/.kube/config

Posljednji korak na glavnom čvoru je instalacija Flannel-a. Pokrenite sljedeću naredbu.

kubectl apply -f https://raw.githubusercontent.com/coreos/flannel/master/Documentation/kube-flannel.yml

S ovom kopiranom konfiguracijom moći ćete se pokrenuti kubectl get csi dobiti odgovor.

NAME                 STATUS    MESSAGE             ERROR
scheduler            Healthy   ok
controller-manager   Healthy   ok
etcd-0               Healthy   {"health":"true"}

Vaš glavni čvor je postavljen i spreman za rad. Na radni čvor!

Radnički čvor

U ovom trenutku nema dodatnog rada koji je neophodan na radnom čvoru. Sve što trebamo učiniti je pokrenuti kubeadm joinnaredbu koju smo dobili iz našeg kubeadm initizlaza.

Ako ste nekim slučajem zagubili naredbu kubeadm join, možete generirati drugu na glavnom čvoru pokretanjem kubeadm token create --print-join-command

Nakon što pokrenete naredbu kubeadm join, ako pokrenete kubectl get nodesna masteru, vidjet ćete izlaz sličan sljedećem.

NAME          STATUS   ROLES    AGE    VERSION
k8-master   Ready    master   107m   v1.14.2
k8-worker   Ready    <none>   45m    v1.14.2

Završavati

Upravo tako ste pokrenuli Kubernetes klaster koristeći kubeadm. To možete učiniti i s privatnim mrežama. Vultr, kao i drugi pružatelji usluga u oblaku, dopuštaju privatne mreže. Također, ako želite izvršiti kubectl naredbe s vašeg lokalnog stroja protiv vašeg klastera, to možete postići tako da kubectl instalirate lokalno i povučete .kube/configdatoteku iz klastera na vaš lokalni stroj u $HOME/.kube/config.

Nadamo se da će vam ovaj vodič pomoći proći kroz kubeadm i navesti vas da se igrate s kubernetesom u trenu!

Korisni linkovi:


Instalirajte Plesk na CentOS 7

Instalirajte Plesk na CentOS 7

Korištenje drugog sustava? Plesk je vlasnička upravljačka ploča web hosta koja omogućuje korisnicima da administriraju svoje osobne i/ili klijentske web stranice, baze podataka

Kako instalirati Squid proxy na CentOS

Kako instalirati Squid proxy na CentOS

Squid je popularan besplatni program za Linux koji vam omogućuje stvaranje web proxyja za prosljeđivanje. U ovom vodiču vidjet ćete kako instalirati Squid na CentOS da vas preokrene

Kako instalirati Lighttpd (LLMP Stack) na CentOS 6

Kako instalirati Lighttpd (LLMP Stack) na CentOS 6

Uvod Lighttpd je fork Apachea koji ima za cilj da bude puno manje intenzivan prema resursima. Lagan je, otuda mu i naziv, i prilično je jednostavan za korištenje. Instaliraj

Konfiguriranje statičkog umrežavanja i IPv6 na CentOS 7

Konfiguriranje statičkog umrežavanja i IPv6 na CentOS 7

VULTR je nedavno napravio promjene na svojoj strani i sada bi sve trebalo raditi dobro iz kutije s omogućenim NetworkManagerom. Želite li onemogućiti

Promjena Icinga2 za korištenje modela Master/Client na CentOS 6 ili CentOS 7

Promjena Icinga2 za korištenje modela Master/Client na CentOS 6 ili CentOS 7

Icinga2 je moćan sustav nadzora, a kada se koristi u modelu master-client, može zamijeniti potrebu za provjerama praćenja na temelju NRPE. Glavni klijent

Kako instalirati Apache Cassandra 3.11.x na CentOS 7

Kako instalirati Apache Cassandra 3.11.x na CentOS 7

Korištenje drugog sustava? Apache Cassandra je besplatni i otvorenog koda NoSQL sustav upravljanja bazom podataka koji je osmišljen kako bi osigurao skalabilnost, visoku

Kako instalirati Microweber na CentOS 7

Kako instalirati Microweber na CentOS 7

Korištenje drugog sustava? Microweber je CMS i internetska trgovina otvorenog koda povuci i ispusti. Izvorni kod Microwebera nalazi se na GitHubu. Ovaj vodič će vam pokazati

Kako instalirati Mattermost 4.1 na CentOS 7

Kako instalirati Mattermost 4.1 na CentOS 7

Korištenje drugog sustava? Mattermost je open source alternativa Slack SAAS servisu za razmjenu poruka. Drugim riječima, s Mattermostom možete ca

Stvaranje mreže Minecraft poslužitelja s BungeeCord na Debian 8, Debian 9 ili CentOS 7

Stvaranje mreže Minecraft poslužitelja s BungeeCord na Debian 8, Debian 9 ili CentOS 7

Što vam treba Vultr VPS s najmanje 1 GB RAM-a. SSH pristup (s root/administrativnim privilegijama). Korak 1: Instalacija BungeeCord-a Najprije

Omogućava šifriranje na Plesku

Omogućava šifriranje na Plesku

Upravljačka ploča Plesk ima vrlo lijepu integraciju za Lets Encrypt. Lets Encrypt je jedan od jedinih SSL pružatelja usluga koji u potpunosti izdaju certifikate

Omogućuje šifriranje na cPanelu

Omogućuje šifriranje na cPanelu

Lets Encrypt je tijelo za izdavanje certifikata posvećeno besplatnom pružanju SSL certifikata. cPanel je izgradio urednu integraciju tako da vi i vaš klijent

Kako instalirati Concrete5 na CentOS 7

Kako instalirati Concrete5 na CentOS 7

Korištenje drugog sustava? Concrete5 je CMS otvorenog koda koji nudi mnoge osebujne i korisne značajke koje pomažu urednicima u jednostavnoj proizvodnji sadržaja i

Kako instalirati ploču za pregled na CentOS 7

Kako instalirati ploču za pregled na CentOS 7

Korištenje drugog sustava? Review Board je besplatan alat otvorenog koda za pregled izvornog koda, dokumentacije, slika i još mnogo toga. To je web-bazirani softver

Postavite HTTP autentifikaciju pomoću Nginxa na CentOS 7

Postavite HTTP autentifikaciju pomoću Nginxa na CentOS 7

U ovom vodiču naučit ćete kako postaviti HTTP autentifikaciju za Nginx web poslužitelj koji radi na CentOS 7. Zahtjevi Da biste započeli, trebat će vam

Kako instalirati YOURLS na CentOS 7

Kako instalirati YOURLS na CentOS 7

YOURLS (Your Own URL Shortener) je aplikacija za skraćivanje URL-ova otvorenog koda i analizu podataka. U ovom članku ćemo pokriti proces instalacije

Kako instalirati i konfigurirati ArangoDB na CentOS 7

Kako instalirati i konfigurirati ArangoDB na CentOS 7

Korištenje drugog sustava? Uvod ArangoDB je NoSQL baza podataka otvorenog koda s fleksibilnim modelom podataka za dokumente, grafikone i ključ-vrijednosti. to je

Korištenje Etckeepera za kontrolu verzija /etc

Korištenje Etckeepera za kontrolu verzija /etc

Uvod Direktorij /etc/ igra ključnu ulogu u načinu na koji Linux sustav funkcionira. Razlog tome je što je gotovo svaka konfiguracija sustava

Zašto biste trebali koristiti SSHFS? Kako montirati udaljeni datotečni sustav sa SSHFS na CentOS 6

Zašto biste trebali koristiti SSHFS? Kako montirati udaljeni datotečni sustav sa SSHFS na CentOS 6

Mnogi administratori sustava upravljaju velikim količinama poslužitelja. Kada se datotekama treba pristupiti na različitim poslužiteljima, prijava na svaki pojedinačno ca

Postavljanje poslužitelja Half Life 2 na CentOS 6

Postavljanje poslužitelja Half Life 2 na CentOS 6

Ovaj vodič će pokriti proces instaliranja poslužitelja za igre Half Life 2 na sustavu CentOS 6. Korak 1: Instaliranje preduvjeta Kako biste postavili ou

Kako instalirati Laravel GitScrum na CentOS 7

Kako instalirati Laravel GitScrum na CentOS 7

Laravel GitScrum ili GitScrum je alat za produktivnost otvorenog koda dizajniran da pomogne razvojnim timovima da implementiraju Scrum metodologiju na sličan način.

Uspon strojeva: primjene AI u stvarnom svijetu

Uspon strojeva: primjene AI u stvarnom svijetu

Umjetna inteligencija nije u budućnosti, ovdje je upravo u sadašnjosti. U ovom blogu Pročitajte kako su aplikacije umjetne inteligencije utjecale na različite sektore.

DDOS napadi: kratak pregled

DDOS napadi: kratak pregled

Jeste li i vi žrtva DDOS napada i zbunjeni ste metodama prevencije? Pročitajte ovaj članak kako biste riješili svoje upite.

Jeste li se ikada zapitali kako hakeri zarađuju novac?

Jeste li se ikada zapitali kako hakeri zarađuju novac?

Možda ste čuli da hakeri zarađuju mnogo novca, ali jeste li se ikada zapitali kako zarađuju toliki novac? raspravimo.

Revolucionarni Googleovi izumi koji će vam olakšati život.

Revolucionarni Googleovi izumi koji će vam olakšati život.

Želite li vidjeti revolucionarne izume Googlea i kako su ti izumi promijenili život svakog čovjeka danas? Zatim čitajte na blogu kako biste vidjeli Googleove izume.

Friday Essential: Što se dogodilo s automobilima s umjetnom inteligencijom?

Friday Essential: Što se dogodilo s automobilima s umjetnom inteligencijom?

Koncept samovozećih automobila koji će krenuti na ceste uz pomoć umjetne inteligencije san je koji već neko vrijeme imamo. No, unatoč nekoliko obećanja, nigdje ih nema. Pročitajte ovaj blog kako biste saznali više…

Tehnološka singularnost: daleka budućnost ljudske civilizacije?

Tehnološka singularnost: daleka budućnost ljudske civilizacije?

Kako se znanost razvija velikom brzinom, preuzimajući mnoge naše napore, raste i rizik da se podvrgnemo neobjašnjivoj Singularnosti. Pročitajte što bi za nas mogla značiti singularnost.

Evolucija pohrane podataka – Infografika

Evolucija pohrane podataka – Infografika

Metode pohrane podataka su se razvijale možda od rođenja podataka. Ovaj blog pokriva evoluciju pohrane podataka na temelju infografike.

Funkcionalnosti slojeva referentne arhitekture velikih podataka

Funkcionalnosti slojeva referentne arhitekture velikih podataka

Pročitajte blog kako biste na najjednostavniji način upoznali različite slojeve u arhitekturi velikih podataka i njihove funkcionalnosti.

6 nevjerojatnih prednosti posjedovanja pametnih kućnih uređaja u našim životima

6 nevjerojatnih prednosti posjedovanja pametnih kućnih uređaja u našim životima

U ovom digitalnom svijetu, pametni kućni uređaji postali su ključni dio života. Evo nekoliko nevjerojatnih prednosti pametnih kućnih uređaja o tome kako naš život čine vrijednim življenja i jednostavnijim.

Ažuriranje dodataka macOS Catalina 10.15.4 uzrokuje više problema nego što ih rješava

Ažuriranje dodataka macOS Catalina 10.15.4 uzrokuje više problema nego što ih rješava

Nedavno je Apple izdao macOS Catalina 10.15.4 dodatak ažuriranju kako bi riješio probleme, ali čini se da ažuriranje uzrokuje više problema koji dovode do zalijevanja mac strojeva. Pročitajte ovaj članak da biste saznali više