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

1、资源管理

(1)陈述式资源管理 (常用------查、增)

使用kubectl工具进行命令行管理

①特点:对资源的增删查比较方便,对改不友好

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

③缺点:命令冗长、复杂

(2)声明式资源管理 (常用------部署资源)

使用yml文件进行声明式资源管理

3 GUI图形化资源管理

2、kubectl命令详解

(1)查看

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

|--------------------|---------------------------------------------------------------------------------------------------|
| 查看版本信息 | kubectl version |
| 查看所有api的资源对象 | kubectl api-resources |
| ||
| 查看k8s的集群信息 | kubectl cluster-info |
| ||
| 自动补齐命令 | |
| 基本信息查看 ||
| 查看master节点的状态 | kubectl get cs |
| ||
| 查看默认命名空间内的pod信息 | kubectl get pod |
| ||
| 查看当前集群所有命名空间 | kubectl get namespaces |
| ||
| 查看指定命名空间里的pod | kubectl get pod -n 命名空间名称 |
| ||
| 查看默认命名空间内pod的详细信息 | kubectl get pod -o wide |
| ||
| 查看指定命名空间内的pod详细信息 | kubectl get pod -o wide -n 命名空间名称 |
| ||
| 查看node节点信息和状态 | kubectl get node |
| ||
| 查看node节点的详细信息 | kubectl get node -o wide |
| ||
| 查看已经部署好的pod的详细信息 | kubectl describe pod pod名称 |
| ||
| 查看指定命名空间里的pod的详细情况 | kubectl describe pod pod名称 -n 命名空间名称 |
| ||
| 动态查看pod日志 | kubectl logs -f pod名称 |
| ||
| 动态查看指定命名空间的pod日志 | kubectl logs -f pod名称-n 命名空间名称 |
| 创建命名空间 | kubectl create ns 名称 |
| ||
| 删除命名空间 | kubectl delete ns 名称 |
| ||
| 删除pod(没有真正删除) | kubectl delete pod pod名称 |
| 生成一个新的pod ||

(2)部署

1)deployment部署pod的两种方式

①陈述式部署(命令行)

②声明式部署(yml)

2)特点

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

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

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

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

注:必须基于deployment创建的服务才能实现以上功能 (绝大多数都使用deployment创建)

|------------------------------------------|-------------------------------------------------------------------------------------------------|
| 查看默认命名空间里基于deployment创建的pod | kubectl get deployments.apps |
| ||
| 查看指定命名空间里deployment创建的pod | kubectl get deployments.apps -n kube-system |
| ||
| 查看默认空间里daemonsets创建的pod | kubectl get daemonsets.apps |
| daemonset不能在命令行创建,只能用yml文件来创建pod,后台运行创建,在每个节点上创建一个方式相同、版本相同的容器运行的pod。一般是依赖环境和重要组件,不会对这些资源进行操作 ||
| ||
| 创建pod (同一个命名空间pod不能重名) | kubectl create deployment pod名称 --image=nginx (--replicas=3) |
| 注:若是基于deployment方式创建的pod ,或基于daemonset方式创建的pod,均是由控制器创建的pod,使用delete删除pod无法删除,相当于重启pod。先删除控制器,才能删除pod,但删除控制器,所有基于这个控制器的pod全部被删除 (慎用) kubectl delete deployments.apps nginx ||
| kubectl delete deployments.apps nginx ||
| 不是基于控制器创建的pod (可以直接删除,很少用) | kubectl run pod名称 --image=nginx |
| ||
| 远程进入节点容器 | kubectl exec -it 容器名称 bash |
| 注:docker的exec只能在本机使用,kubectl的exec可以跨主机进入容器 ||
| ||
| 指定命名空间进入容器 | kubectl exec -it 容器名称 bash -n 命名空间名称 |
| ||
| 快速结束容器 (用于结束卡在销毁状态的pod) | kubectl delete pod nginx-6799fc88d8-j4hxc --force --grace-period=0 |
| --grace-period表示过度的存活期(默认30秒,可以让pod优雅的结束容器内的进程,然后退出pod) --grace-period=0表示立刻退出 ||
| ||
| 对deployment创建的pod扩、缩容 (仅限于deployment控制器) | kubectl scale deployment nginx1 --replicas=3 |
| 扩容: 缩容: ||
| 发布服务的service ||
| ||
| 查看当前命名空间的service | kubectl get svc |
| ||
| 删除service | kubectl delete svc nginx |
| ||
| service的类型 ||
| ****①ClusterIP:****创建service的默认类型,提供一个集群内部的虚拟IP地址,通过这个虚拟IP可以直接访问pod的资源,仅限于pod内部,无法对外提供访问 ②NodePort (常用) 在每个node节点上都开放一个相同的端口,外部可以通过node的本机IP+端口访问pod资源,这是集群外部访问service资源的一种方式(四层代理),基于deployment创建的pod可以使用这种方式 nodeip:nodeport(nodeport可随机指派,也可指定,范围30000~32767) ||
| 对外暴露service端口 | kubectl expose deployment nginx --port=80 --target-port=80 --name=nginx-service --type=NodePort |
| --port=80 service集群的端口(可随意指定) --target-port=80 pod内部容器的端口(服务固定的端口号) ||
| 10.96.26.83:集群内部的IP地址,外部不可以访问 80:对应的是内部的service 端口 30934:和内部的service的80端口做映射 ||
| pod内部的容器的端口是固定的,--port是service和容器映射端口,可以随意指定 --target-port是容器内部的服务端口 ||
| 修改service端口 | kubectl edit svc service名称 |
| ||
| ③LoadBalance:若service类型设定为LoadBalance,映射地址(云平台提供LoadBalance的地址,需要付费),这种用法仅用于公有云服务供应商在云台上设置的service的场景,外部访问,实现负载均衡 创建service,指定类型为LoadBalance ||
| ||
| ④ExternalName (常用):DNS映射,给service分配一个域名,通过域名来访问后端pod的资源,ExternalName的service类型不能提供负载均衡,必须设置一个LoadBalance地址才能实现负载均衡 ||
| 注:企业内部最常见的是
NodePort和ExternalName
结合一起使用 ||

3 更新、回滚、发布方式

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

|--------------------|---------------------------------------------------------------------|
| 更新服务版本 | kubectl set image deployment nginx nginx=nginx:1.22.0 |
| ||
| 查看还原点 | kubectl rollout history deployment nginx |
| 数字越大,就是最近的一次的操作 ||
| 设置还原点时加上标识便于识别还原点 | kubectl set image deployment nginx nginx=nginx:1.15****--record**** |
| ||
| 回滚 | kubectl rollout undo deployment nginx --to-revision=1 |
| ||
| 查看还原状态 | ①kubectl rollout status deployment nginx ②kubectl get pod -w动态查看 |
| ||
| 查看默认命名空间集群内的所有信息 | kubectl get all |
| ||
| 看默认命名空间集群内的所有详细信息 | kubectl get all -o wide |
| ||
| 查看指定命名空间集群内的所有详细信息 | kubectl get all -o wide -n 命名空间名称 |
| ||

相关推荐
NineData5 小时前
NineData云原生智能数据管理平台新功能发布|2024年12月版
数据库·sql·算法·云原生·oracle·devops·ninedata
gs801405 小时前
CoreDNS 概述:云原生 DNS 服务的强大解决方案
云原生
三雷科技7 小时前
docker代理设置
运维·docker·容器
FF在路上8 小时前
Seata的部署与微服务集成
微服务·云原生·架构
ToString_10248 小时前
apollo内置eureka dashboard授权登录
云原生·eureka
C182981825758 小时前
Eureka原理
云原生·eureka
行者张良8 小时前
解决:离线部署Docker容器(使用Docker现有容器生成镜像,将镜像打包成tar并发布到离线服务器中)
服务器·docker·容器
ihengshuai8 小时前
使用DockerCompose部署服务
docker·云原生·容器
程序猿000001号9 小时前
如何进行单体前后端项目的微服务改造
微服务·云原生·架构
半卷书生9 小时前
将node节点加入k8s集群
linux·docker·kubernetes