Kubernetes(ubuntu)

报错:

Unable to fetch some archives, maybe run apt-get update or try with --fix-missing?

解决:
1、vim /etc/apt/sources.list

使用vim编辑sources.list
把原来的镜像地址

http://archive.ubuntu.com/
更换为
http://mirrors.aliyun.com/ubuntu

之后还要执行更新操作

apt-get update
vim批量替换命令:

:%s#abc#123#g --注:把abc替换成123

ubuntuSSH 无法远程登录问题

systemctl start ssh
Failed to start ssh.service: Unit ssh.service not found.

解决

sudo apt-get install openssh-server
sudo vi /etc/ssh/sshd_config
PermitRootLogin yes -- 添加

重启ssh

sudo service ssh restart

查看22端口

netstat -nultp|grep 22

安装服务端ubuntu后设置root密码:

sudo passwd root
查看ssh是否安装成功
没有安装:apt-get update

虚拟机基本设置:

#设置ROOT账户密码
sudo passwd root
#切换到root
su
#设置允许远程登陆root账户
vim /etc/ssh/sshd_config
PermitRootLogin yes
#重启服务
service ssh restart
#关闭交换空间
sudo swapoff -a
#避免开机启动交换空间注释/etc/fstab中的swap
#查看
free -h
#关闭防火墙
ufw disable

在线安装Docker

#更新软件源
sudo apt-get update
#安装依赖
sudo apt-get -y install apt-transport-https ca-certificates curl software-properties-common
#安装GPG证书
curl -fsSL http://mirrors.aliyun.com/docker-ce/linux/ubuntu/gpg | sudo apt-key add -
#增加一条软件源信息
sudo add-apt-repository "deb [arch=amd64] http://mirrors.aliyun.com/docker-ce/linux/ubuntu
$(lsb_release -cs) stable"
#更新软件源
sudo apt-get -y update
#安装docker-ce
sudo apt-get -y install docker-ce

 搭建Kubernetes集群

Master
Master 是 Cluster 的大脑,它的主要职责是调度,即决定将应用放在哪里运行。
Node:
Node 是 Pod 真正运行的主机,可以是物理机,也可以是虚拟机。为了管理 Pod,每个 Node 节点上至少要运行
container runtime(比如 docker 或者 rkt)、 kubelet 和 kube-proxy 服务。
Pod:
Kubernetes 使用 Pod 来管理容器,每个 Pod 可以包含一个或多个紧密关联的容器。
Pod 是一组紧密关联的容器集合,它们共享 PID、IPC、Network 和 UTS namespace,是 Kubernetes 调度的基本
单位。Pod 内的多个容器共享网络和文件系统,可以通过进程间通信和文件共享这种简单高效的方式组合完成服务。
Service:
Service 是应用服务的抽象,通过 labels 为应用提供负载均衡和服务发现。匹配 labels 的 Pod IP 和端口列表组成
endpoints,由 kube-proxy 负责将服务 IP 负载均衡到这些 endpoints 上。
每个 Service 都会自动分配一个 cluster IP(仅在集群内部可访问的虚拟地址)和 DNS 名,其他容器可以通过该地址
或 DNS 来访问服务,而不需要了解后端容器的运行。
kubernetes组件:

etcd 保存了整个集群的状态,服务注册发现;
kube-apiserver 提供了资源操作的唯一入口,并提供认证、授权、访问控制等机制;
kube-controller-manager 负责维护集群的状态,比如故障检测、自动扩展、滚动更新等;
kube-scheduler 负责资源的调度,按照预定的调度策略将 Pod 调度到相应的机器上;
kubelet 负责维持容器的生命周期,同时也负责 Volume(CVI)和网络(CNI)的管理;
Container runtime 负责镜像管理以及 Pod 和容器的真正运行(CRI),默认的容器运行时为 Docker;
kube-proxy 负责为 Service 提供 cluster 内部的服务发现和负载均衡;

安装kubernetes(三台机器同时进行)

1.修改主机名

查看ubuntu环境配置文件cloud.cfg(/etc/cloud目录下)

#该选项为是否允许修改主机名,把preserve_hostname修改为true preserve_hostname:
true
2.使用hostnamectl修改主机名

hostnamectl set-hostname kubernetes-master
3.查看主机信息是否修改成功

hostnamectl
4.安装kubelet,kubeadm,kubectl

kubelet:主要负责启动POD和容器
kubeadm:用于初始化kubernetes集群
kubectl:kubenetes的命令行工具,作用是部署和管理应用,查看各种资源,创建,删除和更新组件
#配置软件源
#安装系统工具
apt-get update && apt-get install -y apt-transport-https
# 安装 GPG 证书
curl https://mirrors.aliyun.com/kubernetes/apt/doc/apt-key.gpg | apt-key add -
# 写入软件源
cat << EOF >/etc/apt/sources.list.d/kubernetes.list
> deb https://mirrors.aliyun.com/kubernetes/apt/ kubernetes-xenial main
> EOF
#安装kubelet,kubeadm,kubectl
apt-get update
apt-get install -y kubelet kubeadm kubectl
版本号(重要):1.24.2
#设置kubectl开机启动并且启动kubelet
systemctl enable kubelet

systemctl start kubelet

#注意:安装完最后会打印一个版本号,记住版本后面配置master的配置文件需要用到
到此处Kubernetes的master已经安装好--后面需要配置

配置Master:

 

到 /usr/local/下创建 docker/kubernetes 文件夹,然后执行后面命令

 

1.导出配置文件 (在 /usr/local/docker/kubernetes 下导入配置文件)
kubeadm config print init
-defaults --kubeconfig ClusterConfiguration > kubeadm.yml
2.修改配置文件

#修改advertiseAddress:为master主机IP
advertiseAddress: 192.168.202.128
#因为有墙,把镜像源修改为国内的,比如阿里云
imageRepository: registry.aliyuncs.com/google_containers
#顺便配置calico的默认网段(后面网络配置会用到)
podSubnet: "192.168.0.0/16"
版本号:
kubernetesVersion:1.24.2
3.拉取所需要的镜像

#查看所需镜像列表
kubeadm config images list --config kubeadm.yml
#拉取镜像
kubeadm config images pull --config kubeadm.yml

在拉取镜像报错To see the stack trace of this error execute with --v=5 or higher
可以使用 docker pull 对镜像一个个拉取

4.初始化主节点

#定了初始化时需要使用的配置文件,其中添加 --experimental-upload-certs 参数可以在后续执行加入节点时自动分发证书文件。追加的 tee kubeadm-init.log 用以输出日志
kubeadm init --config=kubeadm.yml --experimental-upload-certs | tee kubeadm-init.log
5.配置kubectl(第四步结尾输出步骤)

mkdir -p $HOME/.kube
cp -i /etc/kubernetes/admin.conf $HOME/.kube/config
6.验证主节点是否安装完成

kubectl get nodes
到此处Kubernetes的master已经配置好

 

posted @ 2022-06-29 12:54  VNone  阅读(91)  评论(0)    收藏  举报