k8s笔记1- 初步认识k8s

k8s简介:       

         kubernetes,俗称k8是,用于自动部署,扩缩和管理容器化应用程序的开源系统,它将组成应用程序的容器,组合成逻辑单元,便于管理和服务发现。

k8s的作用

        自动化上线和回滚、存储编排、自动装箱、ipv4和ipv6双协议、自我修复、服务发现与负载均衡、secret和配置管理、批量执行、水平扩缩、为扩展性设计

k8s核心组件

  1.  etcd:分布式高性能数据库,key-value的形式存储节点上部署的容器信息等
  2.  api-server:资源操作入口,提供认证、授权、访问控制、api注册和发现等机制
  3.  controller manager:负责维护集群状态、故障检测、自动扩展、滚动更新等
  4.  scheduler:负责资源的调度,按照预定的调度策略将pod调度到相应的节点上
  5.  kubelet:负责维护容器的生命周期和CVI、CNI的管理
  6.  kubectl:在master节点上对k8s集群运行命令

Pod:

        k8s本身是以容器运行在目标机器上,每个k8s节点被称为Node,k8s集群是一组node机器组成的,k8s不直接无操作容器,而是提供了一个pod组件,封装了一组容器,容器都被pod管理。

       Pod是 K8s的最小的可部署的计算单元,它是Kubernetes创建和管理的。一个Pod通常包含一个或者多个容器,这些容器会共享存储、网络资源和运行配置

       可以通过一个YAML或JSON格式的配置文件定义Pod属性,包括容器镜像、环境变量、存储卷等。然后使用Kubernetes API或命令行工具(如kubectl)来创建和管理Pods。

k8s组件创建pod流程

  1. 在master节点写yaml,描述对容器的运行要求,创建pod的要求
  2. 使用kubectl命令创建应用这个资源的描述文件,开始k8s组件交互,把命令发给api-server
  3. api-server 利用本地https证书验证 kubectl请求是否被允许
  4. api-server 将pod创建信息记录到etcd数据库中,如应用的镜像版本、容器名、端口等
  5. api-server通知scheduler准备pod的调度
  6. scheduler调度从etcd中获取pod的部署信息,判断出一个合适的node节点准备部署pod 
  7. scheduler告知api-server决定部署pod的node节点
  8. apiserver将部署信息写入etcd中
  9. api-server通知远程具体的机器去读取etcd中的信息,根据这些信息创建pod

    

YAML语言介绍:

        YAML语言是一个类似xml、json的标志性语言,以数据为中心。 

格式如下:

#yml格式
user:
  age: 18
  address: zhengzhou

     YMAL语法:

  1. 大小写敏感
  2. 使用空格缩进表示层级关系,高版本可以使用tab
  3.  缩进空格数不重要,但是同层级的元素需要相同,左对齐
  4.  # 表示注释                                    

数据类型:

        纯量:单个的不可再分的值(字符串、布尔、整数、浮点、null、时间、日期) 

        对象:键值对的集合,又称为映射(mapping)/哈希(hash)/字典(dictionary)

        数组:一组按照次序排列的值,又称为序列(sequence)/列表(list)

纯量

        布尔:true 或false

        整型:整数,例如123、345等

        浮点:小数,例如3.1415926

        null:不写值 或者写~,建议~

        日期:必须使用iso 8601格式,即yyyy-mm-dd

        时间:必须使用iso 8601格式,即2024-01-03T14:47:00+08:00 时间和日期用T链接,+后边是时区

        字符串:直接写值,如果有特殊符号,必须使用单/双引号包裹

对象:

#yml格式对象格式1 -- 推荐
user:
  age: 18
  address: zhengzhou

#yml格式对象格式2
user: {age: 18,address: zhengzhou}
  

数组

格式1 -- 推荐
address: -zhengzhou
         -beijing
--格式2。
address: {zhengzhou,beijing}

一个yml文件如果想写两段yml内容,中间使用 --- 隔开 

address: -zhengzhou
         -beijing

---

address: -zhengzhou
         -beijing

资源管理方式

 1.命令式对象管理:直接使用命令操作Kubernetes资源

        例如:kubectl run nginx-pod --image=nginx:1.17.1 --port=80

kubectl 固定写法 ,要执行的指令,--image=nginx:1.17.1 --port=80 要干的事

2.命令式对象配置:通过命令配置和配置文件去操作Kubernetes资源

        例如:kubectl create/patch -f nginx-pod.yaml

kubectl固定写法 ,create/patch要执行的指令,nginx-pod.yaml通过配置文件执行

3.声明式对象配置:通过apply命令和配置文件去操作Kubernetes资源

kubectl apply -f nginx-pod.yaml  

对比第二条,apply 只能更新或创建资源

类型操作对象适用环境优点缺点
命令式对象管理对象测试简单只能操作对象,无法审计跟踪
命令式对象配置  文件开发可以审计跟踪项目较大时,配置文件会很多,操作麻烦
声明式对象配置目录开发支持目录操作意外情况下难以调试

 命令式对象管理

        kubectl是Kubernetes集群的命令行工具,通过它能够对集群本身进行管理,并能够在集群上进行容器化应用的安装部署

 语法:kubectl [command] [type] [name] [flags]

  •         command:指定要对资源的操作,例如:create get delete
  •         type:指定资源类型,deployment、pod、service
  •         name:指定资源的名称,名称大小写敏感
  •         flags:指定额外可选参数

案例

#创建一个名为 dev的namespace 名称为

kubectl create ns dev

#查看已有namespace

kubectl get ns

#在dev中创建一个nginx 的应用(pod)

kubectl run pod --image=nginx:1.17.1 -n dev

#查看 dev中的pod

kubectl get pod -n dev

#查看创建过程

kubectl describe pods pod -n dev

#删除namespace dev

kubectl delete ns dev

 

 命令式对象配置

1.创建一个nginxpod.yaml,内容如下

apiVersion: v1 
#创建一个 namespcae
kind: Namespace 
#namespcae 名称为dev
metadata: 
  name: dev 

---

apiVersion: v1 
#创建一个 pod
kind: Pod 
#pod名称为 nginxpod ,在dev的namespace中
metadata: 
  name: nginxpod
  namespace: dev 
# pod 中容器的名字是nginx-containers, 镜像为nginx:1.17.1
spac: 
# 注意containers 是一个数组 name和image是一组数据,注意对齐
  containers:
    - name: nginx-containers
      image: nginx:1.17.1

2.使用create 创建资源

kubectl create -f nginxpod.yaml 

 3.可以使用delete 和配置文件删除 namespace 和 pod

kubectl delete  -f nginxpod.yaml 

声明式对象配置

        使用声明式对象配置就是使用apply描述一个资源的最终状态(yaml)中定义的状态

kubectl apply -f yaml文件

        使用apply操作资源

                如果资源不存在就创建,等同于 kubectl create

                如果资源已存在,就更新,相当于 kubectl patch

root@***:/usr/local/k8code# kubectl delete  -f nginxpod.yaml 
namespace "dev" deleted
pod "nginxpod" deleted
root@***:/usr/local/k8code# kubectl get ns dev
Error from server (NotFound): namespaces "dev" not found
##资源不存在时会直接创建
root@***:/usr/local/k8code# kubectl apply -f nginxpod.yaml 
namespace/dev created
pod/nginxpod created
##资源已存在,但是资源文件没有更新
root@***:/usr/local/k8code# kubectl apply -f nginxpod.yaml 
namespace/dev unchanged
pod/nginxpod unchanged
##做了资源文件更新后可以看到 pod/nginxpod configured 配置有变更
root@***:/usr/local/k8code# vi nginxpod.yaml 
root@***:/usr/local/k8code# kubectl apply -f nginxpod.yaml 
namespace/dev unchanged
pod/nginxpod configured
##使用create 操作已存在资源,会抛出错误
root@***:/usr/local/k8code# kubectl create -f nginxpod.yaml 
Error from server (AlreadyExists): error when creating "nginxpod.yaml": namespaces "dev" already exists
Error from server (AlreadyExists): error when creating "nginxpod.yaml": pods "nginxpod" already exists

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

张驰咨询:ZENNER真兰标杆展示——2023年六西格玛DMAIC项目出色落下帷幕

告别了旧年,我们跨入了新的一年!ZENNER在23年初启动的DMAIC项目在2023年12月25日迎来了总结、收获成果的发布会。 ZENNER真兰集团中国区总裁杨燕明先生,张驰咨询公司的两位精益六西格玛黑带大师专家张驰老师和朱成朝老师,以及真诺…

云卷云舒:构建业务型电信智能运维方法

1 引言 智能运维(AIOps-Algorithmic IT Operations基于算法的IT运维)是人工智能技术在IT运维领域的运用,引用Gartner 的报告的一段话“未来几年,将近50%的企业将会在他们的业务和IT运维方面采用AIOps,远远高于今天的10…

java基础之java8新特性-默认方法

目录 1.默认方法 jdk8之前的接口 jdk8的接口 默认方法的用途 1.默认方法 jdk8之前的接口 在jdk8之前接口(interface)中可以定义变量和方法,变量必须是public,static,final的;方法必须是public&#xf…

腾讯云2024年优惠券领取入口及使用教程

腾讯云作为国内领先的云计算服务提供商,一直致力于为用户提供优质、高效、安全可靠的云计算服务。为了回馈广大用户,腾讯云会不定期地推出各种优惠活动,其中最受欢迎的就是优惠券活动。本文将详细介绍腾讯云优惠券的领取入口及使用教程。 一、…

19、BLIP-2

简介 github 通过利用预训练的视觉模型和语言模型来提升多模态效果和降低训练成本,预训练的视觉模型能够提供高质量的视觉表征,预训练的语言模型则提供了强大的语言生成能力。 实现过程 为了弥合模态差距,提出了一个分两个阶段预训练的 Qu…

秋招复习之数组与链表

目录 前言 1 数组 初始化数组: 访问元素 插入元素 删除元素 遍历数组: 查找元素 扩容数组: 数组的优点与局限性 2 链表 初始化链表 插入节点 删除节点 访问节点 查找节点 数组 vs. 链表 常见链表类型 3 列表 初始化列表 访问元素 插入与删…

6. Mybatis 缓存

6. Mybatis 缓存 MyBatis 包含一个非常强大的查询缓存特性,它可以非常方便地配置和定制。缓存可以极大的提升查询效率MyBatis系统中默认定义了两级缓存 一级缓存二级缓存 默认情况下,只有一级缓存(SqlSession级别的缓存,也称为本地缓存&…

vuex基础用法 与 辅助函数使用

效果图 index.js文件 import Vue from "vue"; import Vuex from vuexVue.use(Vuex)export default new Vuex.Store({state: {shopsList: [{goodsName: "手机1", //商品名goodsAmount: 0, //购买的商品数量goodsPrice: 100, //单个商品价格totalPrice: 0,i…

14.用户管理

目录 1、权限表 1、user表 1.用户列 2.权限列 3.安全列 4.资源控制列 2、db表和host 表 1.用户列 2.权限列 3. tables_priv 表和 columns _priv 表 4.procs_priv 表 2、账户管理 1. 登录和退出MySQL服务器 2、创建普通用户: 1.使用CREATE USER语创建…

C#最佳工具集合:IDE、分析、自动化工具等

C#是企业中广泛使用的编程语言,特别是那些依赖微软的程序语言。如果您使用C#构建应用程序,则最有可能使用Visual Studio,并且已经寻找了一些扩展来对您的开发进行管理。但是,这个工具列表可能会改变您编写C#代码的方式。 C#编程的…

找不到vcruntime140.dll怎么处理?6个修复教程分享

本文将详细介绍vcruntime140.dll文件的相关内容,并提供6个不同的修复教程,帮助大家解决这一问题。 一、vcruntime140.dll是什么文件? vcruntime140.dll是Visual C Redistributable Packages的一部分,它是Microsoft Visual Studi…

连续分配管理方式-第四十三天

目录 前言 单一连续分配 固定分区分配 分区大小相等 分区大小不等 分区说明表 动态分区分配 问题 用什么样的数据结构记录内存的使用情况 应该选择哪个分区进行分配 分区的分配与回收操作 分配 回收 结论 本节思维导图 前言 连续分配指为用户进程分配的必须是一…

条件随机场 (CRF) 的损失函数以及faiss 的原理介绍

1、条件随机场 (CRF) 的损失函数 条件随机场(CRF)是一种统计建模方法,常用于结构化预测问题,如序列标注、分词和命名实体识别等。在CRF模型中,损失函数用于衡量模型预测的标记序列与真实标记序列之间的差异。CRF的目标…

【Redux】自己动手实现redux和react-redux

1. React提供context的作用 在class组件的世界里,如果后代组件共享某些状态,比如主题色、语言键,则需要将这些状态提升到根组件,以props的方式从根组件向后代组件一层一层传递,这样则需要在每层写props.someData&#…

控制障碍函数(Control Barrier Function,CBF) 二、示例

二、示例 2.1、系统模型 这里我们举一个CBF作者给出的经典示例 我们定义控制输入 u u u 为蓝色车的推力。 p p p 为蓝色车的位置, v v v 为蓝色车的速度, z z z 为蓝色车与黄色车之间的距离, v 0 v_0 v0​ 为黄色车的速度。我们定义系统的…

功能介绍 | 探秘Goby功能世界:点击URL,即刻畅享快速调起之旅!

​​0x01 前言 ​我们从只会点鼠标的猴子到CtrlC,CtrlV来回切换的工具人,但有时候遇到大量需要复制的url界面,真的希望能有一个可以一键整理、一键扫描URL的功能来拯救! 好消息是,Goby从客户端版本2.8.6起,官方引入了…

CAN数据记录仪在新能源车上的应用

随着新能源汽车的快速发展,对车辆安全和性能的要求也越来越高。在新能源车中,液位传感器是必不可少的零部件之一,用于监测电池液位、冷却液位等关键参数。在测试阶段需要工作人员花费大量时间跟车去获取它的CAN数据,从而分析是否有…

web自动化测试从入门到持续集成

在很多刚学习自动化的可能会认为我只需要会运用selenium,我只需要在一个编辑器中实用selenium java编写了一些脚本那么就会自动化了,是真的吗?答案肯定是假的。自动化肯定是需要做到真的完全自动化,那如何实现呢?接着往…

学习Go语言Web框架Gee总结--前缀树路由Router(三)

学习Go语言Web框架Gee总结--前缀树路由Router router/gee/trie.gorouter/gee/router.gorouter/gee/context.gorouter/main.go 学习网站来源:Gee 项目目录结构: router/gee/trie.go 实现动态路由最常用的数据结构,被称为前缀树(Trie树) 关…

MySQL之CRUD,函数与union使用

目录 一.CRUD 1.1.SELECT(查询) 1.2.INSERT(新增) 1.3.UPDATE(修改) 1.4.DELETE(删除) 二.函数 2.1.常见函数 2.1.1.字符函数 2.1.2.数字函数 2.1.3.日期函数 2.2.流程控制函数 2.3.聚合函数 三.union与union all 四…