小白到运维工程师自学之路 第七十五集 (Kubernetes 企业级高可用部署)2

 8、添加master节点

在k8s-master2和k8s-master3节点创建文件夹
mkdir -p /etc/kubernetes/pki/etcd

在k8s-master1节点执行
从k8s-master1复制密钥和相关文件到k8s-master2和k8s-master3
scp /etc/kubernetes/admin.conf [email protected]:/etc/kubernetes 
scp /etc/kubernetes/pki/{ca.*,sa.*,front-proxy-ca.*} [email protected]:/etc/kubernetes/pki
scp /etc/kubernetes/pki/etcd/ca.* [email protected]:/etc/kubernetes/pki/etcd

scp /etc/kubernetes/admin.conf [email protected]:/etc/kubernetes 
scp /etc/kubernetes/pki/{ca.*,sa.*,front-proxy-ca.*} [email protected]:/etc/kubernetes/pki
scp /etc/kubernetes/pki/etcd/ca.* [email protected]:/etc/kubernetes/pki/etcd

小白到运维工程师自学之路 第七十五集 (Kubernetes 企业级高可用部署)2_第1张图片

kubeadm token create --ttl 0 --print-join-command
kubeadm token list

将其他master节点加入集群

k8s-master2和k8s-master3都需要加入

令牌最后要加上--control-plane

kubeadm join master.k8s.io:6443 --token v1igjz.rsq683im1cbqksur     --discovery-token-ca-cert-hash sha256:c4b73babba1252778d643f80c4c6f77242a3f0aa7a670090bda682eabc12e225 --control-plane

小白到运维工程师自学之路 第七十五集 (Kubernetes 企业级高可用部署)2_第2张图片

小白到运维工程师自学之路 第七十五集 (Kubernetes 企业级高可用部署)2_第3张图片

 cni-plugins-linux-amd64-v0.8.6.tgz(需要去网上下载)

mkdir -p $HOME/.kube
sudo cp -i /etc/kubernetes/admin.conf $HOME/.kube/config
sudo chown $(id -u):$(id -g) $HOME/.kube/config
tar xf cni-plugins-linux-amd64-v0.8.6.tgz
cp flannel /opt/cni/bin/
docker load < flannel_v0.12.0-amd64.tar
kubectl get nodes

 9、加入Kubernetes Node

直接在node节点服务器上执行k8s-master1初始化成功后的消息即可

kubeadm join master.k8s.io:6443 --token v1igjz.rsq683im1cbqksur     --discovery-token-ca-cert-hash sha256:c4b73babba1252778d643f80c4c6f77242a3f0aa7a670090bda682eabc12e225 

docker load < flannel_v0.12.0-amd64.tar

node2和node3的操作和node1一样

小白到运维工程师自学之路 第七十五集 (Kubernetes 企业级高可用部署)2_第4张图片

 查看节点状态

小白到运维工程师自学之路 第七十五集 (Kubernetes 企业级高可用部署)2_第5张图片

四、测试Kubernetes集群

所有node节点下载nginx
docker pull nginx

在master1上创建一个pod
mkdir demo
cd demo
vim nginx-deployment.yaml
apiVersion: apps/v1
kind: Deployment
metadata:
  name: nginx-deployment
  labels:
    app: nginx
spec:
  replicas: 3
  selector: 
    matchLabels:
      app: nginx
  template:
    metadata:
      labels:
        app: nginx
    spec:
      containers:
      - name: nginx
        image: nginx:latest
        ports:
        - containerPort: 80

小白到运维工程师自学之路 第七十五集 (Kubernetes 企业级高可用部署)2_第6张图片

kubectl create -f nginx-deployment.yaml
kubectl get pods
kubectl get pods -o wide

小白到运维工程师自学之路 第七十五集 (Kubernetes 企业级高可用部署)2_第7张图片

创建Service资源清单

在创建的 nginx-service 资源清单中,定义名称为 nginx-service 的 Service、标签选择器为 app: nginx、type 为 NodePort 指明外部流量可以访问内部容器。在 ports 中定义暴露的端口库号列表,对外暴露访问的端口是 80,容器内部的端口也是 80。

vim nginx-service.yaml
kind: Service
apiVersion: v1
metadata:
  name: nginx-service
spec:
  selector:
    app: nginx
  type: NodePort
  ports:
  - protocol: TCP
    port: 80
targetPort: 80

小白到运维工程师自学之路 第七十五集 (Kubernetes 企业级高可用部署)2_第8张图片

kubectl create -f nginx-service.yaml
kubectl get svc

通过虚拟IP访问浏览器

小白到运维工程师自学之路 第七十五集 (Kubernetes 企业级高可用部署)2_第9张图片

测试负载均衡

将master关机模拟服务器宕机,然后再查看

小白到运维工程师自学之路 第七十五集 (Kubernetes 企业级高可用部署)2_第10张图片

再访问web页面

可以看到web应用正常工作

小白到运维工程师自学之路 第七十五集 (Kubernetes 企业级高可用部署)2_第11张图片

去master2上查看,可以发现虚拟IP已经转移到了master2的ens33网卡上了,说明负载均衡配置成功

小白到运维工程师自学之路 第七十五集 (Kubernetes 企业级高可用部署)2_第12张图片

域名也是可以访问的但是由于还要配置windows的防火墙与dns这里就适用命令测试了

小白到运维工程师自学之路 第七十五集 (Kubernetes 企业级高可用部署)2_第13张图片

以上就是Kubernetes 企业级高可用部署

如有错误欢迎各位大佬批评指正,我们共同进步

你可能感兴趣的:(kubernetes,容器,k8s,运维)