Kubeadmin来快速搭建一个k8s集群:
二进制搭建适合大集群,50台以上的主机,
但是kubeadm更适合中小企业的业务集群
环境:
Master:20.0.0.71 2核4G 或者4核8G docker kubelet kubectl flannel
Node1:20.0.0.72 2核4G 或者4核8G docker kubelet kubectl flannel
Node2: 20.0.0.73 2核4G docker kubelet kubectl flannel
Harbor节点:20.0.0.74 2核4Gdocker-compose harbor
实验开始:
所有节点
systemctl stop firewalld
setenforce 0
iptables -F && iptables -t nat -F && iptables -t mangle -F && iptables -X
swapoff -a
data:image/s3,"s3://crabby-images/8c450/8c4509a6ea3696727644d7f63f4f2878b53af869" alt=""
所有节点
for i in (ls /usr/lib/modules/(uname -r)/kernel/net/netfilter/ipvs|grep -o "^.*");do echo $i; /sbin/modinfo -F filename $i >/dev/null 2>&1 && /sbin/modprobe $i;done
data:image/s3,"s3://crabby-images/ceba6/ceba6d81cac2ced33f2fef192dba6bf52b8fe9a1" alt=""
改主机名
master1:
hostnamectl set-hostname master01
node1:
hostnamectl set-hostname node01
node2:
hostnamectl set-hostname node02
映射
data:image/s3,"s3://crabby-images/5fa05/5fa053108bb2e3c96c9d986894280f2eb237f748" alt=""
做内核优化:
data:image/s3,"s3://crabby-images/e19f7/e19f7529646ddf5dd97822df637a10d5592bc7d2" alt=""
vim /etc/sysctl.d/k8s.conf
#开启网桥模式:
net.bridge.bridge-nf-call-ip6tables=1
net.bridge.bridge-nf-call-iptables=1
#网桥的流量传给iptables链,实现地址映射
#关闭ipv6的流量(可选项)
net.ipv6.conf.all.disable_ipv6=1
#根据工作中的实际情况,自定
net.ipv4.ip_forward=1
wq!
net.bridge.bridge-nf-call-ip6tables = 1
net.bridge.bridge-nf-call-iptables = 1
net.ipv6.conf.all.disable_ipv6=1
net.ipv4.ip_forward=1
data:image/s3,"s3://crabby-images/ef91f/ef91fedfadb7361528f085a8f5c3ca0e9eebed00" alt=""
sysctl --system
时间同步(全部)
yum install ntpdate -y
ntpdate ntp.aliyun.com
date
所有节点安装docker
资源控制器必须systemd(三台)
mkdir /etc/docker
cat > /etc/docker/daemon.json <<EOF
{
"registry-mirrors": ["https://pkm63jfy.mirror.aliyuncs.com"],
"exec-opts": ["native.cgroupdriver=systemd"],
"log-driver": "json-file",
"log-opts": {
"max-size": "100m"
}
}
EOF
systemctl daemon-reload
systemctl restart docker.service
systemctl enable docker.service
docker info | grep "Cgroup Driver"
Cgroup Driver: systemd
data:image/s3,"s3://crabby-images/12761/12761655c9a6833cf956be7cf16f8e3ad6784902" alt=""
data:image/s3,"s3://crabby-images/7254e/7254e4699d59254bf28cb353bb40ba614b6b093d" alt=""
安装kuberctl(三台)
//定义kubernetes源
cat > /etc/yum.repos.d/kubernetes.repo << EOF
[kubernetes]
name=Kubernetes
baseurl=https://mirrors.aliyun.com/kubernetes/yum/repos/kubernetes-el7-x86_64
enabled=1
gpgcheck=0
repo_gpgcheck=0
gpgkey=https://mirrors.aliyun.com/kubernetes/yum/doc/yum-key.gpg https://mirrors.aliyun.com/kubernetes/yum/doc/rpm-package-key.gpg
EOF
yum install -y kubelet-1.20.15 kubeadm-1.20.15 kubectl-1.20.15
data:image/s3,"s3://crabby-images/96d2f/96d2f236401aac30f06ccfa36d7948e2a972580e" alt=""
//查看初始化需要的镜像
kubeadm config images list --kubernetes-version 1.20.15
k8s.gcr.io/kube-apiserver:v1.20.15
k8s.gcr.io/kube-controller-manager:v1.20.15
k8s.gcr.io/kube-scheduler:v1.20.15
k8s.gcr.io/kube-proxy:v1.20.15
取消同步操作
主节点操作:
//查看初始化需要的镜像
kubeadm config images list --kubernetes-version 1.20.15
data:image/s3,"s3://crabby-images/7f751/7f75176a2ce3fa968d5fa5a0d5e3d899e2e0ba4c" alt=""
解析:
Pause:特殊的pod
Pause会在节点上创建一个网络命名空间,其他容器可以加入这个网络命名空间
Pod里面的容器可能使用不同的代码架构编写,可以在一个网络空间里面实现通信,协调这个命名空间里面的资源(实现pod内容器的兼容性)
Kubeadm安装的k8s都是以pod的形式运行在kube-system这个空间当中
Kubeletnode管理器可以进行系统控制
data:image/s3,"s3://crabby-images/2a289/2a289bfce303263488a1a45675e7f94a22113a05" alt=""
kubeadm init \
--apiserver-advertise-address=20.0.0.71 \
--image-repository registry.aliyuncs.com/google_containers \
--kubernetes-version=v1.20.15 \
--service-cidr=10.96.0.0/16 \
--pod-network-cidr=10.244.0.0/16 \
--token-ttl=0
第二行:声明master节点的apiserver法人监听地址
第三行:声明拉取镜像的仓库,使用阿里云
第四行:k8s的版本号
第五行:所有server的对外代理地址都是10.96.0.0/16
第六行:所有pod的IP地址的网段
第七行:默认的token的有效期,默认是24小时,0表示永不过期
data:image/s3,"s3://crabby-images/47fca/47fcae112dca5856216ee3733eecea7897d541fd" alt=""
将黑色代码,复制到两个node节点,node1,node2执行
mkdir -p $HOME/.kube
cp -i /etc/kubernetes/admin.conf $HOME/.kube/config
chown (id -u):(id -g) $HOME/.kube/config
systemctl restart kubelet
data:image/s3,"s3://crabby-images/20d90/20d90bc4188af3d10d1e26475ef154cffd248db6" alt=""
初始化后需要修改 kube-proxy 的 configmap,开启 ipvs
kubectl edit cm kube-proxy -n=kube-system
修改mode: ipvs
data:image/s3,"s3://crabby-images/f1560/f1560fc246fe9eefafd36c2db61e1da3fc3ab4d2" alt=""
data:image/s3,"s3://crabby-images/65e7f/65e7fb6c75a4f315f6eaccb83cabea59ffd1cf9a" alt=""
Systemctl restart kublet
data:image/s3,"s3://crabby-images/86415/86415e6d516fa4155821d0a056973828f8f9e66b" alt=""
kubectl get nodes
data:image/s3,"s3://crabby-images/a1fb6/a1fb67ed06df35712fd7ca2315a9f9ef916749dc" alt=""
data:image/s3,"s3://crabby-images/a1fb6/a1fb67ed06df35712fd7ca2315a9f9ef916749dc" alt=""
kubectl get cs发现集群不健康,更改以下两个文件
data:image/s3,"s3://crabby-images/35069/35069cfc50088a684fa53aca86fdb574c7ec0849" alt=""
修改监听地址
vim /etc/kubernetes/manifests/kube-scheduler.yaml
vim /etc/kubernetes/manifests/kube-controller-manager.yaml
systemctl restart kubelet
data:image/s3,"s3://crabby-images/a8f5a/a8f5a714b2a56080010056c8905f2e448b3586bb" alt=""
data:image/s3,"s3://crabby-images/35ce3/35ce3eb009603ac9e85555cb7dc4b7a30e08e4ff" alt=""
data:image/s3,"s3://crabby-images/bbf4b/bbf4b0afeacb7e030d5c2486dbc3993a4b4a4b2f" alt=""
data:image/s3,"s3://crabby-images/c58e6/c58e68a9247537f8ce0e2db9d266be677f1df8d1" alt=""
data:image/s3,"s3://crabby-images/9ea8e/9ea8ecace679c861d693424b89eccc7e323c06e7" alt=""
data:image/s3,"s3://crabby-images/888c4/888c45b37096f51167aaf67fbddd4b3670420f61" alt=""
data:image/s3,"s3://crabby-images/9f630/9f630132aaeacd96474c8633fcdfa6676400c114" alt=""
data:image/s3,"s3://crabby-images/5a5e2/5a5e21565a9503a1893bdcda8be0fd2ccf34adde" alt=""
kubectl get pods -n kube-system
data:image/s3,"s3://crabby-images/e7612/e761268325e9be7857b9562f6db171c0efb186d8" alt=""
部署网络(三台)
//所有节点上传 flannel 镜像 flannel.tar 和网络插件 cni-plugins-linux-amd64-v0.8.6.tgz 到 /opt 目录,
master节点上传 kube-flannel.yml 文件
data:image/s3,"s3://crabby-images/ce8b6/ce8b65a7044e0eea2795043b896c23910171c4fc" alt=""
cd /opt
docker load < flannel.tar
mv /opt/cni /opt/cni_bak
mkdir -p /opt/cni/bin
tar zxvf cni-plugins-linux-amd64-v0.8.6.tgz -C /opt/cni/bin
主节点:
//在 master 节点创建 flannel 资源
kubectl apply -f kube-flannel.yml
data:image/s3,"s3://crabby-images/c29db/c29db4a0dbc5ac6b9125853337236ee5291793eb" alt=""
kubectl get node
data:image/s3,"s3://crabby-images/d0b53/d0b53079738216c151afbfa9a6f354a371c2976a" alt=""
删除节点:
kubectl delete node master01
data:image/s3,"s3://crabby-images/9da07/9da07372a18f8a863786e8ef11d93c27121098fa" alt=""
kubectl get pod -n kube-system
data:image/s3,"s3://crabby-images/32256/3225614880c8871afcd4880269b7b02f95eaf110" alt=""
证书有效期
#证书有效期的问题,kubeadm默认只有1年:
openssl x509 -in /etc/kubernetes/pki/ca.crt -noout -text | grep Not
openssl x509 -in /etc/kubernetes/pki/apiserver.crt -noout -text | grep Not
chmod 777 update-kubeadm-cert.sh all
./update-kubeadm-cert.sh all
data:image/s3,"s3://crabby-images/c02d4/c02d41c10d558b5eb311f10f7b17ee02b1ce979c" alt=""
看有效期
data:image/s3,"s3://crabby-images/fbcca/fbcca67e178ae2dc43946b05d4fba18c41d533c0" alt=""
data:image/s3,"s3://crabby-images/8d734/8d7346b4f86afe8bcceb6c020311743006f18549" alt=""
运行脚本改日期
data:image/s3,"s3://crabby-images/75ac6/75ac6b91c4369ef303724b92c449961078f2ae5d" alt=""
赋权,然后运行脚本
data:image/s3,"s3://crabby-images/771a0/771a0d6c734b7704185bf9aeae54d8c4e6bf752e" alt=""
//在master节点查看节点状态
kubectl get nodes
kubectl get pods -n kube-system
data:image/s3,"s3://crabby-images/c277e/c277e335629471cb264196ff0c2202596ca5a5a1" alt=""
添加自动补齐
data:image/s3,"s3://crabby-images/1c692/1c6929f3e880a83d2dafa6ebba8a02fb17173792" alt=""
集群已经搭建完毕
data:image/s3,"s3://crabby-images/29a6a/29a6a1d09ad50620400a9c59cd26d9d9a7bde18f" alt=""
验证
创建镜像
kubectl create deployment nginx --image=nginx --replicas=3
data:image/s3,"s3://crabby-images/1833b/1833b38d89af3a1d3022aaee5dced61fbc474dcf" alt=""
kubectl get pods
data:image/s3,"s3://crabby-images/54e67/54e67a882fea86e558327c2f273d9478605184f5" alt=""
kubectl describe pod
data:image/s3,"s3://crabby-images/fc38e/fc38ecc185f17e4ab8eb76f8202c5fbab4d68266" alt=""
pod后面加name,可以查看状态
做个server
kubectl get svc
data:image/s3,"s3://crabby-images/69273/69273d520bf690a9a434911572547a37100cf8e0" alt=""
data:image/s3,"s3://crabby-images/92e5f/92e5fa001b1d6607f9616391f56e0036b502cd25" alt=""
Curl +ip :31038
搭建仓库:
Test4:
//上传 harbor-offline-installer-v2.8.1.tgz 和 docker-compose 文件到 /opt 目录
cd /opt
cp docker-compose /usr/local/bin/
chmod +x /usr/local/bin/docker-compose
data:image/s3,"s3://crabby-images/8d2d5/8d2d5c0f9df7c6bcab768e3132827e490b48113d" alt=""
data:image/s3,"s3://crabby-images/132de/132de6754696dc69cec41d58fa0771c5cad6352b" alt=""
data:image/s3,"s3://crabby-images/c9529/c952971eb7410d8f287150778ebbca491dcc30e3" alt=""
tar zxvf harbor-offline-installer-v2.8.1.tgz
data:image/s3,"s3://crabby-images/706df/706df4330cf0c081603ec0c6007b22da8f205de4" alt=""
data:image/s3,"s3://crabby-images/ea2f7/ea2f701c76c8fe3e787c51fa8658c2b8c4b8b3b7" alt=""
cd harbor/
data:image/s3,"s3://crabby-images/17ecf/17ecff126afa2e022ff08dc837ceaa6ad388fee5" alt=""
vim harbor.yml
data:image/s3,"s3://crabby-images/4cedf/4cedfba105fc28246ddf5e6cdaa300a19aff018f" alt=""
data:image/s3,"s3://crabby-images/91b0c/91b0c074b604d379aa0d5d43f015e850977d33ff" alt=""
data:image/s3,"s3://crabby-images/fccbd/fccbd99dd05d72aaccba75365397081711c76a3e" alt=""
data:image/s3,"s3://crabby-images/e4a7d/e4a7d336cfe29b38df4e67e5509f702e8ee707d1" alt=""
data:image/s3,"s3://crabby-images/c3eb6/c3eb6ad3262d6231fb3ad668290637a9b57df418" alt=""
data:image/s3,"s3://crabby-images/42859/428596fd7c9a93f8f6e0b469571a11bad336e307" alt=""
data:image/s3,"s3://crabby-images/70527/7052745c83ac5e5c8aada1c2ee7f39646ae46a00" alt=""
data:image/s3,"s3://crabby-images/745fa/745faa10858614fc3a259535fdff1d70ef65666c" alt=""
安装 部署与k8s集群对接的Harbor仓库
//上传 harbor-offline-installer-v2.8.1.tgz 和 docker-compose 文件到 /opt 目录
cd /opt
cp docker-compose /usr/local/bin/
chmod +x /usr/local/bin/docker-compose
tar zxvf harbor-offline-installer-v2.8.1.tgz
cd harbor/
vim harbor.yml
hostname = hub.test.com
https:
https port for harbor, default is 443
port: 443
The path of cert and key files for nginx
certificate: /data/cert/server.crt
private_key: /data/cert/server.key
harbor_admin_password = 123456
//生成证书
mkdir -p /data/cert
cd /data/cert
#生成私钥
openssl genrsa -des3 -out server.key 2048
输入两遍密码:123456
openssl genrsa: 用于生成 RSA 密钥。
-des3: 使用 Triple DES 加密算法对生成的私钥进行加密。
-out server.key: 指定生成的私钥文件的名称为 server.key。
2048: 指定 RSA 密钥的位数为 2048 位。
#生成证书签名请求文件
openssl req -new -key server.key -out server.csr
输入私钥密码:123456
输入国家名:CN
输入省名:BJ
输入市名:BJ
输入组织名:TEST
输入机构名:TEST
输入域名:hub.kgc.com
输入管理员邮箱:admin@test.com
其它全部直接回车
#备份私钥
cp server.key server.key.org
#清除私钥密码
openssl rsa -in server.key.org -out server.key
输入私钥密码:123456
#签名证书
openssl x509 -req -days 1000 -in server.csr -signkey server.key -out server.crt
chmod +x /data/cert/*
cd /opt/harbor/
./prepare
./install.sh
在本地使用火狐浏览器访问:https://20.0.0.74
添加例外 -> 确认安全例外
用户名:admin
密码:123456
Node2
mkdir -p /etc/docker/certs.d/hub.test.com/
data:image/s3,"s3://crabby-images/7abdf/7abdf82e78b91393b8ec2abdea00a3f23be5b634" alt=""
Harbor操作
scp -r data/ root@20.0.0.72:/
data:image/s3,"s3://crabby-images/35ece/35ece0fe87bdf29fb48439aed524966de9d8a507" alt=""
data:image/s3,"s3://crabby-images/697a8/697a8656cef5ee58664868c705bf9836cf1834c8" alt=""
data:image/s3,"s3://crabby-images/c29d4/c29d4c6351f08115ff6e029c86aac8ab6fc0d061" alt=""
映射
data:image/s3,"s3://crabby-images/10435/104353ffd9c9f3e958c924798f1f46fc86d4db79" alt=""
vim /lib/systemd/system/docker.service
data:image/s3,"s3://crabby-images/aca52/aca52dd46f5744993bea4f0a93d1df9f71c07005" alt=""
##修改
ExecStart=/usr/bin/dockerd -H fd:// --containerd=/run/containerd/containerd.sock --insecure-registry=hub.test.com
data:image/s3,"s3://crabby-images/f60b5/f60b56911822a1cb4de1cca0dc9158e849185bbc" alt=""
systemctl daemon-reload
systemctl restart docker
data:image/s3,"s3://crabby-images/7876c/7876cb73322f6c57a17407887a2788b74141f6eb" alt=""
登录
docker login -u admin -p 123456 https://hub.test.com
data:image/s3,"s3://crabby-images/a8198/a81989f220d60584c53eb066909913aee6ee6aa7" alt=""
测试是否成功
data:image/s3,"s3://crabby-images/fa77e/fa77e8fdd311ead5a4554fa2c903e866b6e0237e" alt=""
docker pull nginx
docker tag nginx:latest hub.test.com/library/nginx:v1
docker push hub.test.com/library/nginx:v1
data:image/s3,"s3://crabby-images/57bfd/57bfdd7fd33145a207f9a8d6c3f5109faa97b6f9" alt=""
Node3也是同样的操作
mkdir -p /etc/docker/certs.d/hub.test.com/
scp -r data/ root@20.0.0.73:/
mkdir -p /etc/docker/certs.d/hub.test.com/
cd /data/cert/
cp server.crt server.csr server.key /etc/docker/certs.d/hub.test.com/
cd /etc/docker/certs.d/hub.test.com/
data:image/s3,"s3://crabby-images/c29d4/c29d4c6351f08115ff6e029c86aac8ab6fc0d061" alt=""
vim /etc/hosts
vim /lib/systemd/system/docker.service
#添加
ExecStart=/usr/bin/dockerd -H fd:// --containerd=/run/containerd/containerd.sock --insecure-registry=hub.test.com
systemctl daemon-reload
systemctl restart docker
docker login -u admin -p 123456 https://hub.test.com
演示从仓库拉取镜像
kubectl create deployment nginx --image=hub.test.com/library/nginx:v1 --replicas=3
data:image/s3,"s3://crabby-images/3c7cf/3c7cf5df7d64d2d9e036f471f05eb8f2aba838fc" alt=""
拉取失败
kubectl get pods
data:image/s3,"s3://crabby-images/57831/57831e542c92988dc45fa45c92aab9d7ad261d09" alt=""
把harbor权限改为公开
即可成功
data:image/s3,"s3://crabby-images/9b7d5/9b7d5bc292897f60ac3e9377a380f96e8eda2f68" alt=""
基于deployments,创建的无法通过delete删除,必须要先删除deployments.apps,如上图所示
绑定到集群,#获取token值
data:image/s3,"s3://crabby-images/c647a/c647a0354351bd5bbc4533a1eb0139798a514023" alt=""
data:image/s3,"s3://crabby-images/ea2c1/ea2c121910756227192bec249583d298b779ff90" alt=""
创建用户,获取token
data:image/s3,"s3://crabby-images/74d9b/74d9b33ede65191523133bbc44642cecca6400f1" alt=""
data:image/s3,"s3://crabby-images/d19e6/d19e6e4749a482e53efbf6afd3401fc2f135839b" alt=""
浏览器登录