K8S的二进制部署

news2024/11/18 1:25:27

K8S的源码包部署

搭建准备:

k8smaster01:20.0.0.32  kube-apiserver  kube-controller-manager  kube-scheduler  etcd

k8smaster02:20.0.0.33  kube-apiserver  kube-controller-manager  kube-scheduler 

node节点01:20.0.0.34  kubelet  kube-proxy  etcd

node节点02:20.0.0.35  kubelet  kube-proxy  etcd

负载均衡:nginx+keepalive+master01:20.0.0.36

负载均衡:nginx+keepalive+master02:20.0.0.37

ercd:20.0.0.32、20.0.0.34、20.0.0.35

开始部署

k8smaster01、node01、node02

iptables -F
iptables -t nat -F
iptables -t mangle -F
iptables -x
#清空iptables的所有策略
master01、node01、node02关闭swap交换分区
swapoff -a
#关闭swap交换分区
#k8s在涉及时,为了提升性能,默认不使用swap交换分区,k8s在初始化的时候会自动检测swap
开始给主机改名
hostnamectl set-hostname master01
hostnamectl set-hostname node01
hostnamectl set-hostname node02
vim /etc/hosts/
20.0.0.32  master01
20.0.0.34  node01
20.0.0.35  node02
#坐映射

cat > /etc/sysctl.d/k8s.conf << EOF
net.bridge.bridge-nf-call-ip6tables = 1
net.bridge.bridge-nf-call-iptables = 1
net.ipv6.conf.all.disable_ipv6=1
net.ipv4.ip_forward=1
EOF
systemctl --system
#让配置文件生效

解释含义:
vim /etc/sysctl.d/k8s.conf
#优化内核文件
net.bridge.bridge-nf-call-ip6tables=1
#开启网桥模式
net.bridge.bridge-nf-call-iptables=1
#网桥的六里昂传给iptables链,实现地址映射
net.ipv6.conf.all.disable_ipv6=1
#关闭ipv6的流量(可选项)根据工作中实际情况,自定义
net.ipv4.ip_forward=1
#开启转发功能

进行时间同步:
yum install ntpdate -y
ntpdate ntp.aliyun.com 

所有node节点上都安装docker
mv docker-compose-linux-x86_64 docker-compose
mv docker-compose /usr/local/bin/
chmod 777 /usr/local/bin/docker-compose
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
 sudo mkdir -p /etc/docker
 sudo tee /etc/docker/daemon.json <<-'EOF'
{
  "registry-mirrors": ["https://4rvsvncn.mirror.aliyuncs.com"]
}
EOF
sudo systemctl daemon-reload
sudo systemctl restart docker

部署第一个组件

存储k8s的集群信息和用户配置组件 etcd: etcd是一个高可用分布式的键值对存储数据库。etcd是go语言写的 etcd的端口:2379和2380 2379:是API接口,对外为客户端提供通信 2380:是内部端口,内部服务的通信端口 etcd一般都是集群部署,etcd也有选举leader的机制,至少要三台。或者奇数台。 k8s的内部通信需要依靠证书认证。密钥热恩泽。证书的签发环境:

部署证书:
mv cfssl cfssl-certinfo cfssljson /usr/local/bin/
chmod 777 /usr/local/bin/cfssl*
三个证书:
cfssl
#证书签发的命令工具
cfssljson
#将 cfssl 生成的证书(json格式)变为文件承载式证书
cfssl-certinfo
#查看证书信息的工具

配置etcd的二进制文件:
mkdir /opt/k8s
cd /opt/k8s/
chmod 777 etcd-cert.sh etcd.sh
mkdir /opt/k8s/etcd-cert
生成CA证书、etcd 服务器证书以及私钥:
mv etcd-cert.sh etcd-cert/
cd /opt/k8s/etcd-cert/
./etcd-cert.sh
ca-config.json
#证书颁发机构的配置文件,定义了证书生成的策略,默认的过期时间。定义了证书生成的策略,默认的过期时间和模板。
ca-csr.json
#签名的请求文件,包括一些组织信息和加密方式。
ca.pem
#根证书文件,用于给其他组件签发证书
server.csr
#etcd的服务器签发证书的请求文件
server-key.pem
#etcd服务器的私钥文件。
ca.csr
#根证书签发请i去文件。
ca-key.pem
#根证书签发请求文件。
server-csr.json
#用于生成 etcd 服务器证书和私钥的签名请求文件。包括Common Name(CN)、主机地址列表和一些组织信息。
server.pem
#etcd 服务器证书文件,用于加密和认证 etcd 节点之间的通信。
server.csr
#etcd 服务器证书签发请求文件。
server-key.pem
#etcd 服务器证书私钥文件。

cd /opt/k8s/
tar -xf etcd-v3.4.9-linux-amd64.tar.gz
ls etcd-v3.4.9-linux-amd64

mkdir -p /opt/etcd/{cfg,bin,ssl}
cd /opt/k8s/etcd-v3.4.9-linux-amd64/
mv etcd etcdctl /opt/etcd/bin/
cp /opt/k8s/etcd-cert/*.pem /opt/etcd/ssl/

传参:
cd /opt/k8s/
./etcd.sh etcd01 20.0.0.32 etcd02=https://20.0.0.34:2380,etcd03=https://20.0.0.35:2380

在master01上把etcd相关证书文件、命令文件和服务管理文件全部拷贝到另外两个etcd集群节点
scp -r /opt/etcd/ root@20.0.0.34:/opt/
scp -r /opt/etcd/ root@20.0.0.35:/opt/
scp /usr/lib/systemd/system/etcd.service root@20.0.0.34:/usr/lib/systemd/system/
scp /usr/lib/systemd/system/etcd.service root@20.0.0.35:/usr/lib/systemd/system/

node01:
cd /opt/etcd/cfg/
vim etcd
ETCD_NAME="etcd02"
ETCD_LISTEN_PEER_URLS="https://20.0.0.34:2380"
ETCD_LISTEN_CLIENT_URLS="https://192.168.233.34:2379"
ETCD_INITIAL_ADVERTISE_PEER_URLS="https://20.0.0.34:2380"
ETCD_ADVERTISE_CLIENT_URLS="https://20.0.0.34:2379"
ETCD_INITIAL_CLUSTER="etcd01=https://20.0.0.32:2380,etcd02=https://20.0.0.34:2380,etcd03=https://20.0.0.35:2380"
#启动etcd服务
systemctl start etcd
systemctl enable etcd
systemctl status etcd
node02操作相同:
cd /opt/etcd/cfg/
vim etcd
ETCD_NAME="etcd03"
ETCD_LISTEN_PEER_URLS="https://20.0.0.35:2380"
ETCD_LISTEN_CLIENT_URLS="https://192.168.233.35:2379"
ETCD_INITIAL_ADVERTISE_PEER_URLS="https://20.0.0.35:2380"
ETCD_ADVERTISE_CLIENT_URLS="https://20.0.0.35:2379"
ETCD_INITIAL_CLUSTER="etcd01=https://20.0.0.32:2380,etcd02=https://20.0.0.34:2380,etcd03=https://20.0.0.35:2380"
systemctl start etcd
systemctl enable etcd
systemctl status etcd

检查etcd群集状态:
ETCDCTL_API=3 /opt/etcd/bin/etcdctl --cacert=/opt/etcd/ssl/ca.pem --cert=/opt/etcd/ssl/server.pem --key=/opt/etcd/ssl/server-key.pem --endpoints="https://20.0.0.32:2379,https://20.0.0.34:2379,https://20.0.0.35:2379" endpoint health --write-out=table

查看etcd集群成员列表:
ETCDCTL_API=3 /opt/etcd/bin/etcdctl --cacert=/opt/etcd/ssl/ca.pem --cert=/opt/etcd/ssl/server.pem --key=/opt/etcd/ssl/server-key.pem --endpoints="https://20.0.0.32:2379,https://20.0.0.34:2379,https://20.0.0.35:2379" --write-out=table member list

node01

node02

部署 Master 组件

上传 master.zip 和 k8s-cert.sh 到 /opt/k8s 目录中,解压 master.zip 压缩包:
cd /opt/k8s/
vim k8s-cert.sh
unzip master.zip
chmod 777 *.sh

创建k8s的工作目录:
mkdir -p /opt/kubernetes/{bin,cfg,ssl,logs}

创建用于生成CA证书、相关组件的证书和私钥的目录:
mkdir /opt/k8s/k8s-cert
mv /opt/k8s/k8s-cert.sh /opt/k8s/k8s-cert
cd /opt/k8s/k8s-cert/
./k8s-cert.sh
#生成证书和相关组件的证书和私钥
复制组件到指定ssl目录
cp ca*pem apiserver*pem /opt/kubernetes/ssl/

解压master节点的二进制包:
cd /opt/k8s/
tar -xf kubernetes-server-linux-amd64.tar.gz

复制master组件的关键命令文件到 kubernetes工作目录的 bin 子目录中
cd /opt/k8s/kubernetes/server/bin
cp kube-apiserver kubectl kube-controller-manager kube-scheduler /opt/kubernetes/bin/
#将配置文件转移到创建的主配置目录中
ln -s /opt/kubernetes/bin/* /usr/local/bin/

创建token认证文件并开启相关服务

cd /opt/k8s/
vim token.sh
#!/bin/bash
#获取随机数前16个字节内容,以十六进制格式输出,并删除其中空格
BOOTSTRAP_TOKEN=$(head -c 16 /dev/urandom | od -An -t x | tr -d ' ')

#生成 token.csv 文件,按照 Token序列号,用户名,UID,用户组 的格式生成
cat > /opt/kubernetes/cfg/token.csv <<EOF
${BOOTSTRAP_TOKEN},kubelet-bootstrap,10001,"system:kubelet-bootstrap"
EOF

chmod 777 token.sh
./token.sh

cat /opt/kubernetes/cfg/token.csv
#查看密钥是否生成

开启 apiserver 服务:
cd /opt/k8s/
./apiserver.sh 20.0.0.32 https://20.0.0.32:2379,https://20.0.0.34:2379,https://20.0.0.35:2379
netstat -antp | grep 6443
#检查进程是否启动成功

启动 scheduler 服务:
cd /opt/k8s/
./scheduler.sh
netstat -antp | grep kube-scheduler

启动 controller-manager 服务:
./controller-manager.sh
netstat -antp | grep kube-controller-manager

生成kubectl连接集群的kubeconfig文件:
./admin.sh

通过kubectl工具查看当前集群组件状态:
kubectl get cs

Master节点搭建完成!

kubectl api-rescources
#获取集群信息、调用接口名称
kubectl get cs
#查看集群状态
kubectl version
#查看集群版本

优化命令自动补齐:
vim /etc/profile
最后一行---
source < (kubectl completion bash)
source /etc/profile

部署 Worker Node 组件

在node01和node02主机上配置:
可以两台主机同时创建
创建kubernetes工作目录:
mkdir -p /opt/kubernetes/{bin,cfg,ssl,logs}

安装node节点的配置文件:
cd /opt/
unzip node.zip
chmod 777 kubelet.sh proxy.sh

回到master01主机:
cd /opt/k8s/kubernetes/server/bin
#在主节点上传递配置文件到node节点
scp kubelet kube-proxy root@20.0.0.34:/opt/kubernetes/bin/
scp kubelet kube-proxy root@20.0.0.35:/opt/kubernetes/bin/

上传kubeconfig.sh文件到/opt/k8s/kubeconfig目录中,生成kubelet初次加入集群引导kubeconfig文件和kube-proxy.kubeconfig文件:
mkdir /opt/k8s/kubeconfig
cd /opt/k8s/kubeconfig
vim kubeconfig.sh
#配置集群信息
chmod 777 kubeconfig.sh
./kubeconfig.sh 20.0.0.32 /opt/k8s/k8s-cert/
#执行脚本添加本机的IP并传参

把配置文件复制到node01和node02节点:
vim bootstrap.kubeconfig
vim kube-proxy.kubeconfig
scp bootstrap.kubeconfig kube-proxy.kubeconfig root@20.0.0.34:/opt/kubernetes/cfg/
scp bootstrap.kubeconfig kube-proxy.kubeconfig root@20.0.0.35:/opt/kubernetes/cfg/

回到node01和node02检查一下文件是否复制成功:

在master01主机上进行RBAC授权:
kubectl create clusterrolebinding kubelet-bootstrap --clusterrole=system:node-bootstrapper --user=kubelet-bootstrap
#RBAC授权,生成和赋权用户kubelet-bootstrap。发起node节点的请求认证。通过csr加密认证的方式。实现node节点加入到集群当中去。
#kubelet获取mater的验证信息和API-server接口的通信认证。
若执行失败,可先给kubectl绑定默认cluster-admin管理员集群角色,授权对整个集群的管理员权限:
kubectl create clusterrolebinding cluster-system-anonymous --clusterrole=cluster-admin --user=system:anonymous

回到node01节点:
cd /opt/
chmod 777 kubelet.sh
./kubelet.sh 20.0.0.34
ps aux | grep kubelet
在master01上操作,通过CSR请求:
kubectl get csr
kubectl certificate approve node-csr-QDu7fSscpoxuUWFg-Du7DJJ61zaqnLmG_yxehYYni4Y
#通过 CSR 请求
kubectl get csr
#打开csr
当显示Approved,Issued表示加入成功!
启动proxy服务
cd /opt/
./proxy.sh 20.0.0.34
ps aux | grep kube-proxy

回到node02节点:
cd /opt/
chmod 777 kubeconfig.sh
./kubelet.sh 20.0.0.35
ps -aux | grep kubelet
在master01上操作,通过CSR请求
kubectl get csr
kubectl certificate approve 跟上密钥队
#通过 CSR 请求
kubectl get csr
#打开csr
当显示Approved,Issued表示加入成功!

在master01主机上查看节点部署是否成功:
kubectl get node
启动proxy服务
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
cd /opt/
./proxy.sh 20.0.0.35
ps aux | grep kube-proxy

node节点搭建完成!

因为没有搭建网络所以是NotReady但是集群加入成功。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1338605.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Jenkins集成allure测试报告

前言 Allure框架是一个功能强大的自动化测试报告工具&#xff0c;不仅支持多种编程语言&#xff0c;而且能够完美的与各种集成工具结合&#xff0c;包括Jenkins&#xff0c;TeamCity&#xff0c;Bamboo&#xff0c;Maven等等&#xff0c;因此受到了很多测试人员的青睐&#xff…

Redis7快速入门

Docker安装Redis 指定密码&#xff1a; docker run --restartalways -p 6379:6379 --name redis -d redis:7.0.12 --requirepass zhangdapeng520不指定密码&#xff1a; docker run --restartalways -p 6379:6379 --name redis -d redis:7.0.12在真实的开发中&#xff0c;如…

【c++】入门1

c关键字 命名空间 在C/C中&#xff0c;变量、函数和后面要学到的类都是大量存在的&#xff0c;这些变量、函数和类的名称将都存在于全局作用域中&#xff0c;可能会导致很多冲突。使用命名空间的目的是对标识符的名称进行本地化&#xff0c;以避免命名冲突或名字污染&#xff…

C/C++图形化编程(1)

归纳编程学习的感悟&#xff0c; 记录奋斗路上的点滴&#xff0c; 希望能帮到一样刻苦的你&#xff01; 如有不足欢迎指正&#xff01; 共同学习交流&#xff01; &#x1f30e;欢迎各位→点赞 &#x1f44d; 收藏⭐ 留言​&#x1f4dd; 信念是一把无坚不摧的利刃&#xff01…

每日一题-----逆序字符串

大家好我是Beilef&#xff0c;在一个美好的下午我意外接触到编程并且产生了兴趣&#xff0c;哈哈我要努力成为一个跨界者&#xff0c;让我们一起加油吧O(∩_∩)O 文章目录 目录 文章目录 前言 大家好请上车 一、逆序字符串 题⽬描述&#xff1a; 输⼊⼀个字符串&#xff0c;写…

Node.js版本对比

目录 1. node版本与Npm版本对照表 2. node版本与node-sass版本对照表 3. node-sass与sass-loader版本对照表 1. node版本与Npm版本对照表 以往的版本 | Node.js 下面显示最新的对应内容&#xff0c;如果需要查找历史版本&#xff0c;可以进入上面的页面查询 VersionLTSDateV8np…

使用CRA(create-react-app)初始化一个完整的项目环境(该初始化项目已上传到本文章的资源)

1. 整理项目结构&#xff0c;项目目录结构大致划分如下&#xff1a; 2. 安装sass 安装sass开发环境, 注意&#xff1a;使用的文件后缀名要用.scssnpm i sass -D3. 安装Ant Design npm i antd --save 4. 配置基础路由Router&#xff08;具体可参考ReactRouter使用详解&#x…

Kerberos安装教程与命令详解(超详细)

文章目录 前言一、安装准备1. 搭建集群2. 软件包介绍 二、使用shell脚本一键安装1. 复制脚本2. 增加执行权限3. 执行脚本 三、kdb5_util命令1. 简介2. 可用选项和命令的解释3. 常见命令及其说明4. 示例用法 四、kadmin命令1. 简介2. 可用选项和命令的解释3. 常见命令及其说明4.…

渗透测试——1.4主动扫描

主动扫描是别人可以发觉的情报收集 一、nmap的使用 1.nmap<目标主机>:最常用的扫描方式 有nmap版本、扫描时间 “host is up”表示目标主机处于开机状态、“not shown”未开放端口 有四个端口是开的&#xff08;135.139.445.912&#xff09; 2.nmap -p<端口范围…

折叠屏,移动办公的第二战场

当下的移动办公&#xff0c;正在转换战场。 从PC端到移动端&#xff0c;大屏链接小屏&#xff0c;协作模式从单人到团队&#xff0c;移动办公领域一直在发展和自我更新&#xff0c;这也是硬件和软件企业共同开辟的“第一战场”。 如今&#xff0c;折叠屏带来了新形态&#xf…

Kafka、RocketMQ、RabbitMQ消息丢失可能存在的地方,以及解决方案

这里主要对比&#xff1a;Kafka、RocketMQ、RabbitMQ 介绍一下消息生产、存储、消费三者的架构形式。 消息丢失可能存在的场景&#xff1a; 情况一&#xff1a; 生产者发送给MQ的过程消息丢失 在写消息的过程中因为网络的原因&#xff0c;还没到mq消息就丢失了&#xff1b;或…

vue3+elementPlus+cascader动态加载封装自定义组件+v-model指令实现父子通信

文章目录 select普通操作 &#xff08;1&#xff09;cascader操作&#xff08;2&#xff09; select普通操作 &#xff08;1&#xff09; 搜索条件需求&#xff1a;接口入参需要houseId&#xff0c;但是要先选择完楼栋&#xff0c;再选择单元&#xff0c;最后选择房屋 如图&a…

vue2、vue3状态管理之vuex、pinia

提示&#xff1a;文章写完后&#xff0c;目录可以自动生成&#xff0c;如何生成可参考右边的帮助文档 文章目录 前言一、状态管理之vuex1.1 State调用&#xff1a;1.2 Mutation在vuex中定义&#xff1a;在组件中使用&#xff1a; 1.3 Action在vuex中定义&#xff1a;将上面的减…

k8s是什么

生么是k8s&#xff1a; Kubernetes:8个字母省略&#xff0c;就是k8s 自动部署&#xff0c;自动扩展和管理容器化部署的应用程序的一个开源系统、 k8s是负责自动化运维管理多个容器化程序的集群&#xff0c;是一个功能强大的容器编排工具。 分布式和集群化的分布式进行容器管…

关于MySQL、分布式系统、SpringCloud面试题

前言 之前为了准备面试&#xff0c;收集整理了一些面试题。 本篇文章更新时间2023年12月27日。 最新的内容可以看我的原文&#xff1a;https://www.yuque.com/wfzx/ninzck/cbf0cxkrr6s1kniv MySQL 索引 说一下有哪些锁&#xff1f; 行锁有哪些&#xff1f; 性能优化 分库分表…

GrayLog日志平台的基本使用-ssh接入Dashboards展示

这里使用的版本为graylog4.2.10 1、一键安装graylog4.2.10&#xff0c;解压zip包&#xff0c;执行脚本就行 链接&#xff1a;https://pan.baidu.com/s/11U7GpBZ1B7PXR8pyWVcHNw?pwdudln 提取码&#xff1a;udln 2、通过rsyslog采集系统日志&#xff0c;具体操作参考前面文…

Java框架基础--maven,http,postman

maven Maven 提供了一个标准的构建生命周期和一组约定的目录结构&#xff0c;以简化和规范项目的构建过程。它主要用于 Java 项目&#xff0c;但也可以用于其他类型的项目。提高了项目的可维护性、可重复性和一致性&#xff0c;简化了构建和依赖管理的复杂性&#xff0c;使得开…

人类偏好导向:DPO技术重塑SDXL-1.0图像生成

引言 在AI领域&#xff0c;适应和理解人类偏好一直是技术发展的重要方向。斯坦福大学研究团队最近提出的Diffusion-DPO方法&#xff0c;旨在将这一理念应用于图像生成模型&#xff0c;特别是在文本到图像的转换领域。 Huggingface模型下载: https://huggingface.co/mhdang/ A…

dl转置卷积

转置卷积 转置卷积&#xff0c;顾名思义&#xff0c;通过名字我们应该就能看出来&#xff0c;其作用和卷积相反&#xff0c;它可以使得图像的像素增多 上图的意思是&#xff0c;输入是22的图像&#xff0c;卷积核为22的矩阵&#xff0c;然后变换成3*3的矩阵 代码如下 import…

遗传算法的应用——求解一元函数的极值

遗传算法的应用——求解一元函数的极值 1 基本概念2 预备知识3.1 模拟二进制转化为十进制的方法3.2 轮盘赌选择算法 3 问题4 Matlab代码5 运行效果6 总结 1 基本概念 遗传算法(Genetic Algorithm,GA)是模拟生物在自然环境中遗传和进化过程从而形成的随机全局搜索和优化方法&am…