K8S陈述式管理

命令行:kubectl命令行工具

优点:90%以上的场景都可以满足

对资源的增,删,查比较方便,对改不是很友好

缺点:

命令比较冗长,复杂,难记

声明式:

K8S当中的yaml文件来实现资源管理---声明式

GUI:图形化工具的管理

1、kubectl命令

查看 部署 查看pod的情况(详细的信息,日志,发布和回滚)

[root@master01 ~]# kubectl version 
查看k8s版本[root@master01 ~]# kubectl api-resources 
查看所有api资源对象的名称[root@master01 ~]# kubectl cluster-info 
查看K8S的集群信息[root@master01 ~]# kubectl get cs
查看master节点的状态[root@master01 ~]# kubectl get pod
[root@master01 ~]# kubectl get pod -n kube-system 查看默认命名空间内的pod的信息,加-n+命名空间的名称是查看指定命名空间的pod[root@master01 ~]# kubectl get ns
查看当前集群所有的命名空间[root@master01 ~]# kubectl get pod -o wide 
[root@master01 ~]# kubectl get pod -o wide -n kube-system
查看默认命名空间内,pod的详细信息,-n+命名空间,查看指定命名空间内pod详细信息[root@master01 ~]# kubectl get node 
查询节点的信息以及状态[root@master01 ~]# kubectl get node -o wide   查看node节点的详细信息包括真实IP以及他所使用的系统版本等
NAME       STATUS   ROLES                  AGE   VERSION    INTERNAL-IP      EXTERNAL-IP   OS-IMAGE                KERNEL-VERSION           CONTAINER-RUNTIME
master01   Ready    control-plane,master   21h   v1.20.15   192.168.211.10   <none>        CentOS Linux 7 (Core)   3.10.0-1160.el7.x86_64   docker://24.0.7
node01     Ready    <none>                 21h   v1.20.15   192.168.211.20   <none>        CentOS Linux 7 (Core)   3.10.0-1160.el7.x86_64   docker://24.0.7
node02     Ready    <none>                 21h   v1.20.15   192.168.211.30   <none>        CentOS Linux 7 (Core)   3.10.0-1160.el7.x86_64   docker://24.0.7[root@master01 ~]# kubectl describe pod nginx-6799fc88d8-9427k 
查看指定pod的详细信息  后面加上pod名称[root@master01 ~]# kubectl describe pod -n kube-system kube-flannel-ds-nw9nj 
查看指定命名空间,指定pod的详细信息[root@master01 ~]# kubectl logs -f nginx-6799fc88d8-9427k 
动态查看指定pod的日志[root@master01 ~]# kubectl logs -f -n kube-system kube-flannel-ds-ds7r4 
查询指定命名空间内的pod日志,一定要用-n来指定 [root@master01 ~]# kubectl create ns czy   创建命名空间
namespace/czy created
[root@master01 ~]# kubectl get ns
NAME              STATUS   AGE
czy               Active   5s
default           Active   21h
kube-node-lease   Active   21h
kube-public       Active   21h
kube-system       Active   21h
[root@master01 ~]# kubectl delete ns czy  删除命名空间 
namespace "czy" deleted
[root@master01 ~]# kubectl get ns
NAME              STATUS   AGE
default           Active   21h
kube-node-lease   Active   21h
kube-public       Active   21h
kube-system       Active   21h[root@master01 ~]# kubectl delete pod nginx-6799fc88d8-9427k 
删除指定pod   *要先声明动作  delete   create  get  describe 然后跟上对象: ns  pod  service  再跟上对象名称  nginx-6799fc88d8-9427k  
如果不是默认的命名空间,需要加上-n 来指定 

deployment的部署pod:

特点:有两种方式部署

1、陈述式部署:命令行

2、声明式:yaml文件进行部署

滚动更新,他不是一次性的把所有pod部署完毕,他是一个一个的部署更新,pod的更新时候用,逐步的引入新的pod,逐步的减少旧的pod

自我修复:如果有pod节点发生故障,deployment会自动启动新的pod来进行代替

回滚:如果更新有问题,deployment会提供还原点,可以手动还原到未更新前的状态。

扩容和缩容 :deploment可以随时跳转pod的数量,以适应流量的变化。

上述的功能必须是基于deploment创建的服务才可以。绝大多数的pod都是使用deployment来创建的

[root@master01 ~]# kubectl get deployments.apps 
NAME    READY   UP-TO-DATE   AVAILABLE   AGE
nginx   3/3     3            3           21h
查看命名空间内的deployments
[root@master01 ~]# kubectl get deployments.apps -n kube-system 
NAME      READY   UP-TO-DATE   AVAILABLE   AGE
coredns   2/2     2            2           21h
-n 查询指定命名空间 

daemonset:不能通过命令行创建,只能在yaml文件当中定义这种创建方式

后台运行创建,在每个节点上都创建一个相同方式的,相同版本的容器运行的pod

一般都是依赖坏境和重要组件,一般也不会对这些资源进行操作

[root@master01 ~]# kubectl create deployment nginx-czy --image=nginx  
用deployment 创建pod  [root@master01 ~]# kubectl create deployment nginx-xx --image=nginx --replicas=3 -n czy
deployment.apps/nginx-xx created
--replicas=3指定副本数量 czy:指定命名空间 
[root@master01 ~]# kubectl get pod -n czy 
NAME                        READY   STATUS    RESTARTS   AGE
nginx-xx-55f6c96849-8xqcf   1/1     Running   0          91s
nginx-xx-55f6c96849-mfb87   1/1     Running   0          91s
nginx-xx-55f6c96849-zsjtz   1/1     Running   0          91s如果是基于deployment方式创建的pod,或者是daemonset方式创建的pod是由控制器创建的pod
使用delete删除pod是删不掉的,如果你使用delete,相当于重启 [root@master01 ~]# kubectl delete deployments.apps -n czy nginx-xx 
deployment.apps "nginx-xx" deleted
删除deployment
基于deployment方式创建pod,一旦删除deployment,基于这个deployment创建的pod都会被删除 
不是基于控制器创建的,会被直接删除 

kubectl delete pod nginx-czudajdpu301983 --force --grace-period=0

grace-period:表示过度活期,默认是30秒

主要是用于结束卡在销毁状态的pod

对deployment创建的pod进行缩容

[root@master01 ~]# kubectl scale deployment nginx-czy --replicas=3 
deployment.apps/nginx-czy scaled
扩容
[root@master01 ~]# kubectl scale deployment nginx-czy --replicas=1
deployment.apps/nginx-czy scaled
缩容
只适用于deployment
service的类型:
ClusterIP:创建service时的默认类型,提供一个集群内部的虚拟IP地址,这是service的默认类型。通过虚拟IP可以直接访问pod的资源,但是仅限于内部请求,无法对外提供访问。
NotePort:会在每个node节点上都开放一个相同的端口。外部可以通过node的本机IP+端口,访问pod资源。集群外部访问service的一种方式。四层代理方式
nodeip:nodeport
随机指派,也可以指定 从30000开始到32767 
基于deployment创建的pod,可以使用的方式--port=80 service集群端口 
--target-port=80 pod内部容器的端口 [root@master01 ~]# kubectl expose deployment nginx1 --port=80 --target-port=80 --name=nginx-service --type=NodePort 
service/nginx-service exposed
[root@master01 ~]# kubectl get svc
NAME            TYPE        CLUSTER-IP     EXTERNAL-IP   PORT(S)        AGE
kubernetes      ClusterIP   10.96.0.1      <none>        443/TCP        23h
nginx-service   NodePort    10.96.165.42   <none>        80:30512/TCP   6s
创建service

10.96.165.42 集群内部的IP地址 外部不可以访问这个ip地址

80:对应的是内部的service的端口

30512:和内部的service的80端口做映射

pod内部的容器的端口是固定的

--port是service和容器映射的端口,可以是任意只要没被占用

LoadBalancer:如果service的类型设定为LoadBalancer,映射地址(云平台提供LoadBalancer的地址)这种用法仅用于

公有云服务供应商在云平台设置的service的场景。外部来访问实现负载均衡。

创建好了servicw,指定类型为LoadBalancer,会给你提供一个地址来代理pod内部的ip地址

ExternalName:DNS映射,给service分配一个域名。通过域名来访问后端pod资源。ExternalName的service类型,不能提供负载均衡

必须要设置一个LoadBalancer的地址才可以实现

更新和回滚以及发布的方式:

项目的声明周期:

创建----发布----更新----回滚----删除

[root@master01 ~]# kubectl set image deployment nginx2 nginx=nginx:1.10 
deployment.apps/nginx2 image updated
修改服务版本

回滚

[root@master01 ~]# kubectl rollout history deployment nginx2 
deployment.apps/nginx2 
REVISION  CHANGE-CAUSE
1         <none>
2         <none>
数字的大小决定了距离上次操作的远近,数字越大,就是你最近的一次操作 [root@master01 ~]# kubectl set image deployment nginx2 nginx=nginx:1.15 --record 
加上--record会打上标识 不会显示none值[root@master01 ~]# kubectl rollout undo deployment nginx2 --to-revision=1
deployment.apps/nginx2 rolled back
回滚到1这个点 

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

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

相关文章

MR实战:词频统计

文章目录 一、实战概述二、提出任务三、完成任务&#xff08;一&#xff09;准备数据1、在虚拟机上创建文本文件2、上传文件到HDFS指定目录 &#xff08;二&#xff09;实现步骤1、创建Maven项目2、添加相关依赖3、创建日志属性文件4、创建词频统计映射器类5、创建词频统计归并…

【CMake】1. VSCode 开发环境安装与运行

CMake 示例工程代码 https://github.com/LABELNET/cmake-simple 插件 使用 VSCode 开发C项目&#xff0c;安装 CMake 插件 CMakeCMake ToolsCMake Language Support &#xff08;建议&#xff0c;语法提示) 1. 配置 CMake Language Support , Windows 配置 donet 环境 这…

遥感影像-语义分割数据集:山体滑坡数据集详细介绍及训练样本处理流程

原始数据集详情 简介&#xff1a;该遥感滑坡数据集由卫星光学图像、滑坡边界的形状文件和数字高程模型组成。该数据集中的所有图像&#xff0c;即770张滑坡图像&#xff08;红点&#xff09;和2003张非滑坡图像&#xff0c;都是从2018年5月至8月拍摄的TripleSat卫星图像中截取…

windows下使用PowerShell切割大数据文件

测试文件为24.4G文件 打开PowerShell窗口&#xff0c;使用以下命令 $filePath 为指向文件路径 $outputPath 输出到指定文件夹 $chunkSize 单个文件控制切割大小 将命令修改完后&#xff0c;直接粘贴到powershell窗口&#xff0c;点击回车即可进行切割 $filePath "D:\…

【力扣算法日记】无重复字符的最长子串

最近刷了很多算法题&#xff0c;这些解题过程也拓展了自己的思路&#xff0c;是个适合记录的素材。所以决定在继技术知识点详解的【一文系列】之后&#xff0c;开启新坑——【力扣算法系列】&#xff0c;来记录力扣刷题过程。 分享题目不确定&#xff0c;目前打算只分享我认为…

C# OpenCvSharp DNN FreeYOLO 人脸检测

目录 效果 模型信息 项目 代码 下载 C# OpenCvSharp DNN FreeYOLO 人脸检测 效果 模型信息 Inputs ------------------------- name&#xff1a;input tensor&#xff1a;Float[1, 3, 192, 320] --------------------------------------------------------------- Outp…

基于SSM的人事档案管理系统的设计与实现

末尾获取源码 开发语言&#xff1a;Java Java开发工具&#xff1a;JDK1.8 后端框架&#xff1a;SSM 前端&#xff1a;采用JSP技术开发 数据库&#xff1a;MySQL5.7和Navicat管理工具结合 服务器&#xff1a;Tomcat8.5 开发软件&#xff1a;IDEA / Eclipse 是否Maven项目&#x…

C ++类

定义一个Person类&#xff0c;私有成员int age&#xff0c;string &name&#xff0c;定义一个Stu类&#xff0c;包含私有成员double *score&#xff0c;写出两个类的构造函数、析构函数、拷贝构造和拷贝赋值函数&#xff0c;完成对Person的运算符重载(算术运算符、条件运算…

canvas设置图形的阴影

查看专栏目录 canvas示例教程100专栏&#xff0c;提供canvas的基础知识&#xff0c;高级动画&#xff0c;相关应用扩展等信息。canvas作为html的一部分&#xff0c;是图像图标地图可视化的一个重要的基础&#xff0c;学好了canvas&#xff0c;在其他的一些应用上将会起到非常重…

微信小程序:flex布局实现换行

1、关键代码.wxml&#xff1a; <view class"pay margin-top-40"><view class"info"><view class"pay-info-title margin-left-22 flex-start"> 请选择充值金额</view><view class"flex-wrap margin-top-20&quo…

如何在 Ubuntu 20.04 上安装和使用 Docker

前些天发现了一个人工智能学习网站&#xff0c;通俗易懂&#xff0c;风趣幽默&#xff0c;最重要的屌图甚多&#xff0c;忍不住分享一下给大家。点击跳转到网站。 如何在 Ubuntu 20.04 上安装和使用 Docker 介绍 Docker是一个可以简化容器中应用程序进程管理过程的应用程序。…

数字后端设计实现 | 数字后端PR工具Innovus中如何创建不同高度的row?

吾爱IC社区星球学员问题&#xff1a;Innovus后端实现时两种种不同高度的site能做在一个pr里面吗&#xff1f; 答案是可以的。 Innovus支持在同一个设计中中使用不同的row&#xff0c;但需要给各自子模块创建power domain。这里所说的不同高度的row&#xff0c;有两种情况。 1…