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已经配置好



浙公网安备 33010602011771号