k8s(10)声明式对象配置--yaml文件

简介: k8s(10)声明式对象配置--yaml文件

声明式对象配置--yaml文件

程度

  • 有模板
  • 能看懂
  • 能修改
  • 能排错即可

yaml规范

  • 缩进代表上下级关系
  • 缩进时不允许使用Tab键,只允许使用空格,通常缩进2个空格
  • : 键值对,后面必须有空格
  • -列表,后面必须有空格
  • [ ]数组
  • #注释
  • | 多行文本块
  • ---表示文档的开始,多用于分割多个资源对象

使用yaml定义一个Pod

Pod配置模版

vim my-pod.yaml
apiVersion: v1
kind: Pod
metadata:
  name: my-nginx
spec:
  containers:
  - name: nginx
    image: nginx:1.22
    ports:
    - containerPort: 80

如果develop命名空间被删除了,记得换回来

[root@k8s home]# kubectl apply -f my-pod.yaml
Error from server (NotFound): error when creating "my-pod.yaml": namespaces "develop" not found
[root@k8s home]# kubectl config set-context $(kubectl config current-context) --namespace=default
Context "default" modified.

创建pod

[root@k8s home]# kubectl apply -f my-pod.yaml
pod/my-nginx created

删除pod

[root@k8s home]# kubectl delete -f my-pod.yaml 
pod "my-nginx" deleted

标签

标签(Labels) 是附加到对象(比如 Pod)上的键值对,用于补充对象的描述信息。

标签使用户能够以松散的方式管理对象映射,而无需客户端存储这些映射。

由于一个集群中可能管理成千上万个容器,我们可以使用标签高效的进行选择和操作容器集合。


  • 键的格式:
  • 前缀(可选)/名称(必须)
  • 有效名称和值:
  • 必须为 63 个字符或更少(可以为空)
  • 如果不为空,必须以字母数字字符([a-z0-9A-Z])开头和结尾
  • 包含破折号-、下划线_、点.和字母或数字

label配置模版

在yaml配置模板前提上加了一个labels属性

apiVersion: v1
kind: Pod
metadata:
  name: label-demo
  labels: #定义Pod标签
    environment: test
    app: nginx
spec:
  containers:
  - name: nginx
    image: nginx:1.22
    ports:
    - containerPort: 80
[root@k8s home]# vim label-pod.yaml
[root@k8s home]# kubectl apply -f label-pod.yaml 
pod/label-demo created
[root@k8s home]# kubectl get pod
NAME                            READY   STATUS    RESTARTS      AGE
nginx-deploy-855866bb46-5rqh4   1/1     Running   1 (38m ago)   6h23m
nginx-deploy-855866bb46-8fgzg   1/1     Running   1 (38m ago)   6h23m
nginx-deploy-855866bb46-87scw   1/1     Running   2 (35m ago)   6h23m
label-demo                      1/1     Running   0             4s
[root@k8s home]# kubectl get pod --show-labels
NAME                            READY   STATUS    RESTARTS      AGE     LABELS
nginx-deploy-855866bb46-5rqh4   1/1     Running   1 (38m ago)   6h24m   app=nginx-deploy,pod-template-hash=855866bb46
nginx-deploy-855866bb46-8fgzg   1/1     Running   1 (38m ago)   6h24m   app=nginx-deploy,pod-template-hash=855866bb46
nginx-deploy-855866bb46-87scw   1/1     Running   2 (36m ago)   6h24m   app=nginx-deploy,pod-template-hash=855866bb46
label-demo                      1/1     Running   0             24s     app=nginx,environment=test
[root@k8s home]# kubectl get pod -l app=nginx
NAME         READY   STATUS    RESTARTS   AGE
label-demo   1/1     Running   0          41s
[root@k8s home]# kubectl get pod -l app=nginx
NAME         READY   STATUS    RESTARTS   AGE
label-demo   1/1     Running   0          50s
[root@k8s home]# kubectl get pod -l app=nginx-deploy
NAME                            READY   STATUS    RESTARTS      AGE
nginx-deploy-855866bb46-5rqh4   1/1     Running   1 (39m ago)   6h24m
nginx-deploy-855866bb46-8fgzg   1/1     Running   1 (38m ago)   6h24m
nginx-deploy-855866bb46-87scw   1/1     Running   2 (36m ago)   6h24m
[root@k8s home]# kubectl get pod -l app=nginx,
Error from server (BadRequest): Unable to find "/v1, Resource=pods" that match label selector "app=nginx,", field selector "": found '', expected: identifier after ','
[root@k8s home]# kubectl get pod -l app=nginx
NAME         READY   STATUS    RESTARTS   AGE
label-demo   1/1     Running   0          70s
[root@k8s home]# kubectl get pod -l app=nginx,environment=text
No resources found in default namespace.
[root@k8s home]# kubectl get pod -l app=nginx,environment=test
NAME         READY   STATUS    RESTARTS   AGE
label-demo   1/1     Running   0          79s

选择器--创建service

标签选择器 可以识别一组对象。标签不支持唯一性。

标签选择器最常见的用法是为Service选择一组Pod作为后端。

需要有pod,这里用上一个知识点的label创建的pod

Service配置模版

apiVersion: v1
kind: Service
metadata:
  name: my-service
spec:
  type: NodePort
  selector: #与Pod的标签一致
    environment: test
    app: nginx
  ports:
      # 默认情况下,为了方便起见,`targetPort` 被设置为与 `port` 字段相同的值。
    - port: 80
      targetPort: 80
      # 可选字段
      # 默认情况下,为了方便起见,Kubernetes 控制平面会从某个范围内分配一个端口号(默认:30000-32767)
      nodePort: 30007
[root@k8s home]# vim my-service.yaml
[root@k8s home]# kubectl apply -f my-service.yaml
service/my-service created
[root@k8s home]# kubectl get svc
NAME            TYPE        CLUSTER-IP      EXTERNAL-IP   PORT(S)          AGE
kubernetes      ClusterIP   10.43.0.1       <none>        443/TCP          45h
nginx-service   ClusterIP   10.43.65.176    <none>        8080/TCP         6h27m
nginx-outside   NodePort    10.43.127.65    <none>        8081:32109/TCP   5h47m
my-service      NodePort    10.43.154.163   <none>        80:30007/TCP     9m12s
[root@k8s home]# kubectl describe svc my-service
Name:                     my-service
Namespace:                default
Labels:                   <none>
Annotations:              <none>
Selector:                 app=nginx,environment=test
Type:                     NodePort
IP Family Policy:         SingleStack
IP Families:              IPv4
IP:                       10.43.154.163
IPs:                      10.43.154.163
Port:                     <unset>  80/TCP
TargetPort:               80/TCP
NodePort:                 <unset>  30007/TCP
Endpoints:                10.42.1.33:80
Session Affinity:         None
External Traffic Policy:  Cluster
Events:                   <none>
[root@k8s home]# kubectl get pod -l app=nginx -owide
NAME         READY   STATUS    RESTARTS   AGE     IP           NODE   NOMINATED NODE   READINESS GATES
label-demo   1/1     Running   0          2m22s   10.42.1.33   k8s3   <none>           <none>

如果没有对应的pod,

[root@k8s home]# kubectl get svc
NAME            TYPE        CLUSTER-IP      EXTERNAL-IP   PORT(S)          AGE
kubernetes      ClusterIP   10.43.0.1       <none>        443/TCP          45h
nginx-service   ClusterIP   10.43.65.176    <none>        8080/TCP         6h18m
nginx-outside   NodePort    10.43.127.65    <none>        8081:32109/TCP   5h38m
my-service      NodePort    10.43.154.163   <none>        80:30007/TCP     4s
[root@k8s home]# kubectl describe svc my-service
Name:                     my-service
Namespace:                default
Labels:                   <none>
Annotations:              <none>
Selector:                 app=nginx,environment=test
Type:                     NodePort
IP Family Policy:         SingleStack
IP Families:              IPv4
IP:                       10.43.154.163
IPs:                      10.43.154.163
Port:                     <unset>  80/TCP
TargetPort:               80/TCP
NodePort:                 <unset>  30007/TCP
Endpoints:                <none>
Session Affinity:         None
External Traffic Policy:  Cluster
Events:                   <none>
[root@k8s home]# kubectl get pod -l app=nginx -owide
No resources found in default namespace.
相关实践学习
深入解析Docker容器化技术
Docker是一个开源的应用容器引擎,让开发者可以打包他们的应用以及依赖包到一个可移植的容器中,然后发布到任何流行的Linux机器上,也可以实现虚拟化,容器是完全使用沙箱机制,相互之间不会有任何接口。Docker是世界领先的软件容器平台。开发人员利用Docker可以消除协作编码时“在我的机器上可正常工作”的问题。运维人员利用Docker可以在隔离容器中并行运行和管理应用,获得更好的计算密度。企业利用Docker可以构建敏捷的软件交付管道,以更快的速度、更高的安全性和可靠的信誉为Linux和Windows Server应用发布新功能。 在本套课程中,我们将全面的讲解Docker技术栈,从环境安装到容器、镜像操作以及生产环境如何部署开发的微服务应用。本课程由黑马程序员提供。 &nbsp; &nbsp; 相关的阿里云产品:容器服务 ACK 容器服务 Kubernetes 版(简称 ACK)提供高性能可伸缩的容器应用管理能力,支持企业级容器化应用的全生命周期管理。整合阿里云虚拟化、存储、网络和安全能力,打造云端最佳容器化应用运行环境。 了解产品详情: https://www.aliyun.com/product/kubernetes
目录
相关文章
|
10天前
|
网络安全 开发工具 git
在GitLab CI中同步HTTPS仓库地址的yaml配置
最后,提交并推送 `.gitlab-ci.yml`文件到您的GitLab仓库。GitLab CI/CD将自动识别这个文件,并在每次推送到 `master`分支时执行定义的同步任务。
91 16
|
11天前
|
JavaScript Java Maven
【SpringBoot(二)】带你认识Yaml配置文件类型、SpringMVC的资源访问路径 和 静态资源配置的原理!
SpringBoot专栏第二章,从本章开始正式进入SpringBoot的WEB阶段开发,本章先带你认识yaml配置文件和资源的路径配置原理,以方便在后面的文章中打下基础
129 3
|
16天前
|
Kubernetes 安全 网络协议
Kubernetes实用指令:通过dry-run生成部署与服务的YAML配置
总结起来, 使用 ` -- dry—run = client `- o yam l' 参数能够帮助用户预览 Kubernetes 资源定义并且确保它们符合预期效果且没有立即影响现有集群断层结构. 这种做法对于新手学习 K8s 资源规范、测试新策略或者审核现有策略都非常有效率与安全.
181 4
|
1月前
|
Java 测试技术 数据安全/隐私保护
通过yaml文件配置自动化测试程序
通过yaml文件可以将自动化测试环境,测试数据和测试行为分开,请看一下案例
57 4
|
3月前
|
人工智能 缓存 Kubernetes
ACK GIE配置建议
Gateway with Inference Extension是基于Kubernetes社区Gateway API及其扩展规范实现的增强型组件,支持四层/七层路由服务,并面向生成式AI推理场景提供负载均衡优化、服务管理简化等能力,适用于AI推理服务的高可用部署与性能优化。在不同的场景使用ACK Gateway with Inference Extension时,可能需要根据业务需求和高可用需要对网关和推理扩展进行不同的配置调整。本文主要介绍在实际业务场景中针对ACK GIE的配置建议,以获得更好的使用效果。
203 23
|
Java 数据库连接 Maven
springBoot:项目建立&配置修改&yaml的使用&resource 文件夹(二)
本文档介绍了如何创建一个基于Maven的项目,并配置阿里云仓库、数据库连接、端口号、自定义启动横幅及多环境配置等。同时,详细说明了如何使用YAML格式进行配置,以及如何处理静态资源和模板文件。文档还涵盖了Spring Boot项目的`application.properties`和`application.yaml`文件的配置方法,包括设置数据库驱动、URL、用户名、密码等关键信息,以及如何通过配置文件管理不同环境下的应用设置。
918 1
|
7月前
|
Prometheus Kubernetes 监控
Kubernetes监控:Prometheus与AlertManager结合,配置邮件告警。
完成这些步骤之后,您就拥有了一个可以用邮件通知你的Kubernetes监控解决方案了。当然,所有的这些配置都需要相互照应,还要对你的Kubernetes集群状况有深入的了解。希望这份指南能帮助你创建出适合自己场景的监控系统,让你在首次发现问题时就能做出响应。
360 22
|
10月前
|
存储 人工智能 开发框架
Kheish:开源的多智能体开发框架,通过 YAML 配置工作流和多个 Agent 共同协作解决复杂任务
Kheish 是一个开源的多智能体协调平台,基于大型语言模型(LLM)设计,能够通过灵活配置多个智能体来解决复杂任务。平台支持模块化集成、聊天式提示、反馈循环等功能,适用于代码审计、法律文件分析、客户服务自动化等多种应用场景。
295 18
Kheish:开源的多智能体开发框架,通过 YAML 配置工作流和多个 Agent 共同协作解决复杂任务
|
Kubernetes Cloud Native 流计算
Flink-12 Flink Java 3分钟上手 Kubernetes云原生下的Flink集群 Rancher Stateful Set yaml详细 扩容缩容部署 Docker容器编排
Flink-12 Flink Java 3分钟上手 Kubernetes云原生下的Flink集群 Rancher Stateful Set yaml详细 扩容缩容部署 Docker容器编排
315 3
|
11月前
|
Kubernetes 监控 Java
如何在Kubernetes中配置镜像和容器的定期垃圾回收
如何在Kubernetes中配置镜像和容器的定期垃圾回收

热门文章

最新文章

推荐镜像

更多