位置: IT常识 - 正文

K8s超详细安装部署流程(k8s安装步骤)

编辑:rootadmin
K8s超详细安装部署流程 K8S搭建流程1 准备环境

推荐整理分享K8s超详细安装部署流程(k8s安装步骤),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:k8s最新版本安装,k8s安装部署步骤,k8s yum安装,k8s安装方式对比,k8s安装部署步骤,k8s安装步骤,k8s安装部署步骤,k8s安装步骤,内容如对您有帮助,希望把文章链接给更多的朋友!

1.1 服务器要求:

建议最小硬件配置:2核CPU、2G内存、20G硬盘 服务器最好可以访问 外网,会有从网上拉取镜像需求,如果服务器不能上网,需要提前下载对应镜像并导入节点

1.2 软件环境:

软件版本操作系统CentOS7.9_x64 (mini)Docker20-ceKubernetes1.23

1.3 服务器规划:

服务器名称服务器IPmaster192.168.73.120node1192.168.73.121node2192.168.73.1222. 主机名解析(以下命令 所有节点都要执行)

编辑三台服务器的 /etc/hosts 文件 ,添加下面内容: 192.168.73.120 master 192.168.73.121 node1 192.168.73.122 node2

💡 Tips:注意 ip 是你自己服务器的IP,后边的名字也就是你自己服务器的名称 也可以使用下面命令, 自定义自己服务器的名字:

hostnamectl set-hostname node1(node1 是自定义的)3. 时间同步#启动chronyd服务systemctl start chronydsystemctl enable chronyddate

💡 Tips:执行命令前 可以 使用 rpm -qa |grep chrony 查看系统是否已安装chrony,没有安装环境可使用 yum install chrony 命令安装

4. 禁用selinux和firewalld服务

4.1关闭firewalld服务

systemctl stop firewalldsystemctl disable firewalld

4.2关闭selinux服务

sed -i 's/enforcing/disabled/' /etc/selinux/config #重启后生效5. 禁用swap分区

💡Tips:swap分区指的是虚拟内存分区,它的作用是物理内存使用完,之后将磁盘空间虚拟成内存来使用,启用swap设备会对系统的性能产生非常负面的影响,因此kubernetes要求每个节点都要禁用swap设备,但是如果因为某些原因确实不能关闭swap分区,就需要在集群安装过程中通过明确的参数进行配置说明

编辑分区配置文件/etc/fstab,注释掉swap分区一行 # 注意修改完毕之后需要重启linux服务

vi /etc/fstab#注释掉下面的设置 /dev/mapper/centos-swap swap

💡 Tips: 也可以使用以下命令 进入进行修改, 重启后生效 free -m #查看状态 swapoff -a #临时 sed -ri ‘s/.swap./#&/’ /etc/fstab

6. 添加网桥过滤和地址转发功能cat > /etc/sysctl.d/kubernetes.conf << EOFnet.bridge.bridge-nf-call-ip6tables = 1net.bridge.bridge-nf-call-iptables = 1net.ipv4.ip_forward = 1EOF#然后执行sysctl --system //生效命令7.docker安装

#1.安装docker依赖

yum install -y yum-utils

#2.设置docker仓库镜像地址

yum-config-manager --add-repo http://mirrors.aliyun.com/docker-ce/linux/centos/docker-ce.repo

#3.安装下载docker

yum install docker-ce docker-ce-cli containerd.io

#4.设置docker开机启动

systemctl enable docker && systemctl start docker

#5.配置docker 镜像加速器

> cat <<EOF> /etc/docker/daemon.json{ "exec-opts": ["native.cgroupdriver=systemd"], "registry-mirrors": ["https://kn0t2bca.mirror.aliyuncs.com"] } EOF

#6.重启docker服务

systemctl restart docker

8.kubernetes镜像切换成国内源cat > /etc/yum.repos.d/kubernetes.repo << EOF[kubernetes]name=Kubernetesbaseurl=https://mirrors.aliyun.com/kubernetes/yum/repos/kubernetes-el7-x86_64enabled=1gpgcheck=0repo_gpgcheck=0gpgkey=https://mirrors.aliyun.com/kubernetes/yum/doc/yum-key.gpg https://mirrors.aliyun.com/kubernetes/yum/doc/rpm-package-key.gpgEOF9.安装指定版本 kubeadm,kubelet和kubectl

下载指定版本 kubeadm,kubelet和kubectl

yum install -y kubelet-1.23.0 kubeadm-1.23.0 kubectl-1.23.0

K8s超详细安装部署流程(k8s安装步骤)

#设置kubelet开机启动

systemctl enable kubelet

10. 部署Kubernetes

💡 Tips:下面的操作只需要在master节点上执行即可(初始化完成后,最后会输出一个join命令,可以先保存后边会用)

kubeadm init \ --apiserver-advertise-address=192.168.73.101 \ --image-repository registry.aliyuncs.com/google_containers \ --kubernetes-version v1.23.0 \ --service-cidr=10.96.0.0/12 \ --pod-network-cidr=10.244.0.0/16 \ --ignore-preflight-errors=all

–apiserver-advertise-address #集群通告地址(master 机器IP) –image-repository #由于默认拉取镜像地址k8s.gcr.io国内无法访问,这里指定阿里云镜像仓库地址 –kubernetes-version #K8s版本,与上面安装的一致 –service-cidr #集群内部虚拟网络,Pod统一访问入口 –pod-network-cidr #Pod网络,与下面部署的CNI网络组件yaml中保持一致

#创建必要文件

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

把初始化生成的 join 命令 在这里执行: 💡 Tips:下面的操作只需要在node节点上执行即可(下面的命令是 k8s初始化的时候 生成的)

kubeadm join 192.168.73.101:6443 --token 7gqt13.kncw9hg5085iwclx \--discovery-token-ca-cert-hash sha256:66fbfcf18649a5841474c2dc4b9ff90c02fc05de0798ed690e1754437be35a01

#默认token有效期为24小时,当过期之后,该token就不可用了。这时就需要重新创建token,可以直接使用命令快捷生成:

kubeadm token create --print-join-command

11.部署容器网络(CNI)

💡 Tips:以后所有yaml文件都只在Master节点执行。 Calico是一个纯三层的数据中心网络方案,是目前Kubernetes主流的网络方案。 下载YAML:

wget https://docs.projectcalico.org/manifests/calico.yaml

下载完后还需要修改里面定义Pod网络(CALICO_IPV4POOL_CIDR),与前面kubeadm init的 –pod-network-cidr指定的一样

我这里已经提前下载 配置好了,可以直接下载: 链接:https://pan.baidu.com/s/1xiRHLzxO2aThLyLmlTKd5Q 提取码:z867

#文件下载后,上传到master服务器,然后执行下面命令

kubectl apply -f calico.yaml

#查看节点状态

kubectl get pods -n nodes

#查看通信状态

kubectl get pods -n kube-system -w(-w可以不带)

至此K8s已经部署完成。

1.部署nginx测试

#先创建一个yaml文件 vim nginx.yaml

apiVersion: apps/v1kind: Deploymentmetadata: name: nginx-deployment labels: app: nginxspec: replicas: 3 selector: matchLabels: app: nginx template: metadata: labels: app: nginx spec: containers: - name: nginx image: nginx

#文件保存成功后 执行:

kubectl apply -f nginx.yaml

#再创建一个yaml文件

vim nginx-service.yaml

apiVersion: v1kind: Servicemetadata: name: nginx-servicespec: selector: app: nginx type: NodePort ports: - protocol: TCP port: 80 targetPort: 80

#文件保存成功后 执行:

kubectl apply -f nginx-service.yaml

#查看服务 (Running说明启动成功)

kubectl get pod,svc

然后就可以在浏览器打开nginx启动页 :

本文链接地址:https://www.jiuchutong.com/zhishi/295292.html 转载请保留说明!

上一篇:详细vite创建vue3项目(vue3+vue-router+ts+vite+element-plus+pinia)(vue3.0创建)

下一篇:uni-app--》uni-app的生命周期讲解

  • 朋友圈营销中的七大核心错误 你中枪了吗(朋友圈营销的目的)

    朋友圈营销中的七大核心错误 你中枪了吗(朋友圈营销的目的)

  • 打印机共享0000709(打印机共享0000040)

    打印机共享0000709(打印机共享0000040)

  • 淘宝保证金代扣能关闭吗(淘宝保证金代扣是什么意思)

    淘宝保证金代扣能关闭吗(淘宝保证金代扣是什么意思)

  • steam截图快捷键(steam截图快捷键设置)

    steam截图快捷键(steam截图快捷键设置)

  • 魅族 18 Pro出厂系统内核是多少(魅族18pro出厂系统版本)

    魅族 18 Pro出厂系统内核是多少(魅族18pro出厂系统版本)

  • 微信推送标题错了怎么办(微信推送标题错误怎么改)

    微信推送标题错了怎么办(微信推送标题错误怎么改)

  • 4800万像素能比过单反吗(4800万像素比1200万像素噪声降低多少)

    4800万像素能比过单反吗(4800万像素比1200万像素噪声降低多少)

  • 手机的ot g是什么意思(手机的OTG是什么意思)

    手机的ot g是什么意思(手机的OTG是什么意思)

  • 腾讯课堂分屏算不算时间(腾讯课堂分屏算切屏吗)

    腾讯课堂分屏算不算时间(腾讯课堂分屏算切屏吗)

  • 默认打印机取消不了(默认打印机取消怎么设置)

    默认打印机取消不了(默认打印机取消怎么设置)

  • 骑手差评多久能看到(骑手差评多了会怎么样)

    骑手差评多久能看到(骑手差评多了会怎么样)

  • 荣耀v30pro卡槽在哪(荣耀v30pro的卡槽)

    荣耀v30pro卡槽在哪(荣耀v30pro的卡槽)

  • 苹果充电头中间有裂纹怎么办(苹果充电头有个孔)

    苹果充电头中间有裂纹怎么办(苹果充电头有个孔)

  • 笔记本键盘解锁键是哪个键(华硕笔记本键盘解锁)

    笔记本键盘解锁键是哪个键(华硕笔记本键盘解锁)

  • 算法的时间复杂度取决于什么(算法的时间复杂度是指什么)

    算法的时间复杂度取决于什么(算法的时间复杂度是指什么)

  • iphone11pro信号不好怎么办(iphone11pro信号不好)

    iphone11pro信号不好怎么办(iphone11pro信号不好)

  • 苹果怎么自动设置时间(苹果怎么自动设置勿扰模式)

    苹果怎么自动设置时间(苹果怎么自动设置勿扰模式)

  • 退群以后发的消息还在吗(退群以后发的消息能看吗)

    退群以后发的消息还在吗(退群以后发的消息能看吗)

  • 苹果6p电池容量(苹果14的电池容量)

    苹果6p电池容量(苹果14的电池容量)

  • 网易云为什么苹果下载不了(iphonex网易云用不了)

    网易云为什么苹果下载不了(iphonex网易云用不了)

  • vivox27微信有美颜功能吗(vivo手机有美颜吗)

    vivox27微信有美颜功能吗(vivo手机有美颜吗)

  • 电脑受潮了怎么办(电脑受潮怎么修)

    电脑受潮了怎么办(电脑受潮怎么修)

  • word图片里怎么画圈(word怎么写字)

    word图片里怎么画圈(word怎么写字)

  • 怎么把照片传到百度云(怎么把照片传到icloud)

    怎么把照片传到百度云(怎么把照片传到icloud)

  • python函数中返回值的作用(python 函数的返回值)

    python函数中返回值的作用(python 函数的返回值)

  • 普票和增值税发票的区别
  • 用友t3采购订单怎么录入
  • 以前年度损益调整在借方是什么意思
  • 股权转让产生的印花税
  • 个体经营部可以开增值税专用发票吗
  • 跨年度退货可以开红字发票吗
  • 季度利润表不包括什么
  • 科目汇总表的登记方法
  • 通过认证的增值税怎么算
  • 增值税返还需要交增值税吗
  • 一般纳税人应交增值税明细科目设置
  • 买车时的保险包括哪些费用,多少钱
  • 暂估含税还是不含税
  • 年终对应交税费的减免税款怎样处理?
  • 影院分成为什么那么高
  • 股东多人实收资产怎么办
  • 原材料计划价实际价区别
  • 工会经费应该计入人工成本吗
  • 运输营改增
  • 公司补贴为什么要交税
  • 城建税及教育费附加税怎么算
  • 报废车辆补贴收据怎么写
  • 福利费用属于什么费用
  • 手工发票有效期多久
  • 属于留存收益的是
  • 现金净增加额为负数是什么意思
  • 小区保安有收物业费的权利和义务吗?
  • 鸿蒙怎么开启个性化桌面
  • dolby audio设置
  • 其他应收款会计科目
  • 产品作为样品账务处理
  • 完工转出产成品成本计算
  • win11无限重启怎么解决
  • 公司成立之初
  • php密码加密和解密
  • PHP:Memcached::getDelayedByKey()的用法_Memcached类
  • html文档怎么写
  • 生产企业出口退税全部流程
  • 社保退工伤保险怎样做分录
  • 金蝶利润表主营业务成本公式
  • java如何实现异步处理
  • 微信公众号php开发教程
  • vue内置指令实验总结
  • 其他收益增加说明什么
  • 无标题节啥意思
  • html小游戏代码大全
  • 利息收入算什么会计科目
  • 施工企业预缴税款
  • 年金现值和终值的计算
  • 固定资产盘点方案
  • 应交增值税转入未交增值税怎么算
  • 小微企业预缴所得税怎么填报
  • 汇算清缴时资产折旧怎么填
  • 本月冲红上月发票后的税款能抵减吗
  • 公司的现金收入存到个人账户在转到公司指定的私人账户
  • 企业解散清算程序
  • 出口免抵退和免退有什么区别
  • 技术合同免税备案流程
  • 残保金零申报必须大于0
  • 会计中的资金
  • CentOS中mysql cluster安装部署教程
  • 磁盘碎片 win7
  • xp系统内存不足怎么办
  • 上网本安装win7
  • linux那些事儿
  • window svn
  • win10无法安装telnet
  • centos屏蔽ip
  • win10更新中途怎么取消
  • win10系统如何快速回到桌面
  • linux 文件夹权限 777
  • win8怎么调整屏幕分辨率
  • Unity3D游戏开发pdf
  • opengl编程实例
  • 方块大人
  • jquery选择id
  • android开发教程视频
  • 汉诺塔游戏教程
  • 延期审理税务案件的后果
  • 党员e先锋中的支部云课堂在哪
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设