kubectl陈述式资源管理方式、声明式资源管理

一、命令行: kubectl命令行工具

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

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

缺点:命令比较冗长,复杂难记

声明方式:k8s当中的yaml文件实现资源管理----声明式

GUI:图形化工具的管理。

二、kebectl基础命令:

1.查看k8s版本:kubectl version

2.查看集群资源对象的版本和简写: kubectl api-resources

3.查看集群信息:kubectl cluster-info

4.查看系统日志的两种方式:tail -f /var/log/messages    journalctl -u kubelet -f

5.查看集群组件的健康状态:kubectl get cs

6.查看节点的状态:kubectl get node

7.查看默认命名空间里面当前运行的pod  :kubectl get pod

 #restarts 表示pod的重启次数,pod非正常状态下,会自动进行重启,状态正常之后就不会进行重     启,AGE:当前pod的运行的时间

[root@master1 ~]# kubectl get pod

8.创建命名空间:kubectl create ns xy102

9.删除命名空间两种方法:kubectl delete namespaces xy102     kubectl delete ns xy102

10.查看已有的命名空间:kubectl get ns

11.查看当前命名空间的所有资源:kubectl get all

12.deployment的部署方式:

deployment作用:资源对象也就是控制器

滚动更新:不是一次性的把所有pod部署完毕,而是一个一个的来。主要用来pod的更新时使用,逐步的引入新的pod逐步的减少旧的pod

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

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

扩容和缩容:通过deployment可以随时调增pod的数量,以适应流量的变化

上述的功能必须是基于deployment创建的服务才可以

工作中绝大多数的pod都是使用deployment创建的

13.pod两种部署方式:

deployment陈述式部署:命令行

声明式部署:yml文件部署

14.基于deployment创建pod:kubectl create deployment nginx1 --image=nginx:1.22 --replicas=3 -n xy102

--image=nginx:1.22:指定镜像   

--replicas=3:指定副本数

-n  xy102: 指定命名空间

15.查看指定命名空间内的pod

16.基于控制器也就是资源对象,deployment创建的pod   delete删除 pod相当于重启pod

17.不基于deployment创建的pod是可以直接删除的:kubectl run nginx2 --image=nginx:1.22 -n xy102

18.查看node节点的详细信息: kubectl get pod -n xy102 -o wide

19.查看pod的日志:

kubectl logs -f nginx1-654cb56c4-7z2hg

kubectl logs nginx1-654cb56c4-7z2hg

kubectl logs -f -n xy102 nginx1-654cb56c4-7z2hg

20.进入pod内容器:kubectl exec -it -n xy102 nginx1-654cb56c4-6vlf6 bash

21.缩容于扩容:陈述式命令行进行修改

kubectl scale deployment nginx1 -n xy102 --replicas=1

kubectl scale deployment nginx1 -n xy102 --replicas=3

扩容和缩容还可以用说明式修改yaml文件的方式进行扩缩容

kubectl edit deployments.apps nginx1 -n xy102


三、service

1.pod的IP地址随着pod的生命周期有可能会发生改变(例如扩容和缩容),但内部访问我们通过pod的ip可以直接访问,外部访问 就引申出一个pod对外暴漏端口的概念service,它也可以和内部pod容器做一个映射,这种关联映射不受pod的IP地址变化的影响,从而达到外部对pod的访问。

2.创建service:

kubectl expose deployment nginx1 --port=80 --target-port=80 --name=nginx11 -n xy102   

创建一个service名称叫nginx11,expose暴漏的端口为pod的端口,port80是service的端口,target-port80为pod容器内的端口,端口之间相互做个映射80对80

3..service类型及工作原理   :先是宿主机端口------service端口-------pod里面的容器端口

1》ClusterIP 默认类型(对内):提供集群内部的虚拟IP地址,是让其内部pod来访问的,外部访问不了;使用七层负载,对内单机访问

2》NodePort类型(对外):每个节点(集群的所有节点)都会开放一个端口,外部就会通过本机的IP+端口访问pod内的容器服务,每个节点nodeport端口都是一致的,nodeprot端口范围30000-32767;使用四层负载,service根据标签来匹配对应的pod,只要标签匹配都转发到指定的pod内的容器

3》4.LoadBalancer类型:云平台的运行商提供loadbalance的地址

工作原理:也是通过访问负载均衡的地址,可以实现pod的流量转发

4》.Externalname类型:把service的名字映射到DNS的域名上,让pod去访问集群外部的资源,而且设置为此类型,service不能提供四层负载均衡服务。dns映射

怎么来改Nodeport:在yaml文件内修改:kubectl edit svc -n xy102 nginx11

集群的所有节点都有了端口

访问:

首先进入pod的每个容器增添页面内容

进行访问:每个节点都可以访问到

标签:

 查看deployments标签

查看services的标签

selector app=nginx1:只要资源对象deployments里面或者pod里面app标签=nginx1的都可以经过service转发

通过标签进行访问:nginx2没有经过资源对象创建的pod,首先需要在yaml文件内指定标签

四、K8s的项目的生命周期:发布-----修改-----更新----回滚-----销毁

1.滚动更新和回滚:

对nginx1.22进行滚动更新

一个一个滚动更新,先更新一个更新完之后把第一个原来的扔掉,再更新第二个

回滚:数字大小决定了距离上次更新操作的远近,数字越大就是最近一次的操作

如何回滚

2.销毁:pod和service

删除命名空间:前提要先删除pod和service 

3. 项目的发布方式:应用升级以及新旧业务切换的这个过程当中如何保证对外的服务正常是一个非常重要的问题

发布的三种方式:

1》蓝绿发布:把服务器分为蓝绿两组,先停蓝组,绿组依然对外提供服务,等蓝组更新维护完毕上线之后再把绿组关闭维护,使其整个系统在做业务更新和发布过程中对外服务不受影响。

蓝绿发布特点:一旦出现问题影响范围比较大,发布策略也比较简单,用户无感知平滑过渡

               缺点:需要大量的后台服务器做为支持,成本大

2》金丝雀发布(又叫灰度发布):先使用一部分来更新为测试服,如果可以才会把剩下的服务器再进行更新;使用deployment控制器可以通过自定义控制的方式实现金丝雀发布。对自动化控制要求很高,整个系统的稳定性比蓝绿发布高,影响范围可控。

pause:断点 

3》滚动发布:默认模式,部署时间比较慢,但是节约资源,发布策略比较复杂

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

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

相关文章

【终端IDPS】开源安全平台Wazuh之Wazuh Server

引言 Wazuh是一个开源的、免费的企业级安全监控解决方案,专注于威胁检测、完整性监控、事件响应和合规性。它由部署在受监控系统的端点安全代理和管理服务器组成,服务器收集并分析代理收集的数据。Wazuh支持多平台,包括Windows、Linux、macOS…

VLM 系列——Mini-Monkey——论文解读

一、概述 1、是什么 Mini-Monkey 论文全称《Mini-Monkey: Multi-Scale Adaptive Cropping for Multimodal Large Language Models》,是一个轻量级MLLM(多模态的视觉-文本模型),基于InternViT、MLP和InternLLM,其实就是…

基于元神操作系统编程写硬盘扇区

1. 背景 本文介绍了“调用元神操作系统API向硬盘扇区写数据”的程序实现及测试结果。 2. 方法 (1)调用元神操作系统API读硬盘扇区 本部分内容已在前面的文章中进行介绍,详细内容请参考“编写程序调用元神操作系统的API”。 (…

STM32F103与ESP8266 WIFI模块的USART中断调试

本文概述了利用STM32F103的HAL库,通过USART中断方式调试ESP8266(ESP-01)WIFI模块的方法。首先介绍了开发环境和ESP-01模块的基本特点与功能,随后展示了如何通过电脑PC的串口助手进行初步调试与验证。最后,重点阐述了如…

SpringBoot-读取配置文件方式

前言 Spring Boot提供了多种灵活的方式来读取配置文件,以适应不同的开发和部署需求,SpringBoot启动的时候,读取配置文件的时候,首先获取的是file:/config/文件下的配置文件,也就是项目下config文件里面的配置文件&…

jmeter 响应乱码

Jmeter在做接口测试的时候的,如果接口响应的内容中有中文,jmeter的响应内容很可能显示乱码,为了规避这种出现乱码的问题,就要对jmeter的响应结果进行编码处理。 打开jmeter进行接口、压力、性能等测试,出现以下乱码问…

等保需要的设备部署vs网络安全域划分原则

等保需要的安全设备和部署 技术要点–等保2级 技术要点–等保3级 安全产品/服务全景图 选型产品说明 安全区域边界配置 资产探测及漏洞检测配置 网络安全域划分原则 网络安全域 定义 网络安全域是一种网络划分方式,将具有相同安全需求、访问控制、相同信任级别、…

【MySQL 14】用户管理

文章目录 🌈 一、用户管理⭐ 1. 用户信息⭐ 2. 创建用户⭐ 3. 修改密码⭐ 4. 删除用户 🌈二、数据库的权限⭐ 1. 权限列表⭐ 2. 查看权限⭐ 3. 授予权限⭐ 4. 回收权限 🌈 一、用户管理 MySQL 也会区分普通用户和超级用户。如果只是访问某一…

【云原生系列之SkyWalking的部署】

1、分布式链路追踪 1.1概念 在较大的web集群和微服务环境中,客户端的一次请求需要经过不同的模块,多个不同中间件,多个不同机器一起相互协作才能处理完成客户端的请求,而在这一系列的请求过程之中,处理流程可能是串行执行,也可能…

【微信小程序】全局数据共享 - MobX

1. 什么是全局数据共享 2. 小程序中的全局数据共享方案 3.Mobx的使用 1.npm init -y(根据实际情况选择) 在小程序项目中,可以通过 npm 的方式引入 MobX 。 如果你还没有在小程序中使用过 npm ,那先在小程序目录中执行命令: npm init -y2. …

19.神经网络 - 线性层及其他层介绍

神经网络 - 线性层及其他层介绍 1.批标准化层–归一化层(不难,自学看官方文档) Normalization Layers torch.nn — PyTorch 1.10 documentation BatchNorm2d — PyTorch 1.10 documentation 对输入采用Batch Normalization,可…

[数据集][目标检测]光伏发电板红外图像鸟粪检测数据集VOC+YOLO格式173张1类别

数据集格式:Pascal VOC格式YOLO格式(不包含分割路径的txt文件,仅仅包含jpg图片以及对应的VOC格式xml文件和yolo格式txt文件) 图片数量(jpg文件个数):173 标注数量(xml文件个数):173 标注数量(txt文件个数):173 标注类别…

sentinel安装

Releases alibaba/Sentinel GitHub java -jar sentinel-dashboard-1.8.8.jar 默认启动端口是8080 修改端口启动 java -jar sentinel-dashboard-1.8.8.jar --server.port8888 localhost:配置的端口 账密都是sentinel

本地部署Xinference实现智能体推理工作流(一)

提示:没有安装Docker的需要先提前安装好Docker 第一篇章 使用AutoDL平台快速部署xinference 备注:若使用AutoDL平台,以下过程使用无卡模型开机即可(省钱) 1. 下载Dify源码 Github下载Dify:https://github.com/langgenius/dify 2. 快速启动…

通过观测云 eBPF Tracing 实现无埋点的全链路追踪

前言 随着微服务架构的普及和系统复杂度的增加,对应用程序的可观测性要求也越来越高。传统的监控方法通常需要在应用程序中添加代码来记录和追踪重要信息,这种方法可能会增加系统的负担,并且在复杂系统中维护难度较大。 eBPF(Ex…

告别PDF格式困扰,2024年PDF转换器推荐

PDF现在已经逐渐成为了文件传输的主流格式了,它有保存文件页面版式的优点,但是这个格式编辑对大部分人来说还是不那么方便,日常我们还是习惯将它们转换成我们常见的 文本格式来操作。今天我分享一下可以实现PDF格式转换的pdf转换器有哪些吧。…

SX_c语言字符串赋值 “multiple definition of .. first defined here”问题_21

字符串赋值问题&#xff1a; #include <stdio.h> #include <string.h>char* my_string_cat(int position, int slot, char* content){char* gnsst NULL;static char retvalue[50];memset(retvalue, \0, sizeof(retvalue));if(position 0){//头部if(slot 0){//卡…

【视频讲解】SMOTEBoost、RBBoost和RUSBoost不平衡数据集的集成分类酵母数据集、治癌候选药物|数据分享...

全文链接&#xff1a;https://tecdat.cn/?p37502 分析师&#xff1a;Zilin Wu 在当今的大数据时代&#xff0c;科研和实际应用中常常面临着海量数据的处理挑战。在本项目中&#xff0c;我们拥有上万条数据&#xff0c;这既是宝贵的资源&#xff0c;也带来了诸多难题。一方面&a…

【递归回溯之floodfill算法专题练习】

1. 图像渲染 class Solution {int dx[4] {0, 0, -1, 1};int dy[4] {1, -1, 0, 0};int m, n;int oldcolor; public:vector<vector<int>> floodFill(vector<vector<int>>& image, int sr, int sc, int color) {oldcolor image[sr][sc]; // 保存原…

MySQL数据库MVCC机制底层原理详解

mvcc机制即多版本并发控制 当在事务中使用了写操作&#xff08;增删改&#xff09;语句时会给当前事务生成一个事务id&#xff0c;事务id是递增的 同时&#xff0c;对于被修改的行的数据会创建一个数据版本 &#xff0c;这个数据版本除了包含原有的字段还会包含一个事务id和一…