云原生(第六篇)k8s-kubeadmin部署(需要和docker版本兼容)

这篇具有很好参考价值的文章主要介绍了云原生(第六篇)k8s-kubeadmin部署(需要和docker版本兼容)。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

k8s与docker版本,k8s,云原生,kubernetes,容器

master(2C/4G,cpu核心数要求大于2)        192.168.169.10        docker、kubeadm、kubelet、kubectl、flannel
node01(2C/2G)                            192.168.169.30         docker、kubeadm、kubelet、kubectl、flannel
node02(2C/2G)                            192.168.169.40         docker、kubeadm、kubelet、kubectl、flannel
Harbor节点(hub.kgc.com)                192.168.169.50         docker、docker-compose、harbor-offline-v1.2.2

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

前期准备:

 所有节点,关闭防火墙规则,关闭selinux,关闭swap交换
systemctl stop firewalld
systemctl disable firewalld
setenforce 0
sed -i 's/enforcing/disabled/' /etc/selinux/config
iptables -F && iptables -t nat -F && iptables -t mangle -F && iptables -X
swapoff -a                        #交换分区必须要关闭
sed -ri 's/.*swap.*/#&/' /etc/fstab        #永久关闭swap分区,&符号在sed命令中代表上次匹配的结果
#加载 ip_vs 模块
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

k8s与docker版本,k8s,云原生,kubernetes,容器

修改主机名
hostnamectl set-hostname master01
hostnamectl set-hostname node01
hostnamectl set-hostname node02

所有节点修改hosts文件
vim /etc/hosts
192.168.169.10 master01
192.168.169.40 node01
192.168.169.50 node02

调整内核参数
cat > /etc/sysctl.d/kubernetes.conf << EOF
#开启网桥模式,可将网桥的流量传递给iptables链
net.bridge.bridge-nf-call-ip6tables=1
net.bridge.bridge-nf-call-iptables=1
#关闭ipv6协议
net.ipv6.conf.all.disable_ipv6=1
net.ipv4.ip_forward=1
EOF

生效参数
sysctl --system  

k8s与docker版本,k8s,云原生,kubernetes,容器

时间同步:

  1. yum install ntpdate -y

  2. ntpdate time.windows.com

所有节点安装docker

第一种方式:

yum install -y yum-utils device-mapper-persistent-data lvm2 
yum-config-manager --add-repo https://mirrors.aliyun.com/docker-ce/linux/centos/docker-ce.repo 
yum install -y docker-ce docker-ce-cli containerd.io 

k8s与docker版本,k8s,云原生,kubernetes,容器

第二种方式:


 1、使用wget命令下载docker-ce.repo
 
 wget https://mirrors.aliyun.com/docker-ce/linux/centos/docker-ce.repo -O /etc/yum.repos.d/docker-ce.repo  
 
2、安装docker18.06.1版本
 
    yum -y install docker-ce-18.06.1.ce-3.el7
 
3、设置开机自启,并启动docker
 
    systemctl enable docker && systemctl start docker
 
4、查看docker版本
 
    docker --version


 

mkdir /etc/docker

cat > /etc/docker/daemon.json <<EOF
{
"registry-mirrors": ["https://6ijb8ubo.mirror.aliyuncs.com"],
"exec-opts": ["native.cgroupdriver=systemd"],
"log-driver": "json-file",
"log-opts": {
"max-size": "100m"
}
}
EOF

使用Systemd管理的Cgroup来进行资源控制与管理,因为相对Cgroupfs而言,Systemd限制CPU、内存等资源更加简单和成熟稳定。
日志使用json-file格式类型存储,大小为100M,保存在/var/log/containers目录下,方便ELK等日志系统收集和管理日志。

k8s与docker版本,k8s,云原生,kubernetes,容器

systemctl daemon-reload
systemctl restart docker.service
systemctl enable docker.service 

docker info | grep "Cgroup Driver"

所有节点安装kubeadm,kubelet和kubectl

定义kubernetes源

vim /etc/yum.repos.d/kubernetes.repo

[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

k8s与docker版本,k8s,云原生,kubernetes,容器

yum install -y kubelet-1.18.0 kubeadm-1.18.0 kubectl-1.18.0

开机自启kubelet
systemctl enable kubelet.service
K8S通过kubeadm安装出来以后都是以Pod方式存在,即底层是以容器方式运行,所以kubelet必须设置开机自启

k8s与docker版本,k8s,云原生,kubernetes,容器

部署K8S集群(只在master上)

查看初始化需要的镜像
kubeadm config images list --kubernetes-version 1.18.0

k8s与docker版本,k8s,云原生,kubernetes,容器

mkdir /opt/k8s

cd /opt/k8s

kubeadm config print init-defaults > /opt/k8s/kubeadm-config.yaml

......
11 localAPIEndpoint:
12   advertiseAddress: 192.168.169.10		#指定master节点的IP地址
13   bindPort: 6443
......
32 imageRepository: registry.cn-hangzhou.aliyuncs.com/google_containers          #指定拉取镜像的仓库,默认是k8s.gcr.io
33 kind: ClusterConfiguration
34 kubernetesVersion: v1.20.15				#指定kubernetes版本号
35 networking:
36   dnsDomain: cluster.local
37   podSubnet: "10.244.0.0/16"				#指定pod网段,10.244.0.0/16用于匹配flannel默认网段
38   serviceSubnet: 10.96.0.0/16			#指定service网段
39 scheduler: {}
#末尾再添加以下内容
--- 
apiVersion: kubeproxy.config.k8s.io/v1alpha1
kind: KubeProxyConfiguration
mode: ipvs									#把默认的kube-proxy调度方式改为ipvs模式

 k8s与docker版本,k8s,云原生,kubernetes,容器

k8s与docker版本,k8s,云原生,kubernetes,容器

k8s与docker版本,k8s,云原生,kubernetes,容器在线拉取镜像
kubeadm config images pull --config /opt/k8s/kubeadm-config.yaml

k8s与docker版本,k8s,云原生,kubernetes,容器

 初始化 master

kubeadm init --config=/opt/k8s/kubeadm-config.yaml --upload-certs | tee kubeadm-init.log

复制这个到从节点执行(在后面执行完flannel) kubeadm join 192.168.169.10:6443 --token abcdef.0123456789abcdef \
    --discovery-token-ca-cert-hash sha256:eb878f3d78fe3af29c9c0cf3d0f1296f49da445ae9f3efea84f78ec126c0be8a


#--upload-certs 参数可以在后续执行加入节点时自动分发证书文件
#tee kubeadm-init.log 用以输出日志
k8s与docker版本,k8s,云原生,kubernetes,容器

查看 kubeadm-init 日志
less kubeadm-init.log

//kubernetes配置文件目录
ls /etc/kubernetes/

//存放ca等证书和密码的目录
ls /etc/kubernetes/pki    

k8s与docker版本,k8s,云原生,kubernetes,容器

设定kubectl

kubectl需经由API server认证及授权后方能执行相应的管理操作,kubeadm 部署的集群为其生成了一个具有管理员权限的认证配置文件 /etc/kubernetes/admin.conf,它可由 kubectl 通过默认的 “$HOME/.kube/config” 的路径进行加载。

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

k8s与docker版本,k8s,云原生,kubernetes,容器
//如果 kubectl get cs 发现集群不健康,更改以下两个文件
vim /etc/kubernetes/manifests/kube-scheduler.yaml 
vim /etc/kubernetes/manifests/kube-controller-manager.yaml
# 修改如下内容
把--bind-address=127.0.0.1变成--bind-address=192.168.80.10        #修改成k8s的控制节点master01的ipk8s与docker版本,k8s,云原生,kubernetes,容器
把httpGet:字段下的hosts由127.0.0.1变成192.168.80.10(有两处)

#- --port=0                # 搜索port=0,把这一行注释掉

k8s与docker版本,k8s,云原生,kubernetes,容器

systemctl restart kubelet

 所有节点部署网络插件flannel 

方法一:
//所有节点上传 flannel 镜像 flannel.tar 和网络插件 cni-plugins-linux-amd64-v0.8.6.tgz 到 /opt 目录,master节点上传 kube-flannel.yml 文件
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 

方法二:

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


//在 node 节点上执行 kubeadm join 命令加入群集
kubeadm join 192.168.169.10:6443 --token rc0kfs.a1sfe3gl4dvopck5 \
    --discovery-token-ca-cert-hash sha256:864fe553c812df2af262b406b707db68b0fd450dc08b34efb73dd5a4771d37a2

在master节点查看节点状态
kubectl get nodes文章来源地址https://www.toymoban.com/news/detail-724313.html

到了这里,关于云原生(第六篇)k8s-kubeadmin部署(需要和docker版本兼容)的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • kubeadmin安装k8s集群

    目录 一 、环境部署 1、服务器规划 2、环境准备 二、所有节点安装docker 1、配置yum源,安装docker 2、配置daemon.json文件  三、所有节点安装kubeadm、kubelet 和kubectl   四、部署k8s集群 1、查看初始化需要的镜像 2、导入镜像  3、初始化kubeadm 3.1 方法一:通过修改配置文件初始化

    2024年02月09日
    浏览(37)
  • kubeadmin搭建自建k8s集群

    在开始之前,部署Kubernetes集群的虚拟机需要满足以下几个条件: 操作系统 CentOS7.x-86_x64 硬件配置:2GB或更多RAM,2个CPU或更多CPU,硬盘30GB或更多【注意master需要两核】 可以访问外网,需要拉取镜像,如果服务器不能访问外网,需要提前下载镜像包并导入节点服务器中(网上

    2024年04月27日
    浏览(26)
  • 【云原生】Kubeadmin部署Kubernetes集群

    目录 ​编辑 一、环境准备 1.2调整内核参数 二、所有节点部署docker 三、所有节点安装kubeadm,kubelet和kubectl 3.1定义kubernetes源 3.2开机自启kubelet 四、部署K8S集群 4.1查看初始化需要的镜像 4.2在 master 节点上传 v1.20.11.zip 压缩包至 /opt 目录 4.3复制镜像和脚本到 node 节点,并在 nod

    2024年02月09日
    浏览(34)
  • KubeAdmin方式搭建K8S(1.26.0)

    本次安装K8S版本为1.26.0 ip 描述 配置 192.168.233.221 master节点 CPU(2C) 内存(2G) 硬盘(50G) 192.168.233.222 node1节点 CPU(2C) 内存(2G) 硬盘(50G) 192.168.233.223 node2节点 CPU(2C) 内存(2G) 硬盘(50G) 服务器环境配置三台服务器都要执行下面的操作 kubernetes和docker在运行中会产

    2024年02月11日
    浏览(36)
  • 【云原生】Kubeadm部署k8s

    在所有节点上安装Docker和kubeadm 部署Kubernetes Master 部署容器网络插件 部署 Kubernetes Node,将节点加入Kubernetes集群中 部署 Dashboard Web 页面,可视化查看Kubernetes资源 实验环境 服务器 IP地址 主要组件 master 192.168.10.130 docker/kubeadm/kubelet/kubectl/flannel node01 192.168.10.133 docker/kubeadm/kubel

    2024年02月04日
    浏览(41)
  • 【云原生篇】K8S部署全面指南

    部署Kubernetes(K8s)有多种方式,可以根据组织的需求、基础设施和资源来选择最合适的部署方法。以下是一些主流的Kubernetes部署方式: 1. 手动部署 kubeadm :Kubernetes官方提供的工具,可以帮助你快速部署和配置Kubernetes集群。它适合于学习和小规模生产环境,但对于大规模部

    2024年04月10日
    浏览(38)
  • 【云原生】k8s组件&架构介绍与K8s最新版部署

          个人主页: 征服bug-CSDN博客 kubernetes专栏: kubernetes_征服bug的博客-CSDN博客  目录 1 集群组件 1.1 控制平面组件(Control Plane Components) 1.2 Node 组件 1.3 插件 (Addons) 2 集群架构详细 3 集群搭建[重点] 3.1 minikube 3.2 裸机安装 集群组件 核心概念 集群安装 集群 cluster : 将同一个

    2024年02月14日
    浏览(47)
  • 【云原生K8s】二进制部署单master K8s+etcd集群

                                                    mater节点 master01 192.168.190.10 kube-apiserver kube-controller-manager kube-scheduler etcd                                                 node节点 node01 192.168.190.20 kubelet kube-proxy docker (容器引擎) node02 192.168.190.30 kubelet kube-proxy do

    2024年02月14日
    浏览(57)
  • DolphinScheduler on k8s 云原生部署实践

    DolphinScheduler 的高效云原生部署模式,比原始部署模式节省了95%以上的人力资源和工作时间,提升了部署效率和成本效益。 通过集成 GitOps 技术,我们提升了 DolphinScheduler 的 DevOps 管理能力,改善了软件交付效率和安全审计能力。 通过集成新的云原生技术,我们为 DolphinSched

    2024年04月10日
    浏览(37)
  • 原生K8S部署pig微服务项目

    项目地址:码云 Pig微服务项目 基于 Spring Cloud 2021 、Spring Boot 2.7、 OAuth2 的 RBAC 权限管理系统 基于数据驱动视图的理念封装 element-plus,即使没有 vue 的使用经验也能快速上手 提供对常见容器化支持 Docker、Kubernetes、Rancher2 支持 提供 lambda 、stream api 、webflux 的生产实践 pig-ui –

    2024年02月03日
    浏览(41)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包