news 2026/5/11 2:04:20

k8s-应用部署和组件及常用命令(2)

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
k8s-应用部署和组件及常用命令(2)

、相关组件介绍:

node是k8s的集群节点,和实际的机器对应

pod是应用容器,不同的应用部署在不同的pod中,k8s协调资源,将pod部署到集群中的node节点上(非master节点)。

同时pod又是挂在namespace下面的,命名空间之间互相隔离。

pause 管理多个应用容器:搭建k8s集群的时候有一个镜像名字就是 registry.k8s.io/pause:3.9

label 大规模管理pod

volume: 挂载应用数据,应用产生的数据(如日志)和应用配置数据(如configMap)

deployment : 应用部署管理:rs副本管理

service/ingress: 应用访问,对外开放tcp、http、https

flannel: 节点间的网络访问的解决方案。我们部署时采用的这个,也有其他的

2、常用操作指令

kubectl -h 查看命令信息:

image

具体命令的使用和参数也可以使用 kubectl 命令 -h 查看

2.1 get 查看

kubectl get -h

查看资源:get

查看node:

kubectl get nodes

查看命名空间:

kubectl get ns

查看pod:

kubectl get pods -A 查看所有命名空间的pod

kubectl get pods -n 命名空间 查看指定命名空间的pod

kubectl get pods -n kube-system 查看kube-system命名空间的pod

2.2、创建pod的方式

1.命令模式 run

kubectl run -h` 查看命令使用

kubectl run NAME --image=image [--env="key=value"] [--port=port] [--dry-run=server|client] [--overrides=inline-json]

[--command] -- [COMMAND] [args...] [options]

我们使用之前自己做的那个nginx镜像来创建一个nginx。

kubectl run my-nginx --image=k8s-harbor.taoyao.com/nijunyang/my-nginx:1.29.1

image

kubectl describe pod my-nginx 查看my-nginx 详细信息

kubectl logs my-nginx 查看my-nginx 日志

kubectl exec -it my-nginx -- bin/bash 进入容器内部进行交互操作 进入容器之后curl localhost 可以看到nginx的页面内容 exit 退出容器内部交互

kubectl get pods 不指定命名空间,默认使用是default

kubectl get pods -o wide 输出一些扩展信息

image

这里有个ip,这个ip就是这个pod在k8s中的ip,去到k8s的其他节点都能访问:curl 10.244.1.2

image

2.yaml资源清单方式

kubectl get pod my-nginx -o yaml 以yaml方式查看资源信息,,这个是一个实际的状态而k8s就是负责资源预期状态到实际状态。

kubectl run my-nginx --image=k8s-harbor.taoyao.com/nijunyang/my-nginx:1.29.1 --dry-run=client -o yaml 获取这个资源创建的预期状态,--dry-run 不会实际执行。

image

kind: Pod:说明这个 YAML 文件定义的是一个 Pod 资源

kubectl run my-nginx --image=k8s-harbor.taoyao.com/nijunyang/my-nginx:1.29.1 --dry-run=client -o yaml > nginx.yaml 把内容写到资源清单文件中去,用这个文件来创建资源

kubectl apply -f nginx.yaml 以资源清单方式创建资源

2.3 deployment 应用部署管理器

deployment 应用部署管理器,让应用向预期状态靠近,比如 RS 副本管理,pod数量少了,就会自动帮你启动到设置数量。

创建 deployment

命令方式:kubectl create deployment

kubectl create deployment NAME --image=image -- [COMMAND] [args...] [options]

kubectl create deployment my-nginx-deploment --image=k8s-harbor.taoyao.com/nijunyang/my-nginx:1.29.1

image

pod和deployment 还有rs 都创建好了

名字也有层级关系:deployment名字-RS名字-pod名字

资源清单方式:

kubectl create deployment my-nginx-deploment --image=k8s-harbor.taoyao.com/nijunyang/my-nginx:1.29.1 --dry-run=client -o yaml > my-nginx-deploment.yaml 把内容写到资源清单文件中去,用这个文件来创建资源

image

replicas 副本数改成2

kubectl apply -f my-nginx-deploment.yaml

直接就启动了两个pod

image

2.4 资源对象扩缩容:

edit:直接在现有的资源上修改属性

scale:直接动态调整数量

kubectl edit deployments.apps my-nginx-deploment 和vim操作一样 i 编辑模式 :wq 退出保存

image

修改为三个,保存之后k8s自动给我们调整为了三个

image

kubectl scale [--resource-version=version] [--current-replicas=count] --replicas=COUNT (-f FILENAME | TYPE NAME)

[options]

kubectl scale deployment my-nginx-deploment --replicas 5 设置为5个

image

基本也就差不多了,其他资源的创建方式也差不多,命令和yaml文件清单,推荐用文件方式。多使用帮助信息看看,再加上问AI,就差不多了

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/5/10 22:25:41

51、Linux网络文件共享与Samba服务全解析

Linux网络文件共享与Samba服务全解析 在当今的网络环境中,实现文件和资源的共享是非常重要的。本文将介绍两种实现网络文件共享的技术:网络文件系统(NFS)和Samba服务。 NFS:网络文件系统 NFS是一种用于在网络上共享文件系统的协议,它允许用户在不同的计算机之间共享文…

作者头像 李华
网站建设 2026/5/3 11:54:46

运输层核心总结

运输层位于网络层之上、应用层之下,核心职责是为应用进程提供端到端的逻辑通信,屏蔽网络层的异构性和不可靠性。通过 UDP 和 TCP 两种核心协议,分别提供无连接的尽最大努力交付和面向连接的可靠交付服务,依托端口实现进程间通信的…

作者头像 李华
网站建设 2026/5/10 12:51:05

3、编写首个Puppet清单指南

编写首个Puppet清单指南 清单排序配置 Puppet的近期版本支持基于本地清单的排序方式。在 puppet.conf 配置文件中,可按如下方式配置基于清单的排序: ordering = manifest此设置在Puppet 4中为默认配置。不过,了解排序原则仍十分重要,因为在更复杂的清单中,隐式顺序难…

作者头像 李华
网站建设 2026/5/10 2:33:01

6、深入探究 Puppet:Facts、Types 与 Providers 详解

深入探究 Puppet:Facts、Types 与 Providers 详解 一、Facter 系统简介 在 Puppet 中,最初的解决方案虽然强大但成本高昂。主节点在编译过程中遇到特定表达式时需回调代理节点,编写能处理命令返回错误码的清单很费力,且 Puppet 可能变得像奇特的脚本引擎。 当使用 pupp…

作者头像 李华
网站建设 2026/5/11 0:18:43

技术创新引领产业升级:数字化转型下的企业发展新路径

在当今快速变化的全球经济环境中,技术创新已成为驱动产业升级和企业发展的核心动力。随着数字化转型的不断深入,传统行业正面临前所未有的机遇与挑战。本文将探讨数字化转型的核心要素、企业在转型过程中遇到的常见问题以及未来发展趋势,为企…

作者头像 李华