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工作正常
相关推荐
Zfox_3 小时前
CANN Catlass 算子模板库深度解析:高性能 GEMM 融合计算、Cube Unit Tiling 机制与编程范式实践
docker·云原生·容器·eureka
农民工老王3 小时前
K8s 1.31 私有化部署实战:从 Calico 崩溃到 NFS 挂载失败的排坑全记录
云原生·kubernetes
灰子学技术3 小时前
istio从0到1:如何解决分布式配置同步问题
分布式·云原生·istio
广州中轴线4 小时前
OpenStack on Kubernetes 生产部署实战(十四)
kubernetes·智能路由器·openstack
春日见4 小时前
如何创建一个PR
运维·开发语言·windows·git·docker·容器
DARLING Zero two♡4 小时前
告别 Docker 命令行!Portainer+cpolar 让容器管理从局域网走向公网
运维·docker·容器
小马爱打代码4 小时前
ZooKeeper:入门实战
分布式·zookeeper·云原生
liu****5 小时前
2.深入浅出理解虚拟化与容器化(含Docker实操全解析)
运维·c++·docker·容器·虚拟化技术
logocode_li6 小时前
OCI/CRI 双标准下:从 dockerd 到 containerd 的 K8s 运行时迭代史
docker·云原生·容器·k8s
天才奇男子14 小时前
HAProxy高级功能全解析
linux·运维·服务器·微服务·云原生