云原生Kubernetes: Ubuntu 安装 K8S 1.23版本(单Master架构) 及故障恢复

目录

一、实验

1.环境

2.安装 Ubuntu

3.连接Ubuntu

4.master节点安装docker

5.node节点安装docker

6.master节点安装K8S

7.添加K8S工作节点

8.安装网络插件calico

9.故障

10.故障恢复

11.测试k8s网络和coredns

二、问题

1.Ubuntu如何修改镜像源

2.Ubuntu和Windows之间如何实现复制粘贴

3.Ubuntu如何开启openssh-server

4.UbuntuSSH连接失败

5.Ubuntu ping不通

6.更新apt源和安装基础软件包报错

7. master更新镜像源报错

8.Ubuntu如何安装rz命令


一、实验

1.环境

(1)主机

表1 主机

主机架构版本IP备注
master1K8S master节点1.23.1192.168.204.102

node1K8S node节点1.23.1 192.168.204.104

2.安装 Ubuntu

(1) 选择版本

ubuntu-20.04.3-desktop-amd64

(2)系统检查

(3)等待

(4)选择语言

(5)键盘布局

(6)更新和其他软件

(7)时区

(8)磁盘

(9)用户

(10)安装

(11)重启

3.连接Ubuntu

(1)设置密码

1)先用安装时候的用户登录进入系统2)输入:sudo passwd  按回车3)输入新密码,重复输入密码,最后提示passwd:password updated sucessfully
此时已完成root密码的设置4)输入:su root
切换用户到root试试.

(2)网络

ip a

(3)修改机器主机名

master1

hostnamectl set-hostname master1 && bash

node1

hostnamectl set-hostname node1 && bash

(4)安装vim

sudo apt-get install vim

(5)安装网络工具

apt install net-tools

(6)修改网卡

sudo vim /etc/network/interfaces
​
auto ens33
iface ens33 inet static
address 192.168.204.102
netmask 255.255.255.0
gateway 192.168.204.2
dns-nameserver 8.8.8.8

(7)重启

reboot

(8) 修改域名

vim /etc/hosts

(8)更新apt源和安装基础软件包

apt-get update && sudo apt-get install -y apt-transport-https ca-certificates curl software-properties-common gnupg2

4.master节点安装docker

(1)把下载的key添加到本地trusted数据库中

curl -fsSL https://mirrors.ustc.edu.cn/docker-ce/linux/ubuntu/gpg | sudo apt-key add -

(2)设置稳定版仓库

sudo add-apt-repository \"deb [arch=amd64] https://mirrors.ustc.edu.cn/docker-ce/linux/ubuntu/ \$(lsb_release -cs) \stable"

(3) 安装Docker

sudo apt-get install docker-ce docker-ce-cli containerd.io -y

(4) 配置Docker驱动

cat <<EOF | tee /etc/docker/daemon.json
{"exec-opts": ["native.cgroupdriver=systemd"],"log-driver": "json-file","log-opts": {"max-size": "100m"},"storage-driver": "overlay2"
}
EOF

(5)开机自启

mkdir -p /etc/systemd/system/docker.service.dsystemctl daemon-reloadsystemctl restart dockersystemctl enable --now docker

5.node节点安装docker

(1) 安装过程

与master节点相同,这里省略。

6.master节点安装K8S

(1)更新

 apt-get update && apt-get install -y apt-transport-https curl 

(2)镜像加速

cat <<EOF >/etc/apt/sources.list.d/kubernetes.list
deb http://mirrors.ustc.edu.cn/kubernetes/apt kubernetes-xenial main
EOF

(3)安装

apt-get install -y kubelet=1.23.1-00 kubeadm=1.23.1-00 kubectl=1.23.1-00

(4)标记指定软件包为保留(held back),阻止软件自动更新

apt-mark hold kubelet kubeadm kubectl 

(5)关闭交换分区

 swapoff -a

(6)初始化K8S

kubeadm init --apiserver-advertise-address 192.168.204.102 --image-repository registry.cn-hangzhou.aliyuncs.com/google_containers --pod-network-cidr=10.244.0.0/16 --ignore-preflight-errors=SystemVerification

(7)配置文件

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

7.添加K8S工作节点

(1)更新

apt-get update && apt-get install -y apt-transport-https curl 

 (2)镜像加速

cat <<EOF >/etc/apt/sources.list.d/kubernetes.list
deb http://mirrors.ustc.edu.cn/kubernetes/apt kubernetes-xenial main
EOF

(3)安装

apt-get install -y kubelet=1.23.1-00 kubeadm=1.23.1-00 kubectl=1.23.1-00

 (4)标记指定软件包为保留(held back),阻止软件自动更新

apt-mark hold kubelet kubeadm kubectl 

 (5)关闭交换分区

 swapoff -a

(6)在master1上查看加入节点的命令

 kubeadm token create --print-join-command

(7)在node1执行命令

(8)查看

kubectl get node

8.安装网络插件calico

(1)下载配置文件

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

(2)修改配置文件

(3)安装

kubectl apply -f  calico.yaml

9.故障

(1)故障描述

此时磁盘大小不够崩溃

(2)查看pod状态

kubectl get pod --all-namespaces

尝试再次初始化报错ERROR

10.故障恢复

(1)重置kubeadm

kubeadm reset

出现删除提示

(2) 删除配置文件

(3)关闭swap 测试

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

(4)再次重置kubeadm

kubeadm reset

(5)初始化

kubeadm init --apiserver-advertise-address 192.168.204.102 --image-repository registry.cn-hangzhou.aliyuncs.com/google_containers --pod-network-cidr=10.244.0.0/16 --ignore-preflight-errors=SystemVerification

(6) 配置文件

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

(7)在master1上查看加入节点的命令

kubeadm token create --print-join-command
kubeadm join 192.168.204.102:6443 --token d70wh5.gyvrmwa62w91hhoa --discovery-token-ca-cert-hash sha256:765a563a7ba90c23da4c375ec99dd434763ca43512e27c6ae38ce0bd67a6234d

(8)从节点加入失败

systemctl stop kubeletsystemctl stop dockerrm -rf /var/lib/cni/ /var/lib/kubelet/* /etc/cni/ifconfig docker0 downsystemctl start dockerfree -m

(9)删除文件重新加入

rm -rf /etc/kubernetes/kubelet.confrm -rf /etc/kubernetes/pki/ca.crt

(10)查看节点状态

kubectl get node

(11) 安装网络插件calico

kubectl apply -f  calico.yaml

(12) 观察pod变化

拉取镜像需要一定时间,查看pod状态为running则安装成功。

kubectl get pod --all-namespaces -wkubectl get pod --all-namespaces

(13)查看集群状态

 kubectl get nodekubectl get node -o wide

11.测试k8s网络和coredns

(1)测试

kubectl run busybox --image busybox:1.28 --restart=Never --rm -it busybox -- sh
/ # ping www.baidu.com/ # nslookup kubernetes.default.svc.cluster.local/ # exit

二、问题

1.Ubuntu如何修改镜像源

(1)自动

选择 “Ubuntu软件 / 源代码 (需验证,输入密码) / 其它站点 / 选择最佳服务器 ”,自动选择合适的镜像源

(2)手动

Ubuntu系统中,软件源文件地址为:/etc/apt/sources.list1)备份原来的源,将以前的源备份一下,以防以后可以用的。
sudo cp /etc/apt/sources.list /etc/apt/sources.list.bak2)打开/etc/apt/sources.list文件,在前面添加如下条目,并保存。
sudo vim /etc/apt/sources.list(可将vim更换为自己熟悉的编辑器)

#添加阿里源
deb http://mirrors.aliyun.com/ubuntu/ focal main restricted universe multiverse
deb-src http://mirrors.aliyun.com/ubuntu/ focal main restricted universe multiverse
deb http://mirrors.aliyun.com/ubuntu/ focal-security main restricted universe multiverse
deb-src http://mirrors.aliyun.com/ubuntu/ focal-security main restricted universe multiverse
deb http://mirrors.aliyun.com/ubuntu/ focal-updates main restricted universe multiverse
deb-src http://mirrors.aliyun.com/ubuntu/ focal-updates main restricted universe multiverse
deb http://mirrors.aliyun.com/ubuntu/ focal-proposed main restricted universe multiverse
deb-src http://mirrors.aliyun.com/ubuntu/ focal-proposed main restricted universe multiverse
deb http://mirrors.aliyun.com/ubuntu/ focal-backports main restricted universe multiverse
deb-src http://mirrors.aliyun.com/ubuntu/ focal-backports main restricted universe multiverse
#添加清华源
deb https://mirrors.tuna.tsinghua.edu.cn/ubuntu/ focal main restricted universe multiverse
# deb-src https://mirrors.tuna.tsinghua.edu.cn/ubuntu/ focal main restricted universe multiverse
deb https://mirrors.tuna.tsinghua.edu.cn/ubuntu/ focal-updates main restricted universe multiverse
# deb-src https://mirrors.tuna.tsinghua.edu.cn/ubuntu/ focal-updates main restricted universe multiverse
deb https://mirrors.tuna.tsinghua.edu.cn/ubuntu/ focal-backports main restricted universe multiverse
# deb-src https://mirrors.tuna.tsinghua.edu.cn/ubuntu/ focal-backports main restricted universe multiverse
deb https://mirrors.tuna.tsinghua.edu.cn/ubuntu/ focal-security main restricted universe multiverse
# deb-src https://mirrors.tuna.tsinghua.edu.cn/ubuntu/ focal-security main restricted universe multiverse multiverse

(3)更新

更新源

sudo apt-get update 

如出现依赖问题,解决方式如下:

sudo apt-get -f install

更新软件:

sudo apt-get upgrade

2.Ubuntu和Windows之间如何实现复制粘贴

(1)命令

apt-get autoremove open-vm-toolssudo apt-get install open-vm-tools-desktop

3.Ubuntu如何开启openssh-server

(1) 开启命令

要在Ubuntu主机开启SSH服务,需要开启openssh-server命令

(2)下载SSH服务

sudo apt-get install openssh-server 

(3)执行下句,验证下载后是否已经开启了服务

#如果只有ssh-agent表示还没启动
ps -e | grep ssh

(4)开启服务

#如果显示sshd则说明已启动成功
/etc/init.d/ssh start

4.UbuntuSSH连接失败

(1)修改配置文件

1)进入终端窗口
2)进入root权限。输入命令:sudo su,回车后输入密码即可。
3)打开ssh服务器的配置文件,输入命令:vi /etc/ssh/sshd_config
4)在弹出窗口中找到Authentication,使用vi命令修改其中PermitRootLogin后的prohibit-password为yes(如果不会使用vi命令,参考下面的注意)。

修改前

修改后

(2)重新启动

 重新启动ssh服务器,输入命令

sudo /etc/init.d/ssh restart

 重新使用XShell工具进行连接

 

5.Ubuntu ping不

(1)修改网卡

输入命令sudo vim /etc/network/interfaces,编辑该文件。注意此处 ens33 处用自己的网卡编号替换,address和gateway也是要视自己的情况定的。

auto lo
iface lo inet loopbackauto ens33
iface ens33 inet static
address 192.168.204.102
netmask 255.255.255.0
gateway 192.168.204.2
dns-nameserver 8.8.8.8

(2)保存退出

wq 保存退出,此时ping一些自己的内网应该是可以ping通的了。要是ping www.baidu.com还是ping不通的,接下来就需要继续接着做。

(3)DNS解析

在命令行输入sudo vim /etc/systemd/resolved.conf 修改改文件:将DNS前的 # 号去掉,然后加上DNS服务器地址即可。

(4)重启网络服务

 sudo /etc/init.d/ network-manager force-reload  ==> 重新加载网路配置文件
sudo /etc/init.d/network-manager restart

(5)安装ifupdown

apt install ifupdown

(6)再次修改网卡

sudo vim /etc/network/interfaces
auto ens33
iface ens33 inet static
address 192.168.204.102
netmask 255.255.255.0
gateway 192.168.204.2
dns-nameserver 8.8.8.8​

(7)重启

reboot

(8)重启Ubuntu

su root

(9)ping

6.更新apt源和安装基础软件包报错

(1)报错

(2)原因分析

锁定。

(3)解决方法

sudo rm /var/lib/apt/lists/lock
sudo rm /var/cache/apt/archives/lock
sudo rm /var/lib/dpkg/lock*
sudo dpkg --configure -a
sudo apt update

7. master更新镜像源报错

(1)报错

(2)原因分析

没有公钥

(3)解决方法

添加公钥

apt-key adv --recv-keys --keyserver keyserver.ubuntu.com 8B57C5C2836F4BEB 

成功

8.Ubuntu如何安装rz命令

(1)安装

apt install lrzsz

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

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

相关文章

C++开发基础之生产者和消费者模型:实现多线程数据交换与同步

0.前言 在并发编程中&#xff0c;处理多个线程之间的数据交换和同步是一个常见而重要的挑战。生产者和消费者模型是一种经典的解决方案&#xff0c;它为我们提供了一种简单而灵活的方法来协调多个线程的操作。无论是构建消息队列、日志记录系统还是任务调度系统&#xff0c;生…

Java 数组形参

java 基本数据类型传递参数时是值传递 &#xff1b;引用类型传递参数时是引用传递 。 我们根据三道问题来探索一下是什么意思。 首先来看一个问题。 问题一 以下方法调用传递给程序是什么 &#xff1f; double[] rats {1.2, 3.4, 5.6}; routine( rats );A、rats 的副本 …

DataTable.Load(reader)注意事项

对于在C#中操作数据库查询&#xff0c;这样的代码很常见&#xff1a; using var cmd ExecuteCommand(sql); using var reader cmd.ExecuteReader(); DataTable dt new DataTable(); dt.Load(reader); ...一般的查询是没问题的&#xff0c;但是如果涉及主键列的查询&#xf…

protobuf简介(一)

1.protobuf简介 Protobuf是Protocol Buffers的简称&#xff0c;它是Google公司开发的一种数据描述语言&#xff0c;是一种轻便高效的结构化数据存储格式&#xff0c;可以用于结构化数据串行化&#xff0c;或者说序列化 。它很适合做数据存储或 RPC 数据交换格式。可用于通讯协议…

保定兴芮科技有限公司环卫市场化运营服务项目招标公告

项目概况 保定兴芮科技有限公司环卫市场化运营服务项目招标项目的潜在投标人应在河北省公共资源交易服务平台获取招标文件&#xff0c;并于2024年02月20日09点00分(北京时间)前递交投标文件。 一、项目基本情况 项目编号&#xff1a;QDZB2024-010 项目名称&#xff1a;保定兴芮…

洛谷P1540 机器翻译

参考代码 #include<iostream> #include<queue> using namespace std; int nums[1010]; int main(){queue<int> q;int M,N;cin>>M>>N;int res0;while(N--){int tmp;cin>>tmp;if(nums[tmp]1)continue;if(q.size()<M){q.push(tmp);res;nu…

交叉注意力融合时域、频域特征的FFT + CNN-Transformer-CrossAttention轴承故障识别模型

目录 往期精彩内容&#xff1a; 前言 1 快速傅里叶变换FFT原理介绍 第一步&#xff0c;导入部分数据 第二步&#xff0c;故障信号可视化 第三步&#xff0c;故障信号经过FFT可视化 2 轴承故障数据的预处理 2.1 导入数据 2.2 制作数据集和对应标签 3 交叉注意力机制 …

网站地址怎么改成HTTPS?

现在&#xff0c;所有类型的网站都需要通过 HTTPS 协议进行安全连接&#xff0c;而实现这一目标的唯一方法是使用 SSL 证书。如果您不将 HTTP 转换为 HTTPS&#xff0c;浏览器和应用程序会将您网站的连接标记为不安全。 但用户询问如何将我的网站从 HTTP 更改为 HTTPS。在此页…

移动端设计规范 - 文字使用规范

这是一篇关于移动端产品界面设计时&#xff0c;文字大小的使用规范&#xff0c;前端人员如果能了解一点的话&#xff0c;在实际开发中和设计沟通时&#xff0c;节省沟通成本&#xff0c;也能提高设计落地开发时的还原度。 关于 在做移动端产品设计时&#xff0c;有时候使用文字…

【开源精选导航】GitHub-Chinese-Top-Charts:一榜在手,优质中文项目轻松找寻

各位热爱开源技术的朋友们&#xff0c;你们是否有过这样的困扰&#xff1a;面对浩瀚的GitHub海洋&#xff0c;想找寻那些具有高质量中文文档的优秀开源项目却无从下手&#xff1f;今天&#xff0c;我们就为大家揭晓一个宝藏般的开源项目——GitHub 中文项目集合&#xff08;访问…

二维数组移动,合并数值简易2048

2848简易核心运算 --多元素合并数组举例4*4 -- 星空露珠韩永旗制作 --数据合并并重新赋值 --多元素合并数组举例4*4 -- 星空露珠韩永旗制作 --数据合并并重新赋值 local data{{0,2,0,2}, {4,2,0,8}, {8,0,8,4}, {2,2,4,8}} local ch{{1…

【Node.js基础】Node.js的介绍与安装

文章目录 前言一、什么是Node.js&#xff1f;二、安装Node.js2.1 Windows系统2.2 macOS系统2.3 Linux系统 三、运行js代码总结 前言 随着互联网技术的不断发展&#xff0c;构建高性能、实时应用的需求日益增长。Node.js作为一种服务器端运行时环境&#xff0c;以其事件驱动、非…

万户 ezOFFICE SendFileCheckTemplateEdit.jsp SQL注入漏洞

0x01 产品简介 万户OA ezoffice是万户网络协同办公产品多年来一直将主要精力致力于中高端市场的一款OA协同办公软件产品,统一的基础管理平台,实现用户数据统一管理、权限统一分配、身份统一认证。统一规划门户网站群和协同办公平台,将外网信息维护、客户服务、互动交流和日…

uniapp-app使用富文本编辑器editor

使用的是uniapp内置组件的表单组件editor&#xff1a;editor 组件 | uni-app官网 (dcloud.net.cn) 文档上写的也不是特别详细&#xff0c;还以为得npm&#xff0c;但没npm也能用 注意&#xff1a;editor不能封装为组件&#xff0c;否则报错&#xff08;在其他文章看的&#x…

OpenSIPS3.2保存和恢复sdp

uac opensips uas --->invite with sdp--> --->invite with sdp <---183 with sdp <--- 183 with sdp <--- 200 without sdp <---200 without sdp 这是最近的一个case&#xff0c;需要在路由里面做如下处理…

从比亚迪的整车智能战略,看王传福的前瞻市场布局

众所周知&#xff0c;作为中国新能源汽车的代表企业&#xff0c;比亚迪在中国乃至全球的新能源汽车市场一直都扮演着引领者的角色。2024年新年伊始&#xff0c;比亚迪又为新能源汽车带来了一项重磅发布。 整车智能才是真智能 近日&#xff0c;在“2024比亚迪梦想日”上&#xf…

BERT问答模型回答问题

在数据准备阶段&#xff0c;确保您有一个高质量的问答对数据集非常重要。这个数据集应该包含问题和对应的答案&#xff0c;以及答案在上下文中的位置&#xff08;起始和结束索引&#xff09;。 预处理数据时&#xff0c;清洗数据、去除无用信息、分词、转换为小写等操作可以帮…

基于二值化图像转GCode的斜向扫描实现

基于二值化图像转GCode的斜向扫描实现 什么是斜向扫描斜向扫描代码示例 基于二值化图像转GCode的斜向扫描实现 什么是斜向扫描 在激光雕刻中&#xff0c;斜向扫描&#xff08;Diagonal Scanning&#xff09;是一种雕刻技术&#xff0c;其中激光头沿着对角线方向来回移动&…

C++面试:表结构设计规范

目录 表结构设计规范 示例 第一个 第二个 1. 合理选择数据类型 2. 使用主键 3. 避免使用NULL 4. 规范命名 5. 规范化 6. 使用索引优化查询 7. 考虑关系完整性 8. 避免过宽的表 9. 预留扩展性 10. 安全性考虑 表结构设计是数据库设计的重要组成部分&#xff0c;它…

编译opencv4.6问题汇总,第三方软件包见我发的资源

win10系统 python3.8.2&#xff0c;cmake-3.15.5-win64-x64&#xff0c;opencv4.6 编译方式见&#xff1a;OpenCV的编译 - 知乎 本文主要总结问题。赠人玫瑰手留余香。 问题1 Problem with installing OpenCV using Visual Studio and CMake (error code: MSB3073) 解决方法…