網(wǎng)站首頁(yè) 編程語(yǔ)言 正文
1 版本、規(guī)劃
1.1 版本信息:
名稱(chēng) | 版本號(hào) |
---|---|
內(nèi)核 | 3.10.0-1160.el7.x86_64 |
操作系統(tǒng) | CentOS Linux release 7.9.2009 (Core) |
docker | 20.10.11 |
kubeadm | 1.23.0 |
kubelet | 1.23.0 |
kubectl | 1.23.0 |
1.2集群規(guī)劃
IP | hostname |
---|---|
192.168.0.114 | k8s-master |
192.168.0.115 | k8s-node01 |
192.168.0.116 | k8s-node02 |
2.部署
說(shuō)明:
第1步~第8步,所有節(jié)點(diǎn)都要操作master節(jié)點(diǎn):第9、10步node節(jié)點(diǎn):第11步
1、關(guān)閉防火墻
關(guān)閉:systemctl stop firewalld
永久關(guān)閉:systemctl disable firewalld
2、關(guān)閉selinux
關(guān)閉:setenforce 0
3、關(guān)閉swap
臨時(shí)關(guān)閉:swapoff -a
永久關(guān)閉:sed -ri 's/.*swap.*/#&/' /etc/fstab
,通過(guò)該命令注釋掉含swap
行的代碼
檢驗(yàn):free -m
4、添加主機(jī)名和IP對(duì)應(yīng)關(guān)系
根據(jù)1.2中規(guī)劃內(nèi)容在/etc/hosts
中添加映射關(guān)系
192.168.0.114 k8s-master 192.168.0.115 k8s-node01 192.168.0.116 k8s-node02
5、將橋接的IPV4流量傳遞給iptables的鏈
使用以下命令添加配置:
cat > /etc/sysctl.d/k8s.conf << EOF net.bridge.bridge-nf-call-ip6tables = 1 net.bridge.bridge-nf-call-iptables = 1 EOF
執(zhí)行sysctl --system
命令使配置生效:
6、安裝docker 安裝:
wget https://mirrors.aliyun.com/docker-ce/linux/centos/docker-ce.repo -O /etc/yum.repos.d/docker-ce.repo yum install docker-ce
設(shè)置開(kāi)機(jī)自啟
systemctl start docker systemctl enable docker
查看版本:docker version
可能遇到的坑(此處暫且跳過(guò),后面遇到可回來(lái)修改):
問(wèn)題:使用命令docker info|grep cgroup
查看,如果docker使用的Cgroup Driver
為cgroupfs
。則有可能跟kubelet沖突,需要改為一致的systemd
解決方法1:vi /etc/docker/daemon.json
,在文件中添加如下代碼,重啟docker即可
{ "exec-opts": ["native.cgroupdriver=systemd"] }
解決方法2:也可以修改docker啟動(dòng)服務(wù)中的ExecStart
,添加參數(shù)"--exec-opt native.cgroupdriver=systemd"
# docker.service vi /usr/lib/systemd/system/docker.service # 添加 ExecStart=/usr/bin/dockerd --exec-opt native.cgroupdriver=systemd
7、添加阿里云yum軟件源
cat > /etc/yum.repos.d/kubernetes.repo << EOF [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
可能遇到的坑(此處暫且跳過(guò),后面遇到可回來(lái)操作)
問(wèn)題:安裝過(guò)程中,可能提示xxx.rpm 公鑰尚未安裝
解決方法1:導(dǎo)入公鑰后,再次重裝即可
wget https://mirrors.aliyun.com/kubernetes/yum/doc/yum-key.gpg wget https://mirrors.aliyun.com/kubernetes/yum/doc/rpm-package-key.gpg rpm --import yum-key.gpg rpm --import rpm-package-key.gpg
解決方法2:kubernetes.repo
文件中配置gpgchekc
為0,不檢查即可
8、安裝kubeadm、kubelet、kubectl
安裝:yum install -y kubelet-1.23.0 kubectl-1.23.0 kubeadm-1.23.0
或者安裝最新也行:yum install -y kubelet kubectl kubeadm
設(shè)置開(kāi)啟自啟:systemctl enable kubelet
,此處只需設(shè)置開(kāi)機(jī)啟動(dòng)即可。因?yàn)榕渲眠€未成,不必啟動(dòng),啟動(dòng)也會(huì)不成功
9、初始化master節(jié)點(diǎn)
初始化命令
kubeadm init \ --image-repository registry.aliyuncs.com/google_containers \ --kubernetes-version v1.23.0 \ --service-cidr=10.1.0.0/16 \ --pod-network-cidr=10.244.0.0/16
參數(shù)說(shuō)明
--image-repository string
Choose a container registry to pull control plane images from (default “k8s.gcr.io”)此處使用阿里云的registry,否則會(huì)很慢,甚至失敗
若安裝失敗,需要先用kubeadm reset
命令清理下環(huán)境,再重裝。
遇到的坑:
問(wèn)題:The HTTP call equal to 'curl -sSL http://localhost:10248/healthz' failed with error: Get "http://localhost:10248/healthz": dial tcp [::1]:10248: connect: connection refused.
解決方法:詳見(jiàn)第6步
初始化成功 如果出現(xiàn)以下結(jié)果,表示初始化成功
根據(jù)提示,執(zhí)行以下命令
mkdir -p $HOME/.kube sudo cp -i /etc/kubernetes/admin.conf $HOME/.kube/config sudo chown $(id -u):$(id -g) $HOME/.kube/config # 第1條命令:表示創(chuàng)建隱藏文件夾.kube # 第2條命令:表示復(fù)制文件admin.conf到該文件夾下 # 第3條命令:表示設(shè)置文件的所屬用戶(hù)、用戶(hù)組
執(zhí)行完以上命令即可使用kubectl
命令,否則會(huì)提示The connection to the server localhost:8080 was refused - did you specify the right host or port?
10、安裝pod網(wǎng)絡(luò)插件(CNI)
GitHub地址:https://github.com/flannel-io/flannel,也可以直接下載文件
安裝插件:
kubectl apply -f https://raw.githubusercontent.com/coreos/flannel/master/Documentation/kube-flannel.yml
遇到的坑
問(wèn)題:The connection to the server raw.githubusercontent.com was refused - did you specify the right host or port?
解決:在/etc/hosts
中添加raw.githubusercontent.com
映射。ip地址可以通過(guò)https://www.ipaddress.com
進(jìn)行查看
查看是否部署成功:kubectl get pods -n kube-system
再次查看節(jié)點(diǎn),狀態(tài)變?yōu)閞eady
11、node節(jié)點(diǎn)加入集群
向集群添加新節(jié)點(diǎn),只需要將master節(jié)點(diǎn)中執(zhí)行kubeadm init
成功后的kubeadm join
命令復(fù)制到要添加的node節(jié)點(diǎn)中執(zhí)行即可
kubeadm join 192.168.0.114:6443 --token whxbm2.x70y9k1feop2604b \ --discovery-token-ca-cert-hash sha256:d4306836b7ef32fd802e559cf717bbbe3af6dd75d3cb2fa4d3db7a16cc25a657
成功加入后,通過(guò)master節(jié)點(diǎn)使用命令kubectl get nodes
,即可發(fā)現(xiàn)node節(jié)點(diǎn)已加入到集群中,并且狀態(tài)為ready(此處要稍等一會(huì))
原文鏈接:https://blog.csdn.net/ben_na_/article/details/121823369
相關(guān)推薦
- 2022-02-13 如何寫(xiě)一個(gè)自己的strcpy函數(shù)
- 2023-01-12 Golang單元測(cè)試與斷言編寫(xiě)流程詳解_Golang
- 2022-08-20 使用Docker制作Python環(huán)境連接Oracle鏡像_python
- 2022-07-11 docker給正在運(yùn)行中的容器添加映射端口
- 2022-10-14 cannot find symbol[ERROR] package sun.misc
- 2023-01-26 python獲取redis?memory使用情況場(chǎng)景分析_python
- 2024-04-03 clickhouse報(bào)Ports are not available
- 2022-05-20 SpringCloud系列:springboot改造集成nacos
- 最近更新
-
- window11 系統(tǒng)安裝 yarn
- 超詳細(xì)win安裝深度學(xué)習(xí)環(huán)境2025年最新版(
- Linux 中運(yùn)行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲(chǔ)小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎(chǔ)操作-- 運(yùn)算符,流程控制 Flo
- 1. Int 和Integer 的區(qū)別,Jav
- spring @retryable不生效的一種
- Spring Security之認(rèn)證信息的處理
- Spring Security之認(rèn)證過(guò)濾器
- Spring Security概述快速入門(mén)
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權(quán)
- redisson分布式鎖中waittime的設(shè)
- maven:解決release錯(cuò)誤:Artif
- restTemplate使用總結(jié)
- Spring Security之安全異常處理
- MybatisPlus優(yōu)雅實(shí)現(xiàn)加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務(wù)發(fā)現(xiàn)-Nac
- Spring Security之基于HttpR
- Redis 底層數(shù)據(jù)結(jié)構(gòu)-簡(jiǎn)單動(dòng)態(tài)字符串(SD
- arthas操作spring被代理目標(biāo)對(duì)象命令
- Spring中的單例模式應(yīng)用詳解
- 聊聊消息隊(duì)列,發(fā)送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠(yuǎn)程分支