Kubernetes1.15.2集群部署并部署Metrics Server插件
admin
2023-03-31 03:41:41
0

环境信息:

操作系统 主机名 IP地址
CentOS 7.6 k8s-master 192.168.31.61
CentOS 7.6 k8s-node1 192.168.31.62
CentOS 7.6 k8s-node2 192.168.31.63

1. 安装要求

在开始之前,部署Kubernetes集群机器需要满足以下几个条件:

  • 操作系统 CentOS7.x-86_x64
  • 硬件配置:2GB或更多RAM,2个CPU或更多CPU,硬盘30GB或更多
  • 集群中所有机器之间网络互通
  • 可以访问外网,需要拉取镜像
  • 禁止swap分区

2. 学习目标

  1. 在所有节点上安装Docker和kubeadm
  2. 部署Kubernetes Master
  3. 部署容器网络插件
  4. 部署 Kubernetes Node,将节点加入Kubernetes集群中
  5. 部署Dashboard Web页面,可视化查看Kubernetes资源

3. 准备环境

关闭防火墙:
$ systemctl stop firewalld
$ systemctl disable firewalld

关闭selinux:
$ sed -i 's/enforcing/disabled/' /etc/selinux/config 
$ setenforce 0

关闭swap:
$ swapoff -a    临时
$ sed -i '/ swap / s/^\(.*\)$/#\1/g' /etc/fstab  永久

添加主机名与IP对应关系(记得设置主机名):
$ cat /etc/hosts
192.168.31.61 k8s-master
192.168.31.62 k8s-node1
192.168.31.63 k8s-node2

将桥接的IPv4流量传递到iptables的链:
$ cat > /etc/sysctl.d/k8s.conf << EOF
net.bridge.bridge-nf-call-ip6tables = 1
net.bridge.bridge-nf-call-iptables = 1
net.ipv4.ip_forward = 1

EOF
$ sysctl --system

4. 所有节点安装Docker/kubeadm/kubelet

4.1 安装Docker

$ wget https://mirrors.aliyun.com/docker-ce/linux/centos/docker-ce.repo -O /etc/yum.repos.d/docker-ce.repo
$ yum -y install docker-ce
$ systemctl enable docker && systemctl start docker

4.2 添加阿里云YUM软件源

$ 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

4.3 安装kubeadm,kubelet和kubectl

指定版本号部署:

$ yum install -y kubelet-1.15.2 kubeadm-1.15.2 kubectl-1.15.2
$ systemctl enable kubelet

5. 部署Kubernetes Master

在192.168.31.63(Master)执行。

$ kubeadm init \
  --apiserver-advertise-address=192.168.31.61 \
  --image-repository registry.aliyuncs.com/google_containers \
  --kubernetes-version v1.15.2 \
  --service-cidr=10.1.0.0/16 \
  --pod-network-cidr=10.244.0.0/16

由于默认拉取镜像地址k8s.gcr.io国内无法访问,这里指定阿里云镜像仓库地址。

使用kubectl工具:

mkdir -p $HOME/.kube
sudo cp -i /etc/kubernetes/admin.conf $HOME/.kube/config
sudo chown $(id -u):$(id -g) $HOME/.kube/config
$ kubectl get nodes

6. 安装Pod网络插件(CNI)

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

确保能够访问到quay.io这个registery。

如果下载失败,可以改成这个镜像地址:lizhenliang/flannel:v0.11.0-amd64

7. 加入Kubernetes Node

在192.168.31.62/63(Node)执行。

向集群添加新节点,执行在kubeadm init输出的kubeadm join命令:

$ kubeadm join 192.168.31.61:6443 --token esce21.q6hetwm8si29qxwn \
    --discovery-token-ca-cert-hash sha256:00603a05805807501d7181c3d60b478788408cfe6cedefedb1f97569708be9c5

8. 测试kubernetes集群

在Kubernetes集群中创建一个pod,验证是否正常运行:

$ kubectl create deployment nginx --image=nginx
$ kubectl expose deployment nginx --port=80 --type=NodePort
$ kubectl get pod,svc

9. 部署 Dashboard

$ kubectl apply -f https://raw.githubusercontent.com/kubernetes/dashboard/v1.10.1/src/deploy/recommended/kubernetes-dashboard.yaml

默认镜像国内无法访问,修改镜像地址为: lizhenliang/kubernetes-dashboard-amd64:v1.10.1

默认Dashboard只能集群内部访问,修改Service为NodePort类型,暴露到外部:

kind: Service
apiVersion: v1
metadata:
  labels:
    k8s-app: kubernetes-dashboard
  name: kubernetes-dashboard
  namespace: kube-system
spec:
  type: NodePort
  ports:
    - port: 443
      targetPort: 8443
      nodePort: 30001
  selector:
    k8s-app: kubernetes-dashboard
$ kubectl apply -f kubernetes-dashboard.yaml

访问地址:http://NodeIP:30001

创建service account并绑定默认cluster-admin管理员集群角色:

$ kubectl create serviceaccount dashboard-admin -n kube-system
$ kubectl create clusterrolebinding dashboard-admin --clusterrole=cluster-admin --serviceaccount=kube-system:dashboard-admin
$ kubectl describe secrets -n kube-system $(kubectl -n kube-system get secret | awk '/dashboard-admin/{print $1}')

使用输出的token登录Dashboard。

Kubernetes集群安装Metrics Server

$ git clone https://github.com/kubernetes-incubator/metrics-server
下载完成后还需要对 metrics-server/deploy/1.8+/resource-reader.yaml文件进行修改
##官方仓库中的清单文件metrics-server-deployment.yaml中未明确主程序metrics-server传递参数指定指标数据的获取接口,它通常应该是kubernetes.summary_api

     image: registry.aliyuncs.com/google_containers/metrics-server-amd64:v0.3.3
      args:
      - --kubelet-insecure-tls
      - --kubelet-preferred-address-types=InternalIP

修改完之后即可直接使用

$ kubectl apply -f deploy/metrics-server/deploy/1.8+/

查看pod是否为Running状态

$   
kubectl get pod -n kube-system

查看节点,POD资源监控

kubectl top node
kubectl top pods -n kube-system

Kubernetes1.15.2集群部署并部署Metrics Server插件
Kubernetes1.15.2集群部署并部署Metrics Server插件
Kubernetes1.15.2集群部署并部署Metrics Server插件

参考李振良老师的博客:https://blog.51cto.com/lizhenliang/2296100

相关内容

热门资讯

台湾方面再次无法参加世卫大会,... 新华社北京5月11日电(记者李寒芳、马欣然)5月11日,国务院台办发言人陈斌华答记者问。有记者问:第...
伊朗外交部发言人:解冻被冻结资... △伊朗外交部发言人巴加埃(资料图)当地时间5月11日,伊朗外交部发言人巴加埃在回应有关伊美谈判主要分...
男子驾驶摩托车国道上逆行致1死... 早前报道 摩托车国道上逆行致1死1伤,骑手出事前曾做手势打招呼来源:大风新闻(2026年05月11日...
外交部:中方决定不同意台湾地区... 5月11日,外交部发言人郭嘉昆主持例行记者会。有记者问:据了解,第七十九届世界卫生大会将于5月18日...
糖果制品中检出伟哥 4月22日,上海市市场监督管理局发布2026年第13期省级食品安全抽检信息,检出3批次不合格食品,不...
伊朗副议长:我国已成为世界第四... 美伊谈判陷入僵局,伊朗拒绝了美国提出的结束战争的方案。以此同时,伊朗副议长巴巴伊5月10日强调,伊朗...
河南760亿省级财政资金定存招... 【大河财立方消息】5月11日消息,河南省财政厅公布2026年度第1期河南省省级财政专户资金定期存款代...
无忧传媒宣布与“孕妇泰国坠崖案... 据北京商报消息,5月11日,记者从无忧传媒方面获悉,目前公司与签约达人王暖暖经友好协商已确定解约。5...
米哈游:编造“皮套论”谣言构成... 【大河财立方消息】 5月11日,据米哈游法务部,近日米哈游诉网络博主许某鹏(网名“自由人米八”)、罗...
外交部介绍特朗普访华具体安排和... 5月11日,外交部发言人郭嘉昆主持例行记者会。总台央视记者提问:中方已经发布美国总统特朗普来华进行国...