Kubernetes使用yaml创建pod

生成yaml文件创建pod

  • 使用yaml文件可以指定各种属性,生成yaml文件的命令如下:
kubectl run 名字 --image=镜像 --dry-run=client -o yaml > pod.yaml
如:
kubectl run pod1 --image=nginx --dry-run=client -o yaml > pod1.yaml

--dry-run=client:模拟创建pod,但不会真的创建
-o yaml > pod.yaml:以yaml文件的格式输出,然后把结果重定向到pod.yaml
在这里插入图片描述

  • yaml文件中的常见参数
    • yaml文件的写法是分级写的,子级和父级之间要缩进两个空格,子级第一个位置可以以“-”开头,这个“-”与父级对齐。
    • 第一级参数
      • apiVersion:指定pod的apiVersion,是固定的值v1。
      • kind:指定当前yaml要创建的类型是pod,与apiVersion是对应的。
      • metadata:用于指定pod的元数据信息,包括pod名、pod标签和所在命名空间等信息
      • spec:定义容器和各种策略。
    • metadata的二级参数
      • name:定义pod的名字。
      • namespace:定义pod所在的命名空间。
      • labels:定义pod的标签,格式为 key:value。
    • spec的二级参数
      • containers:定义容器。
      • restartPolicy:定义pod的重启策略。
      • dnsPolicy:定义DNS策略。
    • spec.containers的三级参数,第一个参数以“-”开头
      • images:定义容器所使用的镜像。
      • imagePullPolicy:定义镜像的下载策略。
      • name:容器的名字。
      • command:指定容器里运行的进程,不写则为镜像里默认的进程。
      • ports:指定容器所使用的端口。
      • env:定义变量。
      • resources:定义资源限制。
    • spec.containers.ports的参数,第一个参数以“-”开头
      • name:端口的名字。
      • containerPort:容器所使用的端口,仅用作标记,应根据镜像所使用的端口指定。
      • protocol:设置端口协议,是TCP还是UDP。
    • spec.containers.env的参数,第一个参数以“-”开头
      • name:变量名。
      • value:变量值,如果是数字的话,需要用引号引起来。
    • 查看pod的参数,可以使用如下命令
# 查看pod的一级参数,可以使用如下命令
kubectl explain pods
# 查看参数下有几个参数
kubectl explain pods.spec
  • 修改yaml文件
vi pod1.yaml

apiVersion: v1
kind: Pod
metadata:
  creationTimestamp: null
  labels:
    run: pod1
  name: pod1
spec:
  containers:
  - command: ["sh","-c","echo aa;sleep 1000"]
    image: nginx
    imagePullPolicy: IfNotPresent
    name: c1
    resources: {}
  - image: nginx
    imagePullPolicy: IfNotPresent
    name: c2
  dnsPolicy: ClusterFirst
  restartPolicy: Always
status: {}
  • 创建pod,并查看
kubectl apply -f pod1.yaml
kubectl get pod
kubectl get pod -l run=pod1
kubectl logs pod1 -c c1
kubectl logs pod1 -c c2

在这里插入图片描述

  • 查看pod属性,进入pod并获取bash
kubectl describe pod pod1
kubectl exec -it pod1 -c c2 -- bash

在这里插入图片描述
在这里插入图片描述

  • 删除pod
kubectl delete -f pod1.yaml

在这里插入图片描述

### 创建 Kubernetes PodYAML 文件示例 以下是通过 YAML 文件创建 Kubernetes Pod 的具体方法以及相关说明: #### 使用 YAML 定义 Pod PodKubernetes 中最小的部署单元。可以通过定义一个 YAML 文件来描述 Pod 的结构和行为。 下面是一个完整的 YAML 文件示例,用于创建一个简单的 Pod[^3]: ```yaml apiVersion: v1 kind: Pod metadata: name: nginx-pod labels: app: nginx spec: containers: - name: nginx-container image: nginx:latest ports: - containerPort: 80 ``` 上述 YAML 文件中包含了以下几个部分: - `apiVersion`: 表明 API 版本,在此例子中为 `v1`。 - `kind`: 指定资源类型,这里是 `Pod`。 - `metadata`: 描述元数据,包括名称 (`name`) 和标签 (`labels`)。 - `spec.containers`: 列出了容器的相关信息,例如镜像名 (`image`) 和端口映射 (`ports`)。 如果需要挂载 Secret 或其他类型的 Volume,则可以扩展该 YAML 文件如下所示: ```yaml apiVersion: v1 kind: Pod metadata: name: secret-test labels: name: secret-test spec: volumes: - name: volumes12 secret: secretName: mysecret containers: - image: nginx:latest name: db volumeMounts: - name: volumes12 mountPath: "/data" ``` 在此配置中,Secret 被挂载到了 `/data` 路径下作为卷的一部分。 #### 处理 Pod 生命周期 当 Pod 中的某个容器意外终止时,Kubernetes 将依据其 RestartPolicy 自动尝试恢复服务正常运行状态。对于单个 Pod 来说,默认情况下会采用 Always 策略,即无论发生什么情况都会重新启动失败的容器实例[^2]。 要实际应用这些设置并提交给集群执行命令如下: ```bash kubectl apply -f pod-definition.yaml ``` 这将读取名为 `pod-definition.yaml` 的本地文件并将其中的内容发送至服务器以供解析处理。 #### 注意事项 确保所使用YAML 文件语法正确无误,并且所有的字段都按照官方文档中的标准填写;否则可能导致无法成功创建目标对象或者引发不可预期的行为表现。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值