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

news2024/9/20 11:47:10

一、命令行: 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.coloradmin.cn/o/2087164.html

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

相关文章

谷歌又出三款Gemini模型

每周跟踪AI热点新闻动向和震撼发展 想要探索生成式人工智能的前沿进展吗?订阅我们的简报,深入解析最新的技术突破、实际应用案例和未来的趋势。与全球数同行一同,从行业内部的深度分析和实用指南中受益。不要错过这个机会,成为AI领…

uniapp、微信小程序车牌的录入的解决方案

结合uv-ui进行编写&#xff0c;键盘使用uv-ui的组件&#xff0c;其他由我们自己编写。 <template><div class"addCarContent"><div class"boxContent"><div class"carCodeInput" click"getIndex"><div:cl…

中间件实时监控,运维难题一站解决

中间件是介于操作系统和在其上运行的应用程序之间的软件&#xff0c;实现了分布式应用程序的通信和数据管理&#xff0c;用于协调不同的系统和组件之间的通信&#xff0c;是连接应用与底层资源之间的桥梁。因此&#xff0c;中间件的稳定与高可用对于整个业务系统的可靠性和性能…

算法题:单词接龙

单词接龙 字典 wordList 中从单词 beginWord 到 endWord 的 转换序列 是一个按下述规格形成的序列 beginWord -> s1 -> s2 -> … -> sk&#xff1a; 每一对相邻的单词只差一个字母。 对于 1 < i < k 时&#xff0c;每个 si 都在 wordList 中。注意&#xf…

倒计时1天!每日一题,零基础入门FPGA

近年来&#xff0c;FPGA工程师凭借着远高于传统软件开发工程师的薪酬&#xff0c;吸引了越来越多的人转行。 然而&#xff0c;入门FPGA并非易事。你需要有清晰的学习路线&#xff0c;包括它的基本组成&#xff08;如可编程逻辑块CLB、输入输出块IOB、内部连线资源等&#xff0…

【单片机开发】单片机的烧录方式详解(ICP、IAP、ISP)

【前言】 在单片机开发过程中&#xff0c;程序的烧录是一个至关重要的环节。随着技术的不断演进&#xff0c;单片机烧录方式也日益多样化。本文将重点讲解单片机中三种常见的烧录方式&#xff1a;ICP&#xff08;In-Circuit Programming&#xff09;、ISP&#xff08;In-Syste…

html+css+js网页设计 婚庆类型模版 12个页面

htmlcssjs网页设计 婚庆类型模版 12个页面 网页作品代码简单&#xff0c;可使用任意HTML编辑软件&#xff08;如&#xff1a;Dreamweaver、HBuilder、Vscode 、Sublime 、Webstorm、Text 、Notepad 等任意html编辑软件进行运行及修改编辑等操作&#xff09;。 获取源码 1&am…

【排序算法】快速排序升级版--三路快排详解 + 实现(c语言)

&#x1f31f;&#x1f31f;作者主页&#xff1a;ephemerals__ &#x1f31f;&#x1f31f;所属专栏&#xff1a;算法 目录​​​​​​​ 前言 一、三路快排的整体思路 二、三路快排的具体实现 1.测试数据、交换函数和三数取中法 2.三路快排函数 三、程序全部代码 总…

vue手机端 搜索框调起带搜索键盘,点击确认自动关闭

效果如下图 步骤&#xff1a; 1.html,所需配置参数都在下图 <el-form :inline"true" :mode"serchFormf" class"searchForm" action"javascript:return true;"><el-form-item label"" ><el-inputsize"…

Oracle DG备库应用延迟问题分析处理

1.情况说明 分享一个之前的案例&#xff0c;客户备库出现间歇性的日志应用延迟&#xff0c;延迟最高时刻需经过约50分钟左右才能将日志追平。 2.详细记录 2.1、问题发现 数据库的DG1备库出现间歇性的日志应用延迟&#xff0c;具体表现为备库apply lag延迟过高。影响到数据库的…

基于Atlas200DK部署yolov5(v6.0)

Atlas200_YOLOv5_DVPP_AIPP 在Atlas200DK平台上基于DVPP和AIPP实现部署YOLOv5&#xff08;v6.0&#xff09; DVPP解码JPG&#xff0c;并Resize AIPP实现颜色转换&#xff1a;YUV420sp_U8 to RGB 效果&#xff1a; 前处理推理后处理5.21ms1.09ms4.41ms 环境&#xff1a;…

【hot100篇-python刷题记录】【多数元素】

R6-技巧篇 直接哈希表计数得了 查找最大&#xff0c;可以不用一次遍历&#xff0c;直接sort排序哈希表&#xff08;按值排列&#xff09;也可以 class Solution:def majorityElement(self, nums: List[int]) -> int:nlen(nums)tn//2dictdefaultdict(int)for num in nums:d…

C语言练习题2

1.基本运算符 /*基本运算符*/ #include<stdio.h> int main() {int a 10;int b 20;printf("%d %d %d %d", a b, a - b, a * b, a / b); }加减乘除是语言当中最基本的运算符。因为除法中都是整数&#xff0c;所以除法的结果只保留整数。要想获取小数部分除法…

IntelliJ IDEA修改默认.m2和.gradle缓存路径

IntelliJ IDEA修改默认.m2和.gradle缓存路径 在idea.exe安装路径下&#xff0c;找到\bin\idea.properties文件&#xff0c;打开&#xff0c;在后面追加两行&#xff08;如果没有&#xff09;&#xff1a; gradle.user.homeD:/program/gradle新位置maven_repositoryD:/program/m…

微服务框架一

微服务 配置描述 没有配置中心 建立配置中心后 配置中心在微服务的地位 主流配置中心对比 安装Nacos open API配置管理测试 配置外部mysql连接 Nacos每层含义 命名空间

从零开始掌握Vue实例

从零开始掌握Vue实例&#xff1a;深入理解数据绑定与生命周期的核心秘诀 引言 简要介绍主题&#xff1a; 在学习Vue.js的过程中&#xff0c;Vue实例是最基础也是最关键的部分。Vue实例是Vue应用的核心&#xff0c;它是数据、DOM元素和Vue组件之间的桥梁。掌握Vue实例的使用对于…

基于 ASP.NET的教材管理信息系统的设计与实现(最新定制开发,阿龙原创设计)✅

博主介绍&#xff1a; ✌我是阿龙&#xff0c;一名专注于Java技术领域的程序员&#xff0c;全网拥有10W粉丝。作为CSDN特邀作者、博客专家、新星计划导师&#xff0c;我在计算机毕业设计开发方面积累了丰富的经验。同时&#xff0c;我也是掘金、华为云、阿里云、InfoQ等平台…

前端开发学习Docker记录02容器操作

docker images先查看有哪些镜像 运行nginx docker run nginx使用docker ps 可以看到有哪些镜像在运行 docker stats查看运行状态 命令总结

Linux学习(16)-http协议(应用层)与web服务器

本节学习内容 1.HTTP协议基础概念 2.代码实现通过http协议与web端建立连接 一、HTTP协议&#xff08;超文本传输协议&#xff09; 1.HTTP协议为应用层协议其底层的传输层为TCP协议 2.HTTP协议的固定端口号为80&#xff08;HTTPS端口为443&#xff09;&#xff0c;小于1024…

计算机毕业设计PySpark+Django考研分数线预测 考研院校推荐系统 考研推荐系统 考研爬虫 考研大数据 Hadoop 大数据毕设 机器学习 深度学习

考研推荐系统— 项目概述 考研&#xff08;研究生入学考试&#xff09;是许多大学毕业生追求深造的一种途径。为了帮助考生更好地选择适合自己的研究生专业和院校&#xff0c;开发一个考研推荐系统可以为考生提供个性化的建议。该项目旨在通过数据分析和可视化技术&#xff0…