Desplegueu Kubernetes amb Kubeadm a CentOS 7

Visió general

Aquest article està pensat per ajudar-vos a posar en funcionament un clúster de Kubernetes amb kubeadm en molt poc temps. Aquesta guia desplegarà dos servidors, un mestre i un de treballador, però podeu implementar tants servidors com vulgueu.

Què és kubeadm?

Kubeadm és una eina desenvolupada per Kubernetes que us permet posar en funcionament un clúster mínim viable seguint les millors pràctiques. Només arrencarà el vostre clúster, no proveïrà les màquines. Coses com ara els complements, el tauler de control de Kubernetes, les solucions de supervisió, etc., no són coses que kubeadm farà per vosaltres.

Requisits previs

Hi ha uns quants requisits per als servidors que implementarem. Una o més màquines amb un sistema operatiu compatible amb deb/rpm. Farem servir CentOS.

  • 2 GB o més de RAM per màquina
  • 2 CPU o més al mestre

Connectivitat de xarxa completa entre totes les màquines del clúster

Els dos servidors desplegats en aquesta guia són els següents: - 1 CPU 2 GB RAM amb CentOS 7 (node ​​de treball) - 2 CPU 4 GB RAM amb CentOS 7 (node ​​mestre)

Amb aquesta quantitat de memòria RAM als dos servidors, Kubernetes tindrà molt espai per respirar.

Configuració del treballador i el mestre

Aquests són els passos que haurem de fer tant al node mestre com al node de treball:

  • Yum actualització i paquets
  • Instal·leu docker
  • Desactiva selinux
  • Desactiva l'intercanvi
  • Desactiva el tallafoc
  • Actualitza IPTables
  • Instal·leu kubelet/kubeadm/kubectl

Instal·lació de Docker

Utilitzarem la versió 1.14de Kubernetes en aquest tutorial. Per a aquesta versió, Kubernetes recomana executar la versió de Docker 18.06.2. Assegureu-vos de comprovar la versió de Docker recomanada per a la vostra versió de Kuberenetes

Afegirem el repositori Docker a yum i instal·larem específicament 18.06.2. Un cop instal·lat Docker, haurem de configurar el dimoni docker amb la configuració recomanada per 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

Desactiva SELinux

Com que estem utilitzant CentOS, hem de desactivar SELinux. Això és necessari per permetre l'accés dels contenidors al sistema de fitxers host.

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

Desactiva l'intercanvi

L'intercanvi s'ha de desactivar perquè kubelet funcioni correctament.

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

Desactiva el tallafoc

Kubernetes utilitza IPTables per gestionar el trànsit entrant i sortint; per tant, per evitar problemes, desactivem el tallafoc.

systemctl disable firewalld
systemctl stop firewalld

Actualitza IPTables

Kubernetes recomana que ens assegurem que net.bridge.bridge-nf-call-iptablesestigui configurat en 1. Això es deu a problemes en què REHL/CentOS 7 ha tingut problemes amb el trànsit que s'ha redirigit de manera incorrecta a causa d'ometre 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

Instal·leu kubelet/kubeadm/kubectl

Haurem d'afegir el repo de kubernetes a yum. Un cop ho fem, només hem d'executar l'ordre d'instal·lació i habilitar 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

Ara hem configurat completament el nostre node mestre i treballador. Ara podem inicialitzar el nostre node mestre i unir els nostres nodes de treball al mestre!

Nota Si voleu afegir més nodes de treball, el procés anterior també s'hauria de fer en tots aquests nodes.

Configuració del node mestre

Volem inicialitzar el nostre node mestre executant la següent comanda. Voleu substituir l'adreça IP del vostre node mestre a l'ordre següent. A més, passarem el pod-network-cidr per facilitar-nos-ho més endavant quan instal·lem la superposició de xarxa Flannel.

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

Això pot trigar una estona a completar-se, però un cop finalitzat, veureu alguna cosa semblant al final de la sortida com el següent.

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

Aquesta ordre és la que han d'executar els vostres nodes de treball per unir-se al clúster, així que tingueu-ne en compte.

El següent és la franela. La franela és el que permet la comunicació entre pods. Hi ha altres tipus de superposicions de xarxa que podeu instal·lar, però per simplificar aquesta guia utilitzarà Flannel.

Copieu el kube/configfitxer al vostre $Homeperquè pugueu executar kubectlordres.

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

Un darrer pas al node mestre és instal·lar Flannel. Executeu la següent comanda.

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

Amb aquesta configuració copiada, podreu executar-vos kubectl get csi obtenir una resposta.

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

El vostre node mestre està configurat i llest per funcionar. Al node de treballador!

Node de treballador

En aquest punt no hi ha cap treball addicional que sigui necessari al node de treball. Tot el que hem de fer és executar l' kubeadm joinordre que hem obtingut de la nostra kubeadm initsortida.

Si, per casualitat, heu perdut l'ordre de join kubeadm, podeu generar-ne una altra al node mestre executant-lo kubeadm token create --print-join-command

Un cop executeu l'ordre kubeadm join, si executeu kubectl get nodesel master, veureu una sortida similar a la següent.

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

Embolcallant

Així, heu arrencat un clúster de Kubernetes mitjançant kubeadm. També podeu fer-ho amb xarxes privades. Vultr, així com altres proveïdors de núvol, permeten xarxes privades. A més, si voleu executar ordres de kubectl des de la vostra màquina local contra el vostre clúster, podeu fer-ho instal·lant kubectl localment i tirar cap avall el .kube/configfitxer del clúster a la vostra màquina local a $HOME/.kube/config.

Tant de bo aquesta guia us ajudi a recórrer kubeadm i us permeti jugar amb kubernetes en molt poc temps!

Links útils:


Instal·leu Plesk a CentOS 7

Instal·leu Plesk a CentOS 7

Utilitzeu un sistema diferent? Plesk és un tauler de control d'amfitrió web propietari que permet als usuaris administrar els seus llocs web personals i/o de clients, bases de dades

Com instal·lar Squid Proxy a CentOS

Com instal·lar Squid Proxy a CentOS

Squid és un popular programa Linux gratuït que us permet crear un servidor intermediari web de reenviament. En aquesta guia, veureu com instal·lar Squid a CentOS per convertir-vos-hi

Com instal·lar Lighttpd (LLMP Stack) a CentOS 6

Com instal·lar Lighttpd (LLMP Stack) a CentOS 6

Introducció Lighttpd és una bifurcació d'Apache destinada a ser molt menys intensiu en recursos. És lleuger, d'aquí el seu nom, i és bastant senzill d'utilitzar. Instal·lant

Configuració de xarxes estàtiques i IPv6 a CentOS 7

Configuració de xarxes estàtiques i IPv6 a CentOS 7

Recentment, VULTR ha fet canvis al seu extrem, i ara tot hauria de funcionar bé des de la caixa amb NetworkManager habilitat. Si voleu desactivar

Modificació dIcinga2 per utilitzar el model mestre/client a CentOS 6 o CentOS 7

Modificació dIcinga2 per utilitzar el model mestre/client a CentOS 6 o CentOS 7

Icinga2 és un sistema de supervisió potent i, quan s'utilitza en un model de client mestre, pot substituir la necessitat de controls de monitoratge basats en NRPE. El mestre-client

Com instal·lar Apache Cassandra 3.11.x a CentOS 7

Com instal·lar Apache Cassandra 3.11.x a CentOS 7

Utilitzeu un sistema diferent? Apache Cassandra és un sistema de gestió de bases de dades NoSQL gratuït i de codi obert dissenyat per proporcionar escalabilitat, alta

Com instal·lar Microweber a CentOS 7

Com instal·lar Microweber a CentOS 7

Utilitzeu un sistema diferent? Microweber és un CMS d'arrossegar i deixar anar de codi obert i una botiga en línia. El codi font de Microweber està allotjat a GitHub. Aquesta guia us mostrarà

Com instal·lar Vanilla Forum a CentOS 7

Com instal·lar Vanilla Forum a CentOS 7

Utilitzeu un sistema diferent? Vanilla Forum és una aplicació de fòrum de codi obert escrita en PHP. És totalment personalitzable, fàcil d'utilitzar i admet externa

Com instal·lar Mattermost 4.1 a CentOS 7

Com instal·lar Mattermost 4.1 a CentOS 7

Utilitzeu un sistema diferent? Mattermost és una alternativa autoallotjada de codi obert al servei de missatgeria Slack SAAS. En altres paraules, amb Mattermost, ca

Creació duna xarxa de servidors de Minecraft amb BungeeCord a Debian 8, Debian 9 o CentOS 7

Creació duna xarxa de servidors de Minecraft amb BungeeCord a Debian 8, Debian 9 o CentOS 7

Què necessitareu Un Vultr VPS amb almenys 1 GB de RAM. Accés SSH (amb privilegis d'arrel/administrador). Pas 1: instal·lació de BungeeCord Primer de tot

Permet xifrar a Plesk

Permet xifrar a Plesk

El tauler de control de Plesk inclou una integració molt agradable per Lets Encrypt. Lets Encrypt és un dels únics proveïdors SSL que ofereix certificats complets

Permet xifrar a cPanel

Permet xifrar a cPanel

Lets Encrypt és una autoritat de certificació dedicada a proporcionar certificats SSL de manera gratuïta. cPanel ha creat una integració perfecta perquè tu i el teu client

Com instal·lar Concrete5 a CentOS 7

Com instal·lar Concrete5 a CentOS 7

Utilitzeu un sistema diferent? Concrete5 és un CMS de codi obert que ofereix moltes característiques distintives i útils per ajudar els editors a produir continguts fàcilment i

Com instal·lar el tauler de revisió a CentOS 7

Com instal·lar el tauler de revisió a CentOS 7

Utilitzeu un sistema diferent? Review Board és una eina gratuïta i de codi obert per revisar el codi font, la documentació, les imatges i molts més. És un programari basat en web

Configura lautenticació HTTP amb Nginx a CentOS 7

Configura lautenticació HTTP amb Nginx a CentOS 7

En aquesta guia, aprendràs a configurar l'autenticació HTTP per a un servidor web Nginx que s'executa a CentOS 7. Requisits Per començar, necessitareu el

Com instal·lar GoAccess a CentOS 7

Com instal·lar GoAccess a CentOS 7

Utilitzeu un sistema diferent? GoAccess és un analitzador de registres web de codi obert. Podeu utilitzar-lo per analitzar els registres en temps real al terminal o

Com instal·lar YOURLS a CentOS 7

Com instal·lar YOURLS a CentOS 7

YOURLS (Your Own URL Shortener) és una aplicació d'anàlisi de dades i escurçament d'URL de codi obert. En aquest article, tractarem el procés d'instal·lació

Com instal·lar i configurar ArangoDB a CentOS 7

Com instal·lar i configurar ArangoDB a CentOS 7

Utilitzeu un sistema diferent? Introducció ArangoDB és una base de dades NoSQL de codi obert amb un model de dades flexible per a documents, gràfics i claus-valors. És

Utilitzant Etckeeper per al control de versions de /etc

Utilitzant Etckeeper per al control de versions de /etc

Introducció El directori /etc/ té un paper crític en el funcionament d'un sistema Linux. La raó d'això és perquè gairebé totes les configuracions del sistema

Per què hauríeu dutilitzar SSHFS? Com muntar un sistema de fitxers remot amb SSHFS a CentOS 6

Per què hauríeu dutilitzar SSHFS? Com muntar un sistema de fitxers remot amb SSHFS a CentOS 6

Molts administradors de sistemes gestionen grans quantitats de servidors. Quan s'hagi d'accedir als fitxers a través de diferents servidors, inicieu sessió a cadascun individualment ca

The Rise of Machines: Real World Applications of AI

The Rise of Machines: Real World Applications of AI

La Intel·ligència Artificial no està en el futur, és aquí mateix en el present. En aquest bloc Llegiu com les aplicacions d'Intel·ligència Artificial han afectat diversos sectors.

Atacs DDOS: una breu visió general

Atacs DDOS: una breu visió general

També ets víctima d'atacs DDOS i estàs confós sobre els mètodes de prevenció? Llegiu aquest article per resoldre les vostres consultes.

Us heu preguntat mai com guanyen diners els pirates informàtics?

Us heu preguntat mai com guanyen diners els pirates informàtics?

Potser haureu sentit que els pirates informàtics guanyen molts diners, però us heu preguntat mai com guanyen aquest tipus de diners? anem a discutir.

Invents revolucionaris de Google que us facilitaran la vida.

Invents revolucionaris de Google que us facilitaran la vida.

Vols veure els invents revolucionaris de Google i com aquests invents van canviar la vida de tots els éssers humans actuals? A continuació, llegiu al bloc per veure els invents de Google.

Divendres essencial: què va passar amb els cotxes impulsats per IA?

Divendres essencial: què va passar amb els cotxes impulsats per IA?

El concepte de cotxes autònoms per sortir a les carreteres amb l'ajuda de la intel·ligència artificial és un somni que tenim des de fa temps. Però malgrat les diverses promeses, no es veuen enlloc. Llegeix aquest blog per saber-ne més...

Singularitat tecnològica: un futur llunyà de la civilització humana?

Singularitat tecnològica: un futur llunyà de la civilització humana?

A mesura que la ciència evoluciona a un ritme ràpid, fent-se càrrec de molts dels nostres esforços, també augmenten els riscos de sotmetre'ns a una singularitat inexplicable. Llegeix, què pot significar per a nosaltres la singularitat.

Evolució de lemmagatzematge de dades – Infografia

Evolució de lemmagatzematge de dades – Infografia

Els mètodes d'emmagatzematge de les dades que han anat evolucionant poden ser des del naixement de les dades. Aquest bloc tracta l'evolució de l'emmagatzematge de dades a partir d'una infografia.

Funcionalitats de les capes darquitectura de referència de Big Data

Funcionalitats de les capes darquitectura de referència de Big Data

Llegeix el blog per conèixer de la manera més senzilla les diferents capes de l'Arquitectura Big Data i les seves funcionalitats.

6 avantatges sorprenents de tenir dispositius domèstics intel·ligents a les nostres vides

6 avantatges sorprenents de tenir dispositius domèstics intel·ligents a les nostres vides

En aquest món digital, els dispositius domèstics intel·ligents s'han convertit en una part crucial de les vides. A continuació, es mostren alguns avantatges sorprenents dels dispositius domèstics intel·ligents sobre com fan que la nostra vida valgui la pena i sigui més senzilla.

Lactualització del suplement de macOS Catalina 10.15.4 està causant més problemes que no pas solucions

Lactualització del suplement de macOS Catalina 10.15.4 està causant més problemes que no pas solucions

Recentment, Apple va llançar macOS Catalina 10.15.4, una actualització de suplements per solucionar problemes, però sembla que l'actualització està causant més problemes que provoquen el bloqueig de les màquines Mac. Llegiu aquest article per obtenir més informació