k8s的陈述式资源管理(命令行操作)

(一)k8s的陈述式资源管理

1、命令行:kubectl命令行工具——用于一般的资源管理

1优点:90%以上ce场景都可以满足
2特点:对资源的增、删、查比较方便,对改不是很友好
3缺点:命令比较冗长,复杂,难记

2、声明式:k8s当中的yaml文件来实现资源管理——用于配置部署服务

3、GUI:图形化工具的管理

(二)kubectl命令的详解:查看、部署、查看pod的情况(详细信息和日志,发布和回滚)

kubectl命令的详解

kubectl命令行大全:http://docs.kubernetes.org.cn/683.html

先声明动作:create、delete、get、describe

对象:ns、pod、service

对象的名称:hyde nginx

查看

查看版本

kubectl version

查看所有api的资源对象的名称

kubectl api-resources

查看k8s的集群信息

kubectl cluster-info

基本信息查看:

查看master节点的状态

kubectl get cs

查看默认命令空间内的pod信息

kubectl get pod/pods

查看当前集群的所有命名空间

kubectl get ns

查看指定命名空间内的pod信息

kubectl get pod -n kube-system命名空间的名称

查看默认命名空间内pod的详细信息(IP、节点信息)

kubectl get pod -o wide

查看指定命名空间内pod的详细信息

kubectl get pod -o wide -n kube-system

查看node节点的信息和状态

kubectl get nodes/node

查看node节点的详细信息

kubectl get node -o wide

查看已经部署好的pod的详细信息

kubectl describe pod nginx-6799fc88d8-89g2npod的名称

查看指定命名空间内pod的详细信息

kubectl describe pod -n kube-system etcd-master

查看pod的日志

kubectl logs nginx-6799fc88d8-89g2n

动态查看pod的日志

kubectl logs -f nginx-6799fc88d8-89g2n

查看指定命名空间内的日志

kubectl logs -n kube-system etcd-master

创建命名空间

kubectl create ns hyde

删除命名空间

kubectl delete ns hyde

删除pod

kubectl delete pod nginx-6799fc88d8-89g2npod名称)——实际上并没有删除

deployment的部署pod

deployment部署的方式:陈述式部署(命令行)、声明式部署(yml文件)

deployment部署的特点:

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

②自我修复:如果有pod节点发生故障,deployment会自动启动新的pod来进行代替,如果更新有问题,deployment会提供还原点,可以手动还原到未更新前的状态

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

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

* 基于deployment创建的pod,或者是daemonset方式创建的pod,是由控制器创建的pod,使用delete删除pod是删除不掉,相当于重启pod

查看命名空间内通过deployment创建的pod

kubectl get deployments

查看指定命名空间内通过deployment创建的pod

kubectl get deployments -n kube-system

查看命名空间内通过daemonset创建的pod

kubectl get daemonsets

查看指定命名空间内通过daemonset创建的pod

kubectl get daemonsets -n kube-system

* daemonset部署不能通过命令行创建,只能在yml文件中定义这种创建方式。

* daemonset后台运行创建,在每个节点上都创建一个相同方式的,相同版本的容器运行的pod,一般都是依赖环境和重要组件,一般也不会对这些资源进行操作

创建deployment副本

kubectl create deployment nginx-dn --image=nginx

在指定命名空间创建deployment

kubectl create deployment nginx-dn --image=nginx --replicas=3 -n hyde

删除pod(一旦删除deployment,基于deployment创建的pod都会被删除)——慎用

kubectl delete deployments.apps nginx-dn -n hyde

不是基于控制器deployment创建的pod,用delete可以直接删除

kubectl run nginx2 --image=nginx很少使用

kubectl delete pod nginx2

远程进入节点容器

kubectl exec -it nginx-6799fc88d8-blx25 bash

docker的exec只能在本机内部使用,不能跨主机,kubectl的exec可以跨主机进入容器

指定命名空间进入容器

kubectl exec -it  nginx-6799fc88d8-4zqld bash -n hyde

kubectl delete pod nginx1-6f54f4bd96-gmkdb --force --grace-period=0

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

grace-period

表示过度的存活期,默认是30秒,可以让pod优雅的结束容器内的进程,然后退出pod;0表示立刻停止pod,必须要force

对基于deployment创建的pod进行扩容和缩容:

扩容

kubectl scale deployment nginx-dn --replicas=3

缩容

kubectl scale deployment nginx-dn --replicas=1

发布服务的service:

service的类型:生产中用ExternalName做域名映射+NodePort对外提供访问

ClusterIP

创建service的默认类型,提供一个集群内部的虚拟IP地址,这是service的默认类型,通过这个虚拟IP可以直接访问pod 的资源,无法对外提供访问

NodePort

会在每一个node节点上都开放一个相同的端口,外部可以通过node的本机IP+端口,访问pod资源(集群外部访问service的一种方式,四层代理方式),访问方式是nodeip:nodeport,nodeport可以随机指派,也可以指定(范围30000-32767)

LoadBalancer

如果service的类型设定为LoadBalancer,映射地址(云平台提供LoadBalancer的地址),这种用法仅用于公有云服务供应商在云平台上设置的service的场景,外部来访问,实现负载均衡,LoadBalancer的地址是要付费的。创建好了service,指定类型为LoadBalancer,会给你提供一个地址来代理pod内部的IP地址

ExternalName

DNS映射,给service分配一个域名,通过域名来访问后端的pod资源,ExternalName的service类型,不能提供负载均衡,必须要设置一个LoadBalancer的地址才能实现

查看集群中的service

kubectl get svc

删除service

kubectl delete svc nginx

查看指定命名空间的service

kubectl get svc -n kube-system

①创建pod:kubectl create deployment nginx --image=nginx:1.10 --replicas=3

②基于deployment创建service:

kubectl expose deployment nginx --port=80 --target-port=80 --name=nginx-service --type=NodePort

* --port=80:service集群内部的端口,是service和容器映射的端口,任意

* --target-port=80:pod内部容器的端口

NodePort  10.96.112.70:集群内部的IP地址,外部可不易访问这个IP地址

80:32168/TCP

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

* 32168:和内部的service的80端口做映射(本机的端口)

③实现负载均衡:

④修改service中nodeport的地址:

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

项目的生命周期:创建——发布——更新——回滚——删除

更新

kubectl set image deployment nginx nginx=nginx:1.20

curl -I 20.0.0.71:31000

回滚

①查看回滚点:kubectl rollout history deployment nginx

②记录回滚点变更:kubectl set image deployment nginx nginx=:1.15 --record

③回滚:kubectl rollout undo deployment nginx --to-revision=2

查看回滚的状态

kubectl rollout status deployment nginx

②kubectl get pod -w:动态查看pod的更新情况

查看集群内部的所有信息

kubectl get all

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

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

相关文章

7+衰老+WGCNA+机器学习+实验,非肿瘤领域的衰老相关研究

今天给同学们分享一篇生信文章“Identification of aging-related biomarkers and immune infiltration characteristics in osteoarthritis based on bioinformatics analysis and machine learning”,这篇文章发表在Front Immunol期刊上,影响因子为7.3…

C语言——小细节和小知识7

一、逆序字符串 1、递归1 #include <stdio.h> #include <string.h>void ReverseArray(char *str) {char temp *str;//1int len (int)strlen(str);*str *(str len - 1);//2*(str len - 1) \0;//3if(strlen(str 1) > 2)//只要字符串还大于2&#xff0c;就…

解锁小程序UI设计的奥秘:必须知晓的相关事项

一、什么是小程序 2016年张小龙首次提出小程序概念&#xff0c;全称为“微信小程序”&#xff0c;英文名为“微信小程序”MiniProgram它是一种基于微信生态系统、开发周期短、成本低、无需下载安装、即用即走的应用。 到目前为止&#xff0c;小程序不仅是微信独有的&#xff…

4-链表-合并两个有序链表

这是链表的第4题&#xff0c;来个简单算法玩玩。力扣链接。 将两个升序链表合并为一个新的 升序 链表并返回。新链表是通过拼接给定的两个链表的所有节点组成的。 示例 1&#xff1a; 输入&#xff1a;l1 [1,2,4], l2 [1,3,4] 输出&#xff1a;[1,1,2,3,4,4]示例 2&#xff…

Android Studio 如何实现软件英文变中文教程

目录 前言 一、确认版本号 二、下载汉化包 三、汉化包安装 四、如何实现中英文切换 五、更多资源 前言 Android Studio是一款功能强大的集成开发环境&#xff08;IDE&#xff09;&#xff0c;用于开发Android应用程序。默认情况下&#xff0c;Android Studio的界面和…

移动机器人规划、控制算法初识

规划与控制PNC(PlanningandControl) 1 路径规划算法&#xff1a; 移动机器人路径规划算法总结_机器人运动轨迹算法-CSDN博客 2 控制算法&#xff1a; 机器人控制算法综述_机器人控制技术综述-CSDN博客 机器人控制算法简要概述_智能控制算法-CSDN博客 学习资源&#xff1a; …

绝地求生:大逃杀,鼠标灵敏度设置教程及枪法练习技巧 鼠标灵敏度怎么设置

《绝地求生大逃杀》鼠标灵敏度怎么设置&#xff1f;作为一款FPS游戏&#xff0c;如何调整鼠标参数是大家急需掌握的&#xff0c;今天闲游盒带来“院长尼克”分享的《绝地求生大逃杀》鼠标灵敏度设置教程及枪法练习技巧&#xff0c;废话不多说&#xff0c;下面我们一起来看吧。 …

Vue2+element-ui 实现select选择器结合Tree树形控件实现下拉树效果

效果&#xff1a; DOM部分 &#xff1a; // 设置el-option隐藏的下拉选项&#xff0c;选项显示的是汉字label&#xff0c;值是value // 如果不设置一个下拉选项&#xff0c;下面的树形组件将无法正常使用 <el-form-item label"报警区域" prop"monitorId"…

DM达梦数据库表占用空间大小

问题描述&#xff1a; 项目涉及用户量大且数据量大&#xff0c;为提高查询性能采用分表方式处理数据&#xff1b;根据业务要求总共4张业务表&#xff0c;每张业务表扩展成100张表&#xff0c;系统中总共400张表。部署至测试环境发现测试环境占用的磁盘空间是开发环境的8倍。 问…

智慧工地云平台源码 支持二次开发、支持源码交付

智慧工地利用移动互联、物联网、云计算、大数据等新一代信息技术&#xff0c;彻底改变传统施工现场各参建方的交互方式、工作方式和管理模式&#xff0c;为建设集团、施工企业、监理单位、设计单位、政府监管部门等提供一揽子工地现场管理信息化解决方案。 通过人员管理、车辆管…

Goby 漏洞发布| QNAP NAS authLogin.cgi 命令执行漏洞(CVE-2017-6361)

漏洞名称&#xff1a;QNAP NAS authLogin.cgi 命令执行漏洞&#xff08;CVE-2017-6361&#xff09; English Name&#xff1a;QNAP NAS authLogin.cgi command execution vulnerability (CVE-2017-6361) CVSS core: 9.8 影响资产数&#xff1a; 2637547 漏洞描述&#xff1…

Zookeeper之基于Docker搭建集群

简介 搭建ZK分布式模式&#xff0c;由2n1台服务器组成。 搭建集群有两种方式&#xff1a; 单机多服务&#xff1a; 不同服务使用不同的配置文件&#xff0c;配置不同的端口号等。使用同一个配置不同的server.id&#xff0c;即IP相同&#xff0c;但是端口不同。 多机多服务&a…

圆钢在线直线度测量仪的配置都有哪些?

圆钢产线有很多&#xff0c;并且很多都是需要对直线度尺寸进行检测的&#xff0c;这就是在线直线度测量仪的应用所在&#xff0c;在线检测远比人工检测能带给工厂更大的利益与效率。 在线直线度测量仪原理 直线度测量仪设置3台位置测量仪&#xff0c;每台位置测量仪内布置呈十字…

MySql篇——MySql使用常见问题及解决办法

这里汇总MySql使用常见问题及解决办法&#xff0c;会持续更新。 问题1.ERROR 1819 (HY000): Your password does not satisfy the current policy requirements。 含义&#xff1a;你设置的密码不符合当前的密码等级。 可使用 SHOW VARIABLES LIKE validate_password%; 查看…

C语言实例_stdlib.h库函数功能及其用法详解

一、前言 C语言作为一种高效、灵活的编程语言&#xff0c;标准库的使用对于开发人员来说是不可或缺的。其中&#xff0c;stdlib.h是C语言中一个重要的标准库头文件&#xff0c;提供了许多常用的函数和工具&#xff0c;以便开发人员能够更加便捷地进行内存管理、字符串处理、随…

NCNN环境部署及yolov5pt转ncnn模型转换推理

该内容还未完整&#xff0c;笔记内容&#xff0c;持续补充。 〇开发环境版本 vs2022 cmake3.21.1 ncnn20231027发行版 yolov5s v6.2 vunlkan1.2.198.1 Protobuf3.20.0 Opencv3.4.1 一、模型转换 yolov5s v6.2训练的pt模型&#xff0c;直接导出tourchscript&#xff0c…

开放式蓝牙耳机学生党适合买哪些?平价好用的开放式耳机推荐

对于学生党来说&#xff0c;想要买一款既平价又好用的开放式蓝牙耳机&#xff0c;确实需要仔细挑选&#xff0c;那啥是开放式耳机呢&#xff1f;简单来说&#xff0c;开放式耳机就是那种不把耳朵全部封闭起来的耳机&#xff0c;声音可以流通&#xff0c;听起来更自然、舒适&…

Conda:Python环境管理的瑞士军刀

在数据科学和机器学习的世界中&#xff0c;管理各种库和依赖关系的重要性不容忽视。Conda 就是为此而生的强大工具。本文将深入探讨 Conda 的简介、功能以及使用示例&#xff0c;帮助你更好地理解和使用这个工具。 Conda 简介 Conda 是一个开源的包管理系统和环境管理系统&am…

【Shell编程练习】通过位置变量创建 Linux 系统账户及密码

系列文章目录 输出Hello World 系列文章目录位置变量代码实现运行结果 位置变量 位置变量将以数字方式对变量进行命名&#xff0c;可将命令行参数的值存储到脚本中。要从命令行、函数或脚本执行等处传递参数时&#xff0c;就需要在 Shell 脚本中使用位置参数变量。下表为常用…

并发查询数据库并做汇总处理(多线程+CompletableFuture方式)

文章目录 1.需求说明2.准备工作3.线程池执行4.使用CompletableFuture 1.需求说明 我们想要通过更快的方式查询10w条user表数据内容&#xff0c;做数据的汇总&#xff0c;得到10w个用户的年龄分布。 此时很容易想到用多线程处理&#xff0c;但知易行难&#xff0c;还是动手来写…