Namestite Kubernetes s Kubeadmom na CentOS 7

Pregled

Ta članek je namenjen temu, da vam pomaga, da gručo Kubernetes zaženete in zaženete s kubeadm v kratkem času. Ta vodnik bo namestil dva strežnika, enega glavnega in enega delavca, vendar lahko namestite toliko strežnikov, kot želite.

Kaj je kubeadm?

Kubeadm je orodje, ki ga je razvil Kubernetes, ki vam omogoča, da vzpostavite in zaženete minimalno izvedljivo gručo z upoštevanjem najboljših praks. To bo samo zagnalo vašo gručo, ne pa oskrbe strojev. Stvari, kot so dodatki, nadzorna plošča Kubernetes, rešitve za spremljanje in tako naprej, niso nekaj, kar bo kubeadm naredil za vas.

Predpogoji

Za strežnike, ki jih bomo namestili, je nekaj zahtev. Ena ali več naprav, ki izvajajo operacijski sistem, ki je združljiv z deb/rpm. Uporabljali bomo CentOS.

  • 2 GB ali več RAM-a na stroj
  • 2 CPU-ja ali več na glavni enoti

Popolna omrežna povezljivost med vsemi stroji v gruči

Dva strežnika, ki sta nameščena v tem priročniku, sta naslednja: - 1 CPU 2 GB RAM s CentOS 7 (delovno vozlišče) - 2 CPU 4 GB RAM s CentOS 7 (glavno vozlišče)

S to količino RAM-a na obeh strežnikih bo imel Kubernetes dovolj prostora za dihanje.

Konfiguriranje delavca in poveljnika

Tukaj so koraki, ki jih bomo morali izvesti tako na glavnem kot na delovnem vozlišču:

  • Yum posodobitev in paketi
  • Namestite Docker
  • Onemogoči selinux
  • Onemogoči zamenjavo
  • Onemogoči požarni zid
  • Posodobite IPTables
  • Namestite kubelet/kubeadm/kubectl

Namestitev Dockerja

V 1.14tej vadnici bomo uporabljali različico Kubernetesa. Za to različico Kubernetes priporoča izvajanje različice Docker 18.06.2. Preverite priporočeno različico Dockerja za svojo različico Kuberenetes

Dockerjevo skladišče bomo dodali v yum in posebej namestili 18.06.2. Ko je Docker nameščen, bomo morali demona dockerja konfigurirati na nastavitve, ki jih priporoča 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

Onemogoči SELinux

Ker uporabljamo CentOS, moramo onemogočiti SELinux. To je potrebno, da se vsebnikom omogoči dostop do gostiteljskega datotečnega sistema.

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

Onemogoči zamenjavo

Swap je treba onemogočiti, da bo kubelet deloval pravilno.

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

Onemogoči požarni zid

Kubernetes uporablja IPTables za obdelavo vhodnega in odhodnega prometa – zato, da se izognemo kakršnim koli težavam, onemogočimo požarni zid.

systemctl disable firewalld
systemctl stop firewalld

Posodobite IPTables

Kubernetes priporoča, da zagotovimo, da net.bridge.bridge-nf-call-iptablesje nastavljeno na 1. To je posledica težav, pri katerih je imel REHL/CentOS 7 težave z napačno preusmeritvijo prometa zaradi zaobidenja iptables.

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

Namestite kubelet/kubeadm/kubectl

V yum bomo morali dodati repo kubernetes. Ko to storimo, moramo samo zagnati ukaz za namestitev in omogoč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

Zdaj smo v celoti konfigurirali glavno in delovno vozlišče. Zdaj lahko inicializiramo naše glavno vozlišče in pridružimo naša delovna vozlišča glavnemu!

Opomba Če želite dodati več delovnih vozlišč, bi morali zgornji postopek izvesti tudi na vseh teh vozliščih.

Nastavitev glavnega vozlišča

Naše glavno vozlišče želimo inicializirati z izvajanjem naslednjega ukaza. V spodnjem ukazu boste želeli zamenjati naslov IP svojega glavnega vozlišča. Poleg tega bomo posredovali pod-network-cidr, da nam bo kasneje olajšalo namestitev prekrivnega omrežja Flannel.

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

To lahko traja nekaj časa, vendar ko bo končano, boste na koncu izpisa videli nekaj podobnega, kot je naslednje.

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

Ta ukaz je tisto, kar morajo vaša delovna vozlišča izvesti, da se pridružijo gruči, zato ga upoštevajte.

Naslednji je flanel. Flanel je tisto, kar omogoča komunikacijo med strokom. Obstajajo različne druge vrste omrežnih prekrivanj, ki jih lahko namestite, vendar bo ta priročnik zaradi poenostavitve uporabljal Flannel.

Kopirajte kube/configdatoteko v svoj $Home, da lahko izvajate kubectlukaze.

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

Zadnji korak na glavnem vozlišču je namestitev Flannel. Zaženite naslednji ukaz.

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

S kopirano konfiguracijo boste lahko zagnali kubectl get csin dobili odgovor.

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

Vaše glavno vozlišče je nastavljeno in pripravljeno za uporabo. Na delovno vozlišče!

Delovno vozlišče

Na tej točki ni dodatnega dela, ki bi bilo potrebno na delovnem vozlišču. Vse, kar moramo storiti, je zagnati kubeadm joinukaz, ki smo ga dobili iz našega kubeadm initizhoda.

Če ste slučajno zapravili ukaz kubeadm join, lahko z zagonom ustvarite drugega na glavnem vozlišču kubeadm token create --print-join-command

Ko zaženete ukaz kubeadm join, če zaženete na masterju, kubectl get nodesboste videli podoben rezultat kot naslednji.

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

Zavijanje

Tako kot ste zagnali gručo Kubernetes z uporabo kubeadm. To lahko storite tudi z zasebnimi omrežji. Vultr, kot tudi drugi ponudniki v oblaku, omogočajo zasebna omrežja. Tudi, če želite izvajati ukaze kubectl iz vašega lokalnega računalnika v vaši gruči, lahko to dosežete tako, da je kubectl nameščen lokalno in povlečete .kube/configdatoteko iz gruče na vaš lokalni računalnik v $HOME/.kube/config.

Upajmo, da vam bo ta vodnik pomagal pri prehodu skozi kubeadm in vam omogočil, da se v trenutku igrate s kubernetes!

Uporabne povezave:


Namestite Plesk na CentOS 7

Namestite Plesk na CentOS 7

Uporaba drugega sistema? Plesk je lastniška nadzorna plošča spletnega gostitelja, ki uporabnikom omogoča upravljanje svojih osebnih in/ali strank spletnih mest, baz podatkov

Kako namestiti Squid Proxy na CentOS

Kako namestiti Squid Proxy na CentOS

Squid je priljubljen brezplačen program za Linux, ki vam omogoča ustvarjanje spletnega proxyja za posredovanje. V tem priročniku boste videli, kako namestiti Squid na CentOS, da vas obrne

Kako namestiti Lighttpd (LLMP Stack) na CentOS 6

Kako namestiti Lighttpd (LLMP Stack) na CentOS 6

Uvod Lighttpd je razdelek Apache, katerega namen je biti veliko manj intenziven vir. Je lahek, od tod tudi njegovo ime, in je precej preprost za uporabo. Namestite

Konfiguriranje statičnega omrežja in IPv6 na CentOS 7

Konfiguriranje statičnega omrežja in IPv6 na CentOS 7

VULTR je pred kratkim naredil spremembe na svoji strani in zdaj bi moralo vse delovati v redu iz škatle z omogočenim NetworkManagerjem. Če želite onemogočiti

Spreminjanje Icinga2 za uporabo modela Master/Client na CentOS 6 ali CentOS 7

Spreminjanje Icinga2 za uporabo modela Master/Client na CentOS 6 ali CentOS 7

Icinga2 je zmogljiv sistem za spremljanje in če se uporablja v modelu glavni-odjemalec, lahko nadomesti potrebo po nadzornih pregledih, ki temeljijo na NRPE. Glavni naročnik

Kako namestiti Apache Cassandra 3.11.x na CentOS 7

Kako namestiti Apache Cassandra 3.11.x na CentOS 7

Uporaba drugega sistema? Apache Cassandra je brezplačen in odprtokodni sistem za upravljanje baz podatkov NoSQL, ki je zasnovan tako, da zagotavlja razširljivost, visoko

Kako namestiti Microweber na CentOS 7

Kako namestiti Microweber na CentOS 7

Uporaba drugega sistema? Microweber je odprtokodna povleci in spusti CMS in spletna trgovina. Izvorna koda Microweber gostuje na GitHubu. Ta vodnik vam bo pokazal

Kako namestiti Mattermost 4.1 na CentOS 7

Kako namestiti Mattermost 4.1 na CentOS 7

Uporaba drugega sistema? Mattermost je odprtokodna alternativa sporočilni storitvi Slack SAAS, ki jo gosti sami. Z drugimi besedami, z Mattermostom si pribl

Ustvarjanje omrežja strežnikov Minecraft z BungeeCord na Debian 8, Debian 9 ali CentOS 7

Ustvarjanje omrežja strežnikov Minecraft z BungeeCord na Debian 8, Debian 9 ali CentOS 7

Kaj potrebujete Vultr VPS z vsaj 1 GB RAM-a. SSH dostop (z root/administrativnimi pravicami). 1. korak: Namestitev BungeeCord Najprej najprej

Omogočamo šifriranje na Plesku

Omogočamo šifriranje na Plesku

Nadzorna plošča Plesk ima zelo lepo integracijo za Lets Encrypt. Lets Encrypt je eden edinih ponudnikov SSL, ki izdaja potrdila v celoti

Namestite MariaDB 10 na CentOS 6

Namestite MariaDB 10 na CentOS 6

V času pisanja je MariaDB 10.1 razvojna različica MariaDB. Temelji na MariaDB 5.5 in vključuje funkcije, prenesene nazaj iz MySQL 5.6. Ther

Omogoča šifriranje na cPanelu

Omogoča šifriranje na cPanelu

Lets Encrypt je certifikacijski organ, ki je namenjen brezplačnemu zagotavljanju certifikatov SSL. cPanel je zgradil lepo integracijo za vas in vašo stranko

Kako namestiti Concrete5 na CentOS 7

Kako namestiti Concrete5 na CentOS 7

Uporaba drugega sistema? Concrete5 je odprtokodni CMS, ki ponuja številne značilne in uporabne funkcije za pomoč urednikom pri preprosti izdelavi vsebine.

Kako namestiti pregledno ploščo na CentOS 7

Kako namestiti pregledno ploščo na CentOS 7

Uporaba drugega sistema? Review Board je brezplačno in odprtokodno orodje za pregledovanje izvorne kode, dokumentacije, slik in še veliko več. Gre za spletno programsko opremo

Nastavite preverjanje pristnosti HTTP z Nginxom na CentOS 7

Nastavite preverjanje pristnosti HTTP z Nginxom na CentOS 7

V tem priročniku se boste naučili, kako nastaviti preverjanje pristnosti HTTP za spletni strežnik Nginx, ki deluje na CentOS 7. Zahteve Za začetek boste potrebovali

Kako namestiti YOURLS na CentOS 7

Kako namestiti YOURLS na CentOS 7

YOURLS (Your Own URL Shortener) je odprtokodna aplikacija za krajšanje URL-jev in analitiko podatkov. V tem članku bomo obravnavali postopek namestitve

Kako namestiti in konfigurirati ArangoDB na CentOS 7

Kako namestiti in konfigurirati ArangoDB na CentOS 7

Uporaba drugega sistema? Uvod ArangoDB je odprtokodna baza podatkov NoSQL s prilagodljivim podatkovnim modelom za dokumente, grafe in ključe-vrednosti. je

Uporaba Etckeeperja za nadzor različic /etc

Uporaba Etckeeperja za nadzor različic /etc

Uvod Imenik /etc/ igra ključno vlogo pri delovanju sistema Linux. Razlog za to je skoraj vsaka sistemska konfiguracija

Zakaj bi morali uporabljati SSHFS? Kako namestiti oddaljeni datotečni sistem s SSHFS na CentOS 6

Zakaj bi morali uporabljati SSHFS? Kako namestiti oddaljeni datotečni sistem s SSHFS na CentOS 6

Številni sistemski skrbniki upravljajo velike količine strežnikov. Ko je treba do datotek dostopati prek različnih strežnikov, se prijavite v vsakega posebej ca

Nastavitev strežnika Half Life 2 na CentOS 6

Nastavitev strežnika Half Life 2 na CentOS 6

Ta vadnica bo obravnavala postopek namestitve igralnega strežnika Half Life 2 na sistem CentOS 6. 1. korak: Namestitev predpogojev Za nastavitev ou

Vzpon strojev: aplikacije AI v resničnem svetu

Vzpon strojev: aplikacije AI v resničnem svetu

Umetna inteligenca ni v prihodnosti, tukaj je prav v sedanjosti. V tem blogu preberite, kako so aplikacije umetne inteligence vplivale na različne sektorje.

DDOS napadi: kratek pregled

DDOS napadi: kratek pregled

Ste tudi vi žrtev DDOS napadov in ste zmedeni glede načinov preprečevanja? Preberite ta članek, če želite rešiti svoja vprašanja.

Ste se kdaj vprašali, kako hekerji zaslužijo denar?

Ste se kdaj vprašali, kako hekerji zaslužijo denar?

Morda ste že slišali, da hekerji zaslužijo veliko denarja, a ste se kdaj vprašali, kako zaslužijo takšen denar? razpravljajmo.

Revolucionarni Googlovi izumi, ki vam bodo olajšali življenje.

Revolucionarni Googlovi izumi, ki vam bodo olajšali življenje.

Ali želite videti revolucionarne izume Googla in kako so ti izumi danes spremenili življenje vsakega človeka? Nato preberite v blogu in si oglejte Googlove izume.

Friday Essential: Kaj se je zgodilo z avtomobili, ki jih poganja umetna inteligenca?

Friday Essential: Kaj se je zgodilo z avtomobili, ki jih poganja umetna inteligenca?

Koncept samovozečih avtomobilov, ki zapeljejo na ceste s pomočjo umetne inteligence, so sanje, ki jih imamo že nekaj časa. A kljub številnim obljubam jih ni nikjer. Preberite ta blog, če želite izvedeti več…

Tehnološka singularnost: oddaljena prihodnost človeške civilizacije?

Tehnološka singularnost: oddaljena prihodnost človeške civilizacije?

Ker se znanost hitro razvija in prevzame veliko naših prizadevanj, se povečuje tudi tveganje, da se podvržemo nerazložljivi singularnosti. Preberite, kaj bi za nas lahko pomenila singularnost.

Razvoj shranjevanja podatkov – Infografika

Razvoj shranjevanja podatkov – Infografika

Metode shranjevanja podatkov so se lahko razvijale od rojstva podatkov. Ta blog pokriva razvoj shranjevanja podatkov na podlagi infografike.

Funkcionalnosti slojev referenčne arhitekture velikih podatkov

Funkcionalnosti slojev referenčne arhitekture velikih podatkov

Preberite blog, če želite na najpreprostejši način spoznati različne plasti v arhitekturi velikih podatkov in njihove funkcionalnosti.

6 neverjetnih prednosti pametnih naprav za dom v našem življenju

6 neverjetnih prednosti pametnih naprav za dom v našem življenju

V tem digitalno vodenem svetu so pametne naprave za dom postale ključni del življenja. Tukaj je nekaj neverjetnih prednosti pametnih naprav za dom o tem, kako naredijo naše življenje vredno življenja in poenostavijo.

Posodobitev dodatka macOS Catalina 10.15.4 povzroča več težav kot jih rešuje

Posodobitev dodatka macOS Catalina 10.15.4 povzroča več težav kot jih rešuje

Pred kratkim je Apple izdal macOS Catalina 10.15.4 dopolnilno posodobitev za odpravo težav, vendar se zdi, da posodobitev povzroča več težav, ki vodijo do opečenja računalnikov Mac. Preberite ta članek, če želite izvedeti več