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工作正常
相关推荐
阿里云云原生1 天前
阿里云获评 Agentic AI 开发平台领导者,函数计算 AgentRun 赢下关键分!
云原生
蝎子莱莱爱打怪1 天前
Centos7中一键安装K8s集群以及Rancher安装记录
运维·后端·kubernetes
崔小汤呀2 天前
Docker部署Nacos
docker·容器
缓解AI焦虑2 天前
Docker + K8s 部署大模型推理服务:资源划分与多实例调度
docker·容器
阿里云云原生2 天前
MSE Nacos Prompt 管理:让 AI Agent 的核心配置真正可治理
微服务·云原生
阿里云云原生2 天前
当 AI Agent 接管手机:移动端如何进行观测
云原生·agent
阿里云云原生2 天前
AI 原生应用开源开发者沙龙·深圳站精彩回顾 & PPT下载
云原生
阿里云云原生2 天前
灵感启发:日产文章 100 篇,打造“实时热点洞察”引擎
云原生
1candobetter2 天前
Docker Compose Build 与 Up 的区别:什么时候必须重建镜像
docker·容器·eureka
~莫子2 天前
Haproxy七层负载详解+实验详细代码
云原生