k8s创建测试Pod的流程

创建普通测试Pod

主要用于验证应用本身的功能或测试无状态服务,其生命周期短暂,不关心数据存储。

其基本流程是:编写Pod定义文件 -> 部署Pod -> 验证功能 -> 清理资源

编写Pod定义文件:

复制代码
# test-pod.yaml
apiVersion: v1
kind: Pod
metadata:
  name: simple-test-pod
spec:
  containers:
  - name: nginx
    image: nginx:latest
    ports:
    - containerPort: 80

创建Pod

kubectl apply -f test-pod.yaml

验证状态

kubectl get pods -o wide

测试访问(可能需端口转发)

kubectl port-forward simple-test-pod 8080:80

清理

kubectl delete -f test-pod.yaml

使用PVC进行测试的流程

使用PVC测试侧重于验证存储的持久化能力。整个过程涉及PV(提供存储资源)和PVC(申请存储资源)的交互。

其基本流程是:准备存储后端 -> 定义PV/PVC -> 在Pod中挂载PVC -> 验证数据持久性。以下是关键步骤:

  1. 准备存储 :确保有一个可用的存储后端。在您的环境里,Longhorn 已经创建了一个名为longhornStorageClass,它会动态地为您准备PV,无需手动创建。

  2. 定义并申请存储(PVC):您只需要创建一个PVC,指定需要多大的空间和访问模式。Longhorn会自动满足这个申请。

    test-pvc.yaml

    apiVersion: v1
    kind: PersistentVolumeClaim
    metadata:
    name: my-test-pvc
    spec:
    storageClassName: longhorn # 指定使用Longhorn提供的存储
    accessModes:
    - ReadWriteOnce # 常见的访问模式,表示可被单个节点以读写方式挂载
    resources:
    requests:
    storage: 1Gi # 申请1GB的存储空间

创建PVC

kubectl apply -f test-pvc.yaml

查看PVC状态,应为Bound,表示已成功绑定由Longhorn自动创建的PV

kubectl get pvc my-test-pvc

3.在Pod中使用PVC:在Pod的定义中声明使用这个PVC。

复制代码
# pod-with-pvc.yaml
apiVersion: v1
kind: Pod
metadata:
  name: pod-using-pvc
spec:
  containers:
  - name: app
    image: nginx:latest
    volumeMounts:
    - mountPath: "/data"  # 容器内的挂载路径
      name: storage-volume
  volumes:
  - name: storage-volume
    persistentVolumeClaim:
      claimName: my-test-pvc  # 引用上面创建的PVC

创建Pod

kubectl apply -f pod-with-pvc.yaml

4.验证数据持久性:这是测试的核心。

复制代码
# 进入Pod,写入测试数据
kubectl exec -it pod-using-pvc -- sh -c "echo 'Hello, Persistent World!' > /data/testfile.txt"
# 删除这个Pod
kubectl delete pod pod-using-pvc
# 用同样的yaml文件重新创建Pod(它会使用同一个PVC)
kubectl apply -f pod-with-pvc.yaml
# 检查之前写入的文件是否还在
kubectl exec -it pod-using-pvc -- cat /data/testfile.txt
# 如果成功输出 "Hello, Persistent World!",则证明PVC工作正常
相关推荐
危笑ioi28 分钟前
基于Kubeconfig实现K8s节点免密登录
云原生·容器·kubernetes
木二_37 分钟前
058.Kubernetes cert-manager 申请证书及ingress注解介绍
云原生·容器·kubernetes·cert-manager·证书管理
kabu_Charlie1 小时前
使用Docker运行python程序
运维·docker·容器
骥龙1 小时前
第五篇:运行时安全——Docker沙箱与命令审批机制
安全·docker·容器
会算数的⑨2 小时前
演进——从查日志到 AI 自治,企业监控体系的变迁
人工智能·分布式·后端·微服务·云原生
南山十一少3 小时前
docker的安装及使用
运维·docker·容器
道清茗4 小时前
【Kubernetes知识点问答题】PriorityClass、HPA、Argo CD 与 CI/CD 流水线
ci/cd·容器·kubernetes
yuezhilangniao4 小时前
大白话AI运维K8S整体思路和相关名词-结合腾讯云
运维·人工智能·kubernetes
DJ斯特拉4 小时前
Docker基本使用
运维·docker·容器
苦涩花开54864 小时前
Kubernetes学习,记一些笔记
笔记·学习·kubernetes