当前位置: 首页 > news >正文

Kubectl 的使用——k8s陈述式资源管理

一、kebuctl简介:

kubectl 是官方的CLI命令行工具,用于与 apiserver 进行通信,将用户在命令行输入的命令,组织并转化为 apiserver 能识别的信息,进而实现管理 k8s 各种资源的一种有效途径。

对资源的增、删、查操作比较方便,但对改的操作就不容易了。

kubectl的命令大全:kubectl --help
k8s中文文档: http://docs.kubernetes.org.cn/683.html

二、kebuctl的使用: 

1.基础用法:

//查看版本信息 kubectl version

//查看资源对象简写 kubectl api-resources

//查看集群信息 kubectl cluster-info

//配置kubectl自动补全 source <(kubectl completion bash)

 

//node节点查看日志 journalctl -u kubelet -f

2.基本信息查看:

kubectl get <resource> [-o wide|json|yaml] [-n namespace]
获取资源的相关信息,-n 指定命令空间,-o 指定输出格式

获取pod资源: 

指定命令空间: 

指定输出格式:


resource可以是具体资源名称,如pod nginx-xxx;也可以是资源类型,如pod;或者all(仅展示几种核心资源,并不完整)
--all-namespaces 或 -A :表示显示所有命令空间:


--show-labels :显示所有标签:


-l app :仅显示标签为app的资源:


-l app=nginx :仅显示包含app标签,且值为nginx的资源:

-w:持续跟踪输出:

2.1查看master节点状态: 

//查看 master 节点状态
kubectl get componentstatuses
kubectl get cs

 2.2查看命名空间:

//查看命令空间
kubectl get namespace
kubectl get ns
//命令空间的作用:用于允许不同 命令空间 的 相同类型 的资源 重名的

2.3查看default命名空间的所有资源: 

//查看default命名空间的所有资源
kubectl get all [-n default]

2.4查看服务(Service)资源的状态:

//用于获取服务(Service)资源的状态kubectl get svc
//简写成svc

 2.5创建命名空间app:

//创建命名空间app
kubectl create ns app
//查看命名空间
kubectl get ns

2.6删除命名空间app:

//删除命名空间app
kubectl delete ns app
//查看命名空间
kubectl get ns			

3.创建和删除pod:

3.1指定pod控制器和容器镜像创建pod:

  • Deployment:无状态应用部署
  • Statefulset:有状态应用部署
  • Replicaset:副本数量控制器
  • Daemonset:确保所有节点运行同一类 Pod
  • Cronjob:计划性任务
//在命名空间kube-public 创建副本控制器(deployment)来启动Pod(nginx-wl)
kubectl create deployment nginx-0l --image=nginx  -n kube-public 

#创建一个名为nginx-01的deployment(无状态应用部署)

#指定为nginx镜像,且指定为kube-public命名空间

#査看kube-pubic命名空间资源#创建成功 

//用run直接创建——自主式pod
kubectl run gg --image=nginx -n kube-public
//直接创建删除后不会拉取镜像
//run存储在节点中

3.2描述某个资源的详细信息: 

kubectl describe 资源类型kubectl describe 资源类型/pod名

3.3查看命名空间kube-public 中的pod 信息:

//查看命名空间kube-public 中的pod 信息
kubectl get pods -n kube-public

 3.4扩容-缩容:

kubectl scale 资源名 --replicas=n       #n为数字,大于当前副本数则是扩容,小于则是缩容

3.5登录容器 :

kubectl exec -it pod名 -c 容器名 bash/sh        
#区别于docker exec只能登入本机的docker#如果pod中只有一个容器,则无需-c指定kubectl exec -it pod名 -c 容器名 -- 命令  #可以实现不进入容器执行 -- 后的命令

3.6删除pod资源:

由于存在deployment/rc之类的副本控制器,删除pod也会重新拉起来,需删除其控制器

kubectl delete pods <pod名>--force --grace-period=0         #添加该选项强制删除(无需等待)
#grace-period表示过渡存活期,默认30s,在删除pod之前允许POD慢慢终止其上的容器进程,从而优雅退出,0表示立即终止pod

3.7删除副本控制器:

kubectl delete deployment 资源名 -n kube-public

 三、项目的生命周期:

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

1.创建 kubectl create:

●创建并运行一个或多个容器镜像。

●创建一个deployment 或job 来管理容器。

//启动 nginx 实例,暴露容器端口 80,设置副本数 3
kubectl create deployment nginx --image=nginx:1.14 --port=80 --replicas=3
//为deployment的nginx创建service,并通过Service的80端口转发至容器的80端口上,
Service的名称为nginx-service,类型为NodePort

2.发布 kubectl expose:

●将资源暴露为新的 Service。

暴露默认的 ClusterIP 类型服务

kubectl expose deployment 控制器名称 --name=服务名称 --port=服务端口 --target-port=pod端口

 访问ClusterIP测试是否能负载均衡

访问ClusterIP测试是否能负载均衡: 

暴露 NodePort 类型服务 :

kubectl expose deployment 控制器名称 --name=服务名称 --port=服务端口 --target-port=pod端口 --type=NodePort

浏览器访问测试: 

查看单独容器详细信息 

3.更新 kubectl set:

●更改现有应用资源一些信息。

查看版本:

更改版本:

4.回滚 kubectl rollout:

回滚操作的使用方式:

kubectl rollout history pod控制器 控制器名        #查看该资源的更新历史

5.删除 kubectl delete:

删除所有资源代表一个项目的结束

kubectl delete pod控制器 控制器名称        #删除pod控制器kubectl delete 服务 服务名称                     #删除服务

四、金丝雀发布:

Deployment控制器支持自定义控制更新过程中的滚动节奏,如“暂停(pause)”或“继续(resume)”更新操作。比如等待第一批新的Pod资源创建完成后立即暂停更新过程,此时,仅存在一部分新版本的应用,主体部分还是旧的版本。然后,再筛选一小部分的用户请求路由到新版本的Pod应用,继续观察能否稳定地按期望的方式运行。确定没问题之后再继续完成余下的Pod资源滚动更新,否则立即回滚更新操作。这就是所谓的金丝雀发布。

当我们有多个服务需要创建时;我们在创建的过程中,先创建一部分然后暂停(pause);创建的这一部分作为测试;如果测试结果正常,我们再继续(resume)创建。

1.创建: 

2.暴露端口:

3.更新并在第一轮完成后暂停:

没更新前的版本:

更新deployment的版本,并配置暂停deployment: 

查看: 

4.测试无误后继续更新 : 

等待全部更新:

总结:

生命周期:

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

创建: kubectl create 《资源名称》 --image=《镜像名称》 --port= 端口 --replicas= target port=

发布:

kubectl expose 《资源类型》《资源名称》 --port -targetport= type=clusterIP|Nodeport

更新:

kubectl set image<资源类型><资源名称><容器名>=<镜像名 标签版本>

回滚:

kubectl rollout unde<资源类型><资源名称>默认是回滚到上一个版本状态

--to-revision=回滚的指定版本

kubectl rollout historylstatus <资源类型><资源名称>

删除:kubectl delete <资源类型><资源名称》

蓝绿发布:

两套设备 进行新旧版本的切换

好处:用户无感知,业务稳定

缺点:资源消耗2倍 成本特别高

滚动:

按照他的比例一部分一部分滚动更新,k8s的默认更新机制

无创建一点的比例pod,先创建在删除一定的旧的pod

灰度发布(金丝雀):

先更新一部分pod,然后在暂停更新

安排一小部分的用户流量去访问更新pod来进行测试,当测试没问题后在扩大比例 直到全部更新完成为止

当yaml配置文件发送改动成功后,使用create创建的资源想要更新的时候,需要先delete删除原有资源在去通过yaml文件,创建资源使用apply创建的资源想要更新,可以直接在执行kubectl apply -f 更新

相关文章:

Kubectl 的使用——k8s陈述式资源管理

一、kebuctl简介: kubectl 是官方的CLI命令行工具&#xff0c;用于与 apiserver 进行通信&#xff0c;将用户在命令行输入的命令&#xff0c;组织并转化为 apiserver 能识别的信息&#xff0c;进而实现管理 k8s 各种资源的一种有效途径。 对资源的增、删、查操作比较方便&…...

多天线技术

多天线技术可以分为两类&#xff1a;分集技术和空间复用技术。分集技术利用多天线接收或者发射载有同一信息的信号&#xff0c;提高传输的可靠性。分集技术是将瑞利衰落无线信道换成更加稳定的信道。 发射端未知CSI时的信道容量 发射端已知CSI时的信道容量 信道估计&#xff…...

Meta发布Chameleon模型预览,挑战多模态AI前沿

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

声压级越大,STIPA 越好,公共广播就越清晰吗?

在公共广播中&#xff0c;有些朋友经常问到是不是声压越大&#xff0c;广播清晰度就越高&#xff0c;下面我从搜集了一些专业技术资料&#xff0c;供大家参考。 一、声压级越大&#xff0c;STIPA 越好吗&#xff1f; 不完全是。最初&#xff0c;人们认为当声压级达到 60 dBA 以…...

基于springboot+vue的4S店车辆管理系统

开发语言&#xff1a;Java框架&#xff1a;springbootJDK版本&#xff1a;JDK1.8服务器&#xff1a;tomcat7数据库&#xff1a;mysql 5.7&#xff08;一定要5.7版本&#xff09;数据库工具&#xff1a;Navicat11开发软件&#xff1a;eclipse/myeclipse/ideaMaven包&#xff1a;…...

深入理解 HTTP 缓存

浏览器缓存不是本地存储&#xff0c;要分清。浏览器缓存分为强缓存和协商缓存。本篇文章参考&#xff1a;使用 HTTP 缓存防止不必要的网络请求 讲解之前&#xff0c;我画了个简图来解释浏览器从缓存中获取资源的过程。 1. 强缓存 强缓存是浏览器缓存机制中的一种&#xff0c;…...

upload-labs 通关方法

目录 Less-1&#xff08;JS前端验证&#xff09; Less-2&#xff08;MIME验证&#xff09; Less-3&#xff08;黑名单&#xff0c;特殊过滤&#xff09; Less-4&#xff08;黑名单验证&#xff0c;.htaccess&#xff09; Less-5&#xff08;黑名单&#xff0c;点空格点绕过…...

5-26 Cpp学习笔记

1、如果子类实现了基类的函数&#xff0c;返回值、参数都相同&#xff0c;就覆盖了基类的函数。 2、使用作用域解析运算符来调用基类的函数。myDinner.Swim(); —— 调用子类的。myDinner.Fish::Swim(); —— 调用基类的(基类是Fish) 3、在子类中使用关键字using解除对Fish::…...

YOLOv8_pose的训练、验证、预测及导出[关键点检测实践篇]

1.关键点数据集划分和配置 从上面得到的数据还不能够直接训练,需要按照一定的比例划分训练集和验证集,并按照下面的结构来存放数据,划分代码如下所示,该部分内容和YOLOv8的训练、验证、预测及导出[目标检测实践篇]_yolov8训练测试验证-CSDN博客是重复的,代码如下: …...

架构师必考题--软件系统质量属性

软件系统质量属性 1.质量属性2.质量属性场景描述3.系统架构评估 这个知识点是系统架构师必考的题目&#xff0c;也是案例分析题第一题&#xff0c; 有时候会出现在选择题里面&#xff0c;考的分数也是非常高的。 1.质量属性 属性说明可用性错误检测/恢复/避免性能资源需求/管理…...

使用AWR对电路进行交流仿真---以整流器仿真为例

使用AWR对电路进行交流仿真—以整流器仿真为例 生活不易&#xff0c;喵喵叹气。马上就要上班了&#xff0c;公司的ADS的版权紧缺&#xff0c;主要用的软件都是NI 的AWR&#xff0c;只能趁着现在没事做先学习一下子了&#xff0c;希望不要裁我。 本AWR专栏只是学习的小小记录而…...

在UbuntuLinux系统上安装MySQL和使用

前言 最近开始计划在Ubuntu上写一个webserver的项目&#xff0c;看到一些比较好的类似的项目使用了MySQL&#xff0c;我就打算先把环境搞好跑一下试试&#xff0c;方便后面更进一步的学习。其实在本机windows上我已经有一个mysql&#xff0c;不过 在Unbuntu上安装MySQL 首先…...

React 如何自定义 Hooks

自定义 Hooks React 内部自带了很多 Hooks 例如 useState、useEffect 等等&#xff0c;那么我们为什么还要自定义 Hooks&#xff1f;使用 Hooks 的好处之一就是重用&#xff0c;可以将代码从组件中抽离出来定义为 Hooks&#xff0c;而不用每个组件中重复去写相同的代码。首先是…...

智能家居完结 -- 整体设计

系统框图 前情提要: 智能家居1 -- 实现语音模块-CSDN博客 智能家居2 -- 实现网络控制模块-CSDN博客 智能家居3 - 实现烟雾报警模块-CSDN博客 智能家居4 -- 添加接收消息的初步处理-CSDN博客 智能家居5 - 实现处理线程-CSDN博客 智能家居6 -- 配置 ini文件优化设备添加-CS…...

双指针用法练习题(2024/5/26)

1三数之和 给你一个整数数组 nums &#xff0c;判断是否存在三元组 [nums[i], nums[j], nums[k]] 满足 i ! j、i ! k 且 j ! k &#xff0c;同时还满足 nums[i] nums[j] nums[k] 0 。请 你返回所有和为 0 且不重复的三元组。 注意&#xff1a;答案中不可以包含重复的三元…...

Ansible02-Ansible Modules模块详解

目录 写在前面4. Ansible Modules 模块4.1 Ansible常用模块4.1.1 Command模块4.1.2 shell模块4.1.3 scrpit模块4.1.4 file模块4.1.5 copy模块4.1.6 lineinfile模块4.1.7 systemd模块4.1.8 yum模块4.1.9 get_url模块4.1.10 yum_repository模块4.1.11 user模块4.1.12 group模块4.…...

【Python特征工程系列】一文教你使用PCA进行特征分析与降维(案例+源码)

这是我的第287篇原创文章。 一、引言 主成分分析&#xff08;Principal Component Analysis, PCA&#xff09;是一种常用的降维技术&#xff0c;它通过线性变换将原始特征转换为一组线性不相关的新特征&#xff0c;称为主成分&#xff0c;以便更好地表达数据的方差。 在特征重要…...

【Linux】Ubuntu系统挂载NAS文件夹

测试系统&#xff1a;Ubuntu24.02 1. 安装必要的软件包 sudo apt update sudo apt install cifs-utils 2. 创建挂载点 sudo mkdir -p /mnt/nas 3. 获取当前用户的 UID 和 GID id -u id -g 4. 挂载&#xff1a;设置用户名/密码/nas地址 sudo mount -t cifs -o username,…...

如何用ai打一场酣畅淋漓的数学建模比赛? 给考研加加分!

文章目录 数学建模比赛1. 数学建模是什么&#xff1f;2. 数学建模分工合作2.1 第一&#xff1a;组队和分工合作2.2 第二&#xff1a;充分的准备2.3 第三&#xff1a;比赛中写论文过程 3. 数学建模基本过程4. 2023全年数学建模竞赛时间轴5. 数学建模-资料大全6. 数学建模实战 数…...

深入浅出MySQL事务实现底层原理

重要概念 事务的ACID 原子性&#xff08;Atomicity&#xff09;&#xff1a;即不可分割性&#xff0c;事务中的操作要么全不做&#xff0c;要么全做一致性&#xff08;Consistency&#xff09;&#xff1a;一个事务在执行前后&#xff0c;数据库都必须处于正确的状态&#xf…...

2026届最火的五大AI辅助论文网站实测分析

Ai论文网站排名&#xff08;开题报告、文献综述、降aigc率、降重综合对比&#xff09; TOP1. 千笔AI TOP2. aipasspaper TOP3. 清北论文 TOP4. 豆包 TOP5. kimi TOP6. deepseek 有着自动剖析研究领域热点能力的AI开题报告工具&#xff0c;是依托自然语言处理与知识图谱技…...

HWA05_leetcode48旋转图像

题目解法class Solution:def rotate(self, matrix: List[List[int]]) -> None:"""Do not return anything, modify matrix in-place instead."""#这是一个n行n列的矩阵n len(matrix)#只需要遍历n/2行for i in range(n//2):#每一列从i开始直到…...

【开发小技巧】手把手调用腾讯 ClawHub 镜像分页搜索接口

【开发小技巧】手把手调用腾讯 ClawHub 镜像分页搜索接口 一、接口简介 如果你想在自己的项目里快速实现「技能列表检索」能力&#xff0c;这个接口非常适合做数据源。 接口地址&#xff1a;https://lightmake.site/api/skills请求方式&#xff1a;GET功能说明&#xff1a;分页…...

Ollama小白入门:从零开始使用Yi-Coder-1.5B,体验AI写代码

Ollama小白入门&#xff1a;从零开始使用Yi-Coder-1.5B&#xff0c;体验AI写代码 1. 为什么你需要Yi-Coder-1.5B 作为一个开发者&#xff0c;你是否经常遇到这些情况&#xff1a; 知道要实现什么功能&#xff0c;但写不出具体代码需要快速生成一些模板代码来节省时间学习新编…...

深入解析dify中的TF-IDF与余弦相似度在RAG重排序中的应用

1. 理解RAG中的重排序问题 在检索增强生成&#xff08;RAG&#xff09;系统中&#xff0c;重排序&#xff08;rerank&#xff09;是一个关键环节。想象一下你在图书馆用搜索引擎找资料&#xff1a;系统先找到100本可能相关的书&#xff0c;但真正对你有用的可能只有前3本。重排…...

Dism++终极指南:如何用这款免费工具彻底优化Windows系统

Dism终极指南&#xff1a;如何用这款免费工具彻底优化Windows系统 【免费下载链接】Dism-Multi-language Dism Multi-language Support & BUG Report 项目地址: https://gitcode.com/gh_mirrors/di/Dism-Multi-language Dism是一款强大的Windows系统维护工具&#x…...

第1篇 | AUTOSAR方法论解码:从整车功能到ECU落地的工程哲学

在汽车智能化浪潮中&#xff0c;一个深刻的悖论正困扰着无数工程师&#xff1a;为什么标准化架构明明承诺了“一次开发、多处复用”&#xff0c;现实却是每个项目都在重复造轮子&#xff1f;答案或许藏在AUTOSAR方法论的核心逻辑里。 AUTOSAR方法论的本质&#xff0c;是将整车软…...

DS3232 Arduino轻量RTC库:嵌入式时间管理与I²C优化实践

1. DS3232 Arduino库深度解析&#xff1a;面向嵌入式工程师的精简型RTC驱动实践指南1.1 库定位与工程设计哲学DS3232 Arduino库是一个专为嵌入式实时系统优化的轻量级IC实时时钟&#xff08;RTC&#xff09;驱动&#xff0c;其核心设计目标并非功能堆砌&#xff0c;而是在资源受…...

C语言在嵌入式开发中的核心优势与实践

1. C语言为何历久弥新在嵌入式开发领域摸爬滚打十几年&#xff0c;我见过无数编程语言起起落落&#xff0c;唯独C语言始终屹立不倒。记得刚入行时&#xff0c;前辈就告诉我&#xff1a;"想搞嵌入式&#xff0c;先把C语言吃透。"当时不以为然&#xff0c;直到后来调试…...

NPJ Precis Oncol 重庆大学附属肿瘤医院张久权教授团队:基于纵向MRI的分形分析预测乳腺癌新辅助化疗反应

01文献学习今天分享的文献是由重庆大学附属肿瘤医院张久权教授等团队于12月12日在肿瘤学顶刊《npj Precision Oncology》&#xff08;中科院1区top&#xff0c;IF8&#xff09;上发表的研究“Fractal analysis of longitudinal MRI for predicting response to neoadjuvant che…...