美文网首页容器
K8S集群安装部署

K8S集群安装部署

作者: sspa | 来源:发表于2019-08-26 15:36 被阅读0次

参考地址:https://www.cnblogs.com/xkops/p/6169034.html

1. 确保系统已经安装epel-release源

# yum -y install epel-release

2. 关闭防火墙服务和selinx,避免与docker容器的防火墙规则冲突

# systemctl stop firewalld
# systemctl disable firewalld
# setenforce 0

3. 安装配置Kubernetes Master

3.1 使用yum安装etcd和kubernetes-master
# yum -y install etcd kubernetes-master

node:在安装etcd之前确保 /etc/hosts 下的配置正确。

3.2 编辑 /etc/etcd/etcd.conf 文件
ETCD_NAME=default # 默认名称
ETCD_DATA_DIR="/var/lib/etcd/default.etcd" # 默认etcd数据目录
ETCD_LISTEN_CLIENT_URLS="http://0.0.0.0:2379" # 主要0.0.0.0为监听的网卡地址,不要乱改
ETCD_ADVERTISE_CLIENT_URLS="http://localhost:2379" # 连接的etc地址,本文是单机版的etcd,不用改变
3.3 编辑 /etc/kubernetes/apiserver 文件
KUBE_API_ADDRESS="--insecure-bind-address=0.0.0.0"
KUBE_API_PORT="--port=8080"
KUBELET_PORT="--kubelet-port=10250"
KUBE_ETCD_SERVERS="--etcd-servers=http://127.0.0.1:2379"
KUBE_SERVICE_ADDRESSES="--service-cluster-ip-range=10.254.0.0/16"
KUBE_ADMISSION_CONTROL="--admission-control=NamespaceLifecycle,NamespaceExists,LimitRanger,SecurityContextDeny,ResourceQuota"
KUBE_API_ARGS=""
3.4 启动 etcd, kube-apiserver, kube-controller-manager, kube-scheduler 等服务,并设置开机启动。
# for SERVICES in etcd kube-apiserver kube-controller-manager kube-scheduler; do systemctl restart $SERVICES;systemctl enable $SERVICES;systemctl status $SERVICES ; done

注意:如果服务启动失败请运行 cat /usr/lib/systemd/system/$SERVICES 命令注意如下字段的信息提示:

[Service]
WorkingDirectory=/var/lib/kubelet
EnvironmentFile=-/etc/kubernetes/config
EnvironmentFile=-/etc/kubernetes/kubelet
ExecStart=/usr/bin/kubelet \
        $KUBE_LOGTOSTDERR \
        $KUBE_LOG_LEVEL \
        $KUBELET_API_SERVER \
        $KUBELET_ADDRESS \
        $KUBELET_PORT \
        $KUBELET_HOSTNAME \
        $KUBE_ALLOW_PRIV \
        $KUBELET_POD_INFRA_CONTAINER \
        $KUBELET_ARGS
Restart=on-failure

对比各个参数配置,查找问题。

3.5 在etcd中定义flannel网络
# etcdctl mk /atomic.io/network/config '{"Network":"172.17.0.0/16"}'

4. 安装配置Kubernetes Node

4.1 使用yum安装flannel和kubernetes-node
# yum -y install flannel kubernetes-node
4.2 为flannel网络指定etcd服务,修改 /etc/sysconfig/flanneld 文件
FLANNEL_ETCD="http://master:2379" # master地址
FLANNEL_ETCD_KEY="/atomic.io/network"
4.3 修改 /etc/kubernetes/config 文件
KUBE_LOGTOSTDERR="--logtostderr=true"
KUBE_LOG_LEVEL="--v=0"
KUBE_ALLOW_PRIV="--allow-privileged=false"
KUBE_MASTER="--master=http://master:8080"# master地址
4.4 按照如下内容修改对应node的配置文件/etc/kubernetes/kubelet
KUBELET_ADDRESS="--address=0.0.0.0"
KUBELET_PORT="--port=10250"
KUBELET_HOSTNAME="--hostname-override=node" #修改成对应Node的IP
KUBELET_API_SERVER="--api-servers=http://master:8080" #指定Master节点的API Server
KUBELET_POD_INFRA_CONTAINER="--pod-infra-container-image=registry.access.redhat.com/rhel7/pod-infrastructure:latest"
KUBELET_ARGS=""
4.5 在所有Node节点上启动 kube-proxy,kubelet,docker,flanneld 等服务,并设置开机启动。
# for SERVICES in kube-proxy kubelet docker flanneld;do systemctl restart $SERVICES;systemctl enable $SERVICES;systemctl status $SERVICES; done

5. 验证集群是否安装成功

在master上执行如下命令:

# kubectl get node

相关文章

  • jenkins x 在阿里云主机上安装

    1、ssh登录阿里云k8s集群的master节点上进行安装部署,确保主机上已经安装了k8s集群和helm clie...

  • 部署k8s 1.22.2 集群 && Euler部署k8s 1

    部署k8s 1.22.2 集群 Euler部署k8s 1.22.2 集群 一、基础环境 主机名IP地址角色系统ma...

  • GlusterFS部署

    GlusterFS部署 准备 1. 目标 安装GlusterFS集群的主要目的是为k8s集群提供分布式持久化存储。...

  • 二进制安装K8S(基于1.19.16版本)

    前言 通过kubeadmin安装K8S集群可以做到快速部署,但是如果需要调整K8S各个组件及服务的安全配置,高可用...

  • 【原创】记一次k8s单机部署

    记一次k8s单机部署 目录 环境 基本安装 k8s集群初始化 安装过程中遇到的问题 安装完成后的配置 配置tomc...

  • 一文学会 K8S故障处理

    1 集群故障概述 在k8s集群的部署过程中,大家可能会遇到很多问题。这也是本地部署k8s集群遇到的最大挑战,因此本...

  • k8s-访问外网服务的两种方式

    需求 k8s集群内的pod需要访问mysql,由于mysql的性质,不适合部署在k8s集群内,故k8s集群内的应用...

  • k8s离线下载安装包指南

    因为公司部署k8s的时候需要在现场的内网环境安装,所以需要在无网环境进行安装k8s集群,所以在现场规划设备和系统时...

  • ubuntu 安装 k8s

    前言 本文介绍如何在ubuntu上部署k8s集群,大致可以分为如下几个步骤: 修改ubuntu配置 安装docke...

  • K8S的安装(Ubuntu 20.04)

    前言 本文介绍如何在ubuntu上部署k8s集群,大致可以分为如下几个步骤: 修改ubuntu配置 安装docke...

网友评论

    本文标题:K8S集群安装部署

    本文链接:https://www.haomeiwen.com/subject/tbtdectx.html