【K8S 系列】k8s 学习二,kubernetes 核心概念及初步了解安装部署方式

简介: 【K8S 系列】k8s 学习二,kubernetes 核心概念及初步了解安装部署方式

咱们再来回顾一下 K8S 集群架构的组件,在网上找一张集群架构图说明一波

1、master 组件

  • apiserver

集群的统一入口,restful 的方式,最后交给 etcd 存储

  • shcheduler

节点调度,选择 node 节点进行应用部署

  • controller-manager

处理集群中常规后台任务,一个资源对应一个控制器

  • etcd

存储系统,用于保存集群相关的数据

2、node 组件,工作节点

  • kubelet

master 排到 node 节点代表,管理本机的容器

  • kube-proxy

提供网络代理,负载均衡等操作

k8s 核心概念

1、Pod

  • 最小部署的逻辑单元
  • 是一组容器的集合
  • 共享网络
  • 生命周期短暂

2、controller

  • 确保预期的 Pod 副本数量
  • 无状态应用部署 / 有状态应用部署
  • 确保所有 node 运行同一个 Pod
  • 执行一次性任务和定时任务

3、service

  • 定义一组 Pod 的访问规则

Kubernetes 安装方式:

  • 使用官方提供的 minikube
  • 使用 kubeadmin 进行部署,k8s的部署工具,跑在 k8s 里面,这个使用起来相对简单

kubeadmin 提供 kubeadmin init 和 kubeadmin join,用于快速部署 k8s 集群

官网地址为:https://kubernetes.io/docs/reference/setup-tools/kubeadm/

  • 自己使用 kubernetes 二进制方式安装部署 (这种部署方式,我们学习的时候一定要走这个步骤,一步一步的去搭建,才能遇到很多问题,进而解决他,熟悉他)

官方提供的 minikube

minikube

点击 Launch Terminal ,可以查看到如下界面

官方给我们提供的 minikube ,版本是 v1.8.1

系统是 Ubuntu 18.04

CPU 2 核

内存 2 G

磁盘 145 G 左右

Kubernetes 版本 v1.17.6

Docker 版本 19.03.6

咱们可以使用 kubectl get pods -n kube-system 查看一下 pod 节点

kubeadmin 进行部署

使用 kubeadmin 来进行部署,相对使用二进制来部署就会简单容易一些,先来规划一下部署方案

平台规划

单 master 搭建方式

多 master 搭建方式

kubeadmin 开始部署

使用 kubeadmin 部署 k8s 环境,通过如下 2 条指令即可完成 kubernetes 的部署:

  • kubeadm init

创建一个 master 节点

  • kubeadm join <master 节点的IP 和端口>

将 node 节点加入到集群中

测试环境硬件要求

master 节点: 2 核,2G,磁盘 20 G

node 节点:4 核,8G,磁盘 80 G

  • 一台或者多台机器,操作系统自选,可以是 ubuntu ,可以是 centos
  • 硬件配置如上
  • 集群中所有的节点网络互通
  • 可以访问外网,可以拉取镜像
  • 禁止 swap 分区

先来安装一下 kubectl

官方提供了 4 种方式来安装 kubecrl

咱们直接使用第 1 种:

1、用如下命令下载最新的 kubectl 版本

curl -LO "https://dl.k8s.io/release/$(curl -L -s https://dl.k8s.io/release/stable.txt)/bin/linux/amd64/kubectl"

2、下载 kubectl 校验和文件

curl -LO "https://dl.k8s.io/$(curl -L -s https://dl.k8s.io/release/stable.txt)/bin/linux/amd64/kubectl.sha256"

3、验证 kubectl 的可执行文件

echo "$(<kubectl.sha256) kubectl" | sha256sum --check

# echo "$(<kubectl.sha256) kubectl" | sha256sum --check
kubectl: OK

出现上述情况,为验证通过

4、安装 kubectl

sudo install -o root -g root -m 0755 kubectl /usr/local/bin/kubectl

5、查看咱们安装的版本

kubectl version --client

# kubectl version --client
Client Version: version.Info{Major:"1", Minor:"22", GitVersion:"v1.22.0", GitCommit:"c2b5237ccd9c0f1d600d3072634ca66cefdf272f", GitTreeState:"clean", BuildDate:"2021-08-04T18:03:20Z", GoVersion:"go1.16.6", Compiler:"gc", Platform:"linux/amd64"}
  • GitVersion

git 的版本是 v1.22.0

  • GoVersion

go 的版本是 1.16.6

  • BuildDate

构建时间为 2021-08-04T18:03 ,还算挺新

配置一下 kubectl 自动补全功能

kubectl 的自动补全功能依赖 bash-completion,因此需要我们安装他

1、安装 bash-completion

apt-get install bash-completion

2、启动 kubectl 自动补全功能

~/.bashrc 中导入(source)补全脚本

echo 'source <(kubectl completion bash)' >>~/.bashrc

将补全脚本添加到目录 /etc/bash_completion.d

kubectl completion bash >/etc/bash_completion.d/kubectl

如果 kubectl 有关联的别名,你可以扩展 shell 补全来适配此别名

echo 'alias k=kubectl' >>~/.bashrc
echo 'complete -F __start_kubectl k' >>~/.bashrc

kubernetes 的安装部署方式步骤相对有点多,这个必须要自己一步一步的实践,否则是学不到东西的,大家可以多在官网上摸摸鱼

https://kubernetes.io/docs/tasks/tools/install-kubectl-linux/

参考资料:

kubernetes docs

欢迎点赞,关注,收藏

朋友们,你的支持和鼓励,是我坚持分享,提高质量的动力

好了,本次就到这里

技术是开放的,我们的心态,更应是开放的。拥抱变化,向阳而生,努力向前行。

我是小魔童哪吒,欢迎点赞关注收藏,下次见~

相关实践学习
通过Ingress进行灰度发布
本场景您将运行一个简单的应用,部署一个新的应用用于新的发布,并通过Ingress能力实现灰度发布。
容器应用与集群管理
欢迎来到《容器应用与集群管理》课程,本课程是“云原生容器Clouder认证“系列中的第二阶段。课程将向您介绍与容器集群相关的概念和技术,这些概念和技术可以帮助您了解阿里云容器服务ACK/ACK Serverless的使用。同时,本课程也会向您介绍可以采取的工具、方法和可操作步骤,以帮助您了解如何基于容器服务ACK Serverless构建和管理企业级应用。 学习完本课程后,您将能够: 掌握容器集群、容器编排的基本概念 掌握Kubernetes的基础概念及核心思想 掌握阿里云容器服务ACK/ACK Serverless概念及使用方法 基于容器服务ACK Serverless搭建和管理企业级网站应用
相关文章
|
8天前
|
存储 Kubernetes Docker
Kubernetes(k8s)和Docker Compose本质区别
理解它们的区别和各自的优势,有助于选择合适的工具来满足特定的项目需求。
62 19
|
22天前
|
关系型数据库 MySQL Docker
《docker高级篇(大厂进阶):5.Docker-compose容器编排》包括是什么能干嘛去哪下、Compose核心概念、Compose使用三个步骤、Compose常用命令、Compose编排微服务
《docker高级篇(大厂进阶):5.Docker-compose容器编排》包括是什么能干嘛去哪下、Compose核心概念、Compose使用三个步骤、Compose常用命令、Compose编排微服务
84 24
|
14天前
|
存储 Kubernetes 容器
K8S部署nexus
该配置文件定义了Nexus 3的Kubernetes部署,包括PersistentVolumeClaim、Deployment和服务。PVC请求20Gi存储,使用NFS存储类。Deployment配置了一个Nexus 3容器,内存限制为6G,CPU为1000m,并挂载数据卷。Service类型为NodePort,通过30520端口对外提供服务。所有资源位于`nexus`命名空间中。
|
19天前
|
Kubernetes 应用服务中间件 nginx
二进制安装Kubernetes(k8s)v1.32.0
本指南提供了一个详细的步骤,用于在Linux系统上通过二进制文件安装Kubernetes(k8s)v1.32.0,支持IPv4+IPv6双栈。具体步骤包括环境准备、系统配置、组件安装和配置等。
185 10
|
24天前
|
关系型数据库 MySQL Docker
《docker高级篇(大厂进阶):5.Docker-compose容器编排》包括是什么能干嘛去哪下、Compose核心概念、Compose使用三个步骤、Compose常用命令、Compose编排微服务
《docker高级篇(大厂进阶):5.Docker-compose容器编排》包括是什么能干嘛去哪下、Compose核心概念、Compose使用三个步骤、Compose常用命令、Compose编排微服务
109 6
|
23天前
|
存储 Kubernetes 关系型数据库
阿里云ACK备份中心,K8s集群业务应用数据的一站式灾备方案
本文源自2024云栖大会苏雅诗的演讲,探讨了K8s集群业务为何需要灾备及其重要性。文中强调了集群与业务高可用配置对稳定性的重要性,并指出人为误操作等风险,建议实施周期性和特定情况下的灾备措施。针对容器化业务,提出了灾备的新特性与需求,包括工作负载为核心、云资源信息的备份,以及有状态应用的数据保护。介绍了ACK推出的备份中心解决方案,支持命名空间、标签、资源类型等维度的备份,并具备存储卷数据保护功能,能够满足GitOps流程企业的特定需求。此外,还详细描述了备份中心的使用流程、控制台展示、灾备难点及解决方案等内容,展示了备份中心如何有效应对K8s集群资源和存储卷数据的灾备挑战。
|
2月前
|
Kubernetes Cloud Native 微服务
云原生入门与实践:Kubernetes的简易部署
云原生技术正改变着现代应用的开发和部署方式。本文将引导你了解云原生的基础概念,并重点介绍如何使用Kubernetes进行容器编排。我们将通过一个简易的示例来展示如何快速启动一个Kubernetes集群,并在其上运行一个简单的应用。无论你是云原生新手还是希望扩展现有知识,本文都将为你提供实用的信息和启发性的见解。
|
Kubernetes Shell Docker
Kubernetes安装部署演示介绍-(一)
序 这是差不多2年前我整理的一篇纯手工搭建Kubernetes的文档,里边涉及的软件版本相对偏低一些,但对一些初学者来说应该依然具有一定的借鉴意义。 环境介绍: OS:Linux redhat721 3.
1278 0
|
Kubernetes Shell 容器
Kubernetes安装部署演示介绍-(二)
四、安装k8s 1、安装 使用的是k8s 1.2.4版本。 将kubernetes.tar.gz 上传主机,并解压。 tar -xzvf kubernetes.tar.gz cd kubernetes/server/ tar -xzvf kubernetes-server-linux-amd64.
1130 0
|
9天前
|
Prometheus Kubernetes 监控
OpenAI故障复盘 - 阿里云容器服务与可观测产品如何保障大规模K8s集群稳定性
聚焦近日OpenAI的大规模K8s集群故障,介绍阿里云容器服务与可观测团队在大规模K8s场景下我们的建设与沉淀。以及分享对类似故障问题的应对方案:包括在K8s和Prometheus的高可用架构设计方面、事前事后的稳定性保障体系方面。

热门文章

最新文章