首页 > 其他分享 >kubernetes 1.27.1最新版集群部署

kubernetes 1.27.1最新版集群部署

时间:2023-04-25 18:55:34浏览次数:55  
标签:cri kubernetes k8s 1.27 registry io docker 最新版 com

kubernetes 1.27.1 最新版集群部署国内环境

官方安装部署文档:https://kubernetes.io/zh-cn/docs/setup/production-environment/tools/kubeadm/install-kubeadm/

准备云服务器

首先买三台服务器。我用的阿里云服务器。

https://pic-keboom.oss-cn-hangzhou.aliyuncs.com/20230424111614.png

三台服务器如下,然后我用的Tabby连接三台服务器。

https://pic-keboom.oss-cn-hangzhou.aliyuncs.com/20230424112135.png

我以 i-bp12igqv5c7kdligslo2 私网地址为:172.16.146.249 这个实例为master节点。

主节点和从节点都需要做的

关闭SELinux,禁用SELinux的目的是让容器可以读取主机文件系统

sudo setenforce 0
sudo sed -i 's/^SELINUX=enforcing$/SELINUX=permissive/' /etc/selinux/config

关闭swap,如果内存不够用,直接起新节点,而不是让节点hang住

swapoff -a
sed -ri 's/.*swap.*/#&/' /etc/fstab

允许 iptables 检查桥接流量

cat <<EOF | sudo tee /etc/modules-load.d/k8s.conf
br_netfilter
EOF

cat <<EOF | sudo tee /etc/sysctl.d/k8s.conf
net.bridge.bridge-nf-call-ip6tables = 1
net.bridge.bridge-nf-call-iptables = 1
EOF
sudo sysctl --system

添加hosts

vim /etc/hosts
172.16.146.249 k8s-master
172.16.146.248 k8s-node1
172.16.146.247 k8s-node2

安装docker。

安装kubelet、kubeadm、kubectl。

安装docker

https://pic-keboom.oss-cn-hangzhou.aliyuncs.com/20230424113016.png

Alibaba Cloud Linux 3 (Soaring Falcon) 此系统兼容centos和RHEL

我们用centos安装方式安装docker, https://docs.docker.com/engine/install/centos/

sudo yum install -y yum-utils
sudo yum-config-manager \
    --add-repo \
    https://download.docker.com/linux/centos/docker-ce.repo
sudo yum install docker-ce docker-ce-cli containerd.io docker-buildx-plugin docker-compose-plugin
sudo systemctl start docker
sudo docker run hello-world

三台服务器都需要安装docker。接着我们配置docker镜像加速

https://pic-keboom.oss-cn-hangzhou.aliyuncs.com/20230424113818.png

sudo mkdir -p /etc/docker
sudo tee /etc/docker/daemon.json <<-'EOF'
{
  "registry-mirrors": ["https://qkmogfd4.mirror.aliyuncs.com"]
}
EOF
sudo systemctl daemon-reload
sudo systemctl restart docker

可以使用docker info 查看Registry Mirrors 是否成功配置了阿里云镜像。

安装cri-dockerd

安装go:https://go.dev/doc/install

cd /usr/local
# 下载 go1.20.3.linux-amd64.tar.gz 好像需要FQ,那么现在本地下载完后,上传到服务器/usr/local目录下
rm -rf /usr/local/go && tar -C /usr/local -xzf go1.20.3.linux-amd64.tar.gz
export PATH=$PATH:/usr/local/go/bin  # 可以把他放到类似/etc/profile文件中
go version

接着安装cri-dockerd,我将cri-dockerd安装在 /opt 目录下。

项目地址:https://github.com/Mirantis/cri-dockerd

安装git :yum install git ,服务器访问github慢的,网上说的改hosts对我来说有用

git clone https://github.com/Mirantis/cri-dockerd.git
cd cri-dockerd
mkdir bin
go build -o bin/cri-dockerd   # 这一步比较耗时,耐心等待
mkdir -p /usr/local/bin
install -o root -g root -m 0755 bin/cri-dockerd /usr/local/bin/cri-dockerd
cp -a packaging/systemd/* /etc/systemd/system
sed -i -e 's,/usr/bin/cri-dockerd,/usr/local/bin/cri-dockerd,' /etc/systemd/system/cri-docker.service
systemctl daemon-reload
systemctl enable cri-docker.service
systemctl enable --now cri-docker.socket

安装kubelet、kubeadm、kubectl

https://developer.aliyun.com/mirror/kubernetes/

cat <<EOF > /etc/yum.repos.d/kubernetes.repo
[kubernetes]
name=Kubernetes
baseurl=https://mirrors.aliyun.com/kubernetes/yum/repos/kubernetes-el7-x86_64/
enabled=1
gpgcheck=1
repo_gpgcheck=1
gpgkey=https://mirrors.aliyun.com/kubernetes/yum/doc/yum-key.gpg https://mirrors.aliyun.com/kubernetes/yum/doc/rpm-package-key.gpg
EOF
setenforce 0
yum install -y kubelet kubeadm kubectl
systemctl enable kubelet && systemctl start kubelet

主节点部署

https://pic-keboom.oss-cn-hangzhou.aliyuncs.com/20230424133146.png

国内访问不了registry.k8s.io,我们用阿里云的镜像,我们使用命令:

kubeadm config images pull --image-repository registry.cn-hangzhou.aliyuncs.com/google_containers --cri-socket=unix:///var/run/cri-dockerd.sock

接着k8s会获取registry.k8s.io前缀的镜像,那么我们:

docker tag registry.cn-hangzhou.aliyuncs.com/google_containers/kube-apiserver:v1.27.1 \
registry.k8s.io/kube-apiserver:v1.27.1

docker tag registry.cn-hangzhou.aliyuncs.com/google_containers/kube-scheduler:v1.27.1 \
registry.k8s.io/kube-scheduler:v1.27.1

docker tag registry.cn-hangzhou.aliyuncs.com/google_containers/kube-controller-manager:v1.27.1 \
registry.k8s.io/kube-controller-manager:v1.27.1

docker tag registry.cn-hangzhou.aliyuncs.com/google_containers/kube-proxy:v1.27.1 \
registry.k8s.io/kube-controller-manager:v1.27.1

docker tag registry.cn-hangzhou.aliyuncs.com/google_containers/coredns:v1.10.1 \
registry.k8s.io/coredns:v1.10.1

docker tag registry.cn-hangzhou.aliyuncs.com/google_containers/etcd:3.5.7-0 \
registry.k8s.io/etcd:3.5.7-0 

docker tag registry.cn-hangzhou.aliyuncs.com/google_containers/pause:3.6 \
registry.k8s.io/pause:3.6

-------------------------- 这个pause3.6和3.9建议都下载,我部署的时候总出问题
docker tag registry.cn-hangzhou.aliyuncs.com/google_containers/pause:3.9 \
registry.k8s.io/pause:3.9
kubeadm init \
--apiserver-advertise-address=172.16.146.249 \
--control-plane-endpoint=k8s-master \
--image-repository [registry.cn-hangzhou.aliyuncs.com/](http://registry.cn-hangzhou.aliyuncs.com/)google_containers \
--cri-socket=unix:///var/run/cri-dockerd.sock \
--pod-network-cidr=192.168.0.0/16 \
--v=5

生成kubeconfig文件

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

安装网络插件Calico

https://docs.tigera.io/calico/latest/getting-started/kubernetes/quickstart

按照文档一步步安装即可,要注意的是 kubeadm init 时 pod-network-cidr网络地址。

如果你设置的不是192.168.0.0/16,那么需要在creating custom resource时,修改相应的值。

最终执行完后,我的主节点pod状态:

https://pic-keboom.oss-cn-hangzhou.aliyuncs.com/20230425163300.png

加入节点

进入到我的 172.16.146.248 k8s-node1172.16.146.247 k8s-node2。将它们加入主节点

我的token过期了,因此我执行kubeadm token create拿到一个新的token。

discovery-token-ca-cert-hash可以通过如下命令获取:

openssl x509 -pubkey -in /etc/kubernetes/pki/ca.crt | openssl rsa -pubin -outform der 2>/dev/null |\
   openssl dgst -sha256 -hex | sed 's/^.* //'
kubeadm join k8s-master:6443 --token ik594p.9jxv0yaohe9piqlj \
        --discovery-token-ca-cert-hash sha256:c6f792668e27516e1425bac6e489503cd483c054793e08675e4b8109b9644058 \
--cri-socket=unix:///var/run/cri-dockerd.sock

https://pic-keboom.oss-cn-hangzhou.aliyuncs.com/20230425164240.png

https://pic-keboom.oss-cn-hangzhou.aliyuncs.com/20230425165201.png

等了很长时间,这些 pod还是没有running,使用命令查看日志:

kubectl describe pods kube-proxy-x75bt -n kube-system

看到是因为registry.k8s.io/pause:3.6拉取失败,我试了在新加的两个node机器上执行:

docker pull registry.cn-hangzhou.aliyuncs.com/google_containers/pause:3.6

docker tag registry.cn-hangzhou.aliyuncs.com/google_containers/pause:3.6 registry.k8s.io/pause:3.6

接着回主节点查看pod状态,发现最终能够成功。

好了,部署过程还是有不少坑的,因为国内网络的问题。如果大家部署过程中有其他问题 ,欢迎评论区讨论。

标签:cri,kubernetes,k8s,1.27,registry,io,docker,最新版,com
From: https://www.cnblogs.com/keboom/p/17353545.html

相关文章

  • mac os下安装k8s的kubernetes-dashboard
     需要这个的继续往下看 环境macos 12.6.2 安装dokcer https://docs.docker.com/desktop/install/mac-install/安装k8s https://blog.csdn.net/qq_20042935/article/details/124472626 <-看这位兄弟写的很详细了安装kubernetes-dashboard 1.创建命名空间 kubec......
  • kubernetes 使用 1
    安装1.用以下命令下载最新发行版:curl-LO"https://dl.k8s.io/release/$(curl-L-shttps://dl.k8s.io/release/stable.txt)/bin/linux/amd64/kubectl"可以用以下方式指定版本curl-LOhttps://dl.k8s.io/release/v1.27.0/bin/linux/amd64/kubectl2.验证该可执行文件(可选步......
  • 升级PVE7到最新版本并设置国内源
    该操作涉及到系统管理,建议在确保自身能力和安全性的情况下进行:升级PVE7到最新版本并设置国内源:删除企业源:sudorm-rf/etc/apt/sources.list.d/pve-enterprise.list添加PVE官方GPGkey:sudowgethttp://mirrors.ustc.edu.cn/proxmox/debian/proxmox-ve-release-6.x.gpg......
  • kubernetes集群的高可用架构
    概述kubernete在云平台的高可用分为两种情形单az的高可用集群搭建多az的高可用集群搭建这两种情形其实就是一个k8s集群内部的高可用,只是多az的场景下能够实现更高级别的高可用,此时k8s需要跨az部署集群。集群内部的高可用需要实现基础组件的高可用,其中最重要的就是etcd和api......
  • photoshop 2022 新功能介绍,ps2021最新版下载mac/win
    ps2021最新版下载Mac版win版 photoshop2022新功能介绍选取主体云端服务在Photoshop2022年8月(23.5版)中,透过我们的「选取主体」云端服务,获得比在装置上进行「选取主体」处理更细致、品质更好的影像。若要使用「选取主体」云端服务,请执行下列任一操作:浏览至「偏好......
  • ubuntu 22.04 安装最新版本的 nodejs
    参考资料:HowToInstallNode.jsonUbuntu20.04采用其中的第二个方法:cd~curl-sLhttps://deb.nodesource.com/setup_18.x-o/tmp/nodesource_setup.shvi/tmp/nodesource_setup.shsudobash/tmp/nodesource_setup.shsudoaptinstallnodejs注意,sudoaptinstallno......
  • kubernetes1.27 kuberadm方式安装全过程
    配置hosts#master"10.102.4.13master">>/etc/hosts#node1"10.102.4.14node1">>/etc/hosts#node2"10.102.4.15node2">>/etc/hosts安装kubeadm、kubelet和kubectl(三台都要)cat<<EOF|sudotee/etc/yum.repos.......
  • 91-云原生操作系统-Kubernetes网络通信常见架构及案例解析
    VxLAN技术演进VxLAN的技术演进二层通信-基于目标mac地址通信,不可夸局域网通信,通常是由接入交换机或汇聚交换机实现报文转发。VLAN(VirtualLocalAreaNetwork)-即虚拟局域网,是将一个物理(交换机)的网络在逻辑上划分成多个广播域的通信技术,VLAN内的主机间可以直接通信,而VLAN网络外......
  • linux openClouldOS 8.6安装最新版MySQL详细教程
    参考linux安装最新版MySQL详细教程rpm包下载其中下载MySQL官网的仓库文件,根据服务器情况选择的RedHatEnterpriseLinux8/OracleLinux8(ArchitectureIndependent),RPMPackage下载地址改为wgethttp://repo.mysql.com/mysql80-community-release-el8-5.noarch.rpm再......
  • k3s 基础 —— 配置 kubernetes dashboard
    安装请参考部署仪表盘GITHUB_URL=https://github.com/kubernetes/dashboard/releasesVERSION_KUBE_DASHBOARD=$(curl-w'%{url_effective}'-I-L-s-S${GITHUB_URL}/latest-o/dev/null|sed-e's|.*/||')sudok3skubectlcreate-fhttps://raw.githu......