ToB企服应用市场:ToB评测及商务社交产业平台

标题: POD 存储、PV、PVC [打印本页]

作者: 何小豆儿在此    时间: 2024-12-23 22:59
标题: POD 存储、PV、PVC
目录
容器怎样持久化存储?
PV和PVC
为什么不能直接在 Pod 或容器中存储数据?
什么是 PV和 PVC?
可以使用本地磁盘空间创建PV吗?
怎样让客户端通过ftp上传到远端服务器的POD里面?
另一个POD想访问ftp的POD里面的文件怎么办?


容器怎样持久化存储?

DockerKubernetes 中,容器的数据存储举动是 基于层(layer)的,并且容器内的数据在容器生命周期内是持久的,直到容器被删除为止。
1. 容器和镜像的关系
容器是基于镜像(Image)创建的。镜像自己是只读的,而容器在启动时会创建一个可写层,容器对文件系统的所有更改都会写入这个可写层。这就意味着:

因此,容器内的文件和更改 不会 被直接丢失,除非容器被 删除。如果容器被制止或重启,但 容器没有被删除,它的可写层中的数据将仍旧保存。
2. 容器重启
如果容器被 重启,它会重新启动容器自己,但不会丢失之前的更改,因为容器的可写层是持久存在的(纵然容器制止或重启,也不会丢失数据,除非容器自己被删除)。

3. 举个例子
假设你启动了一个容器,在容器内创建了一个文件 /tmp/test.txt,然后制止并重启容器:

4. 容器存储与持久化
容器的可写层是 临时的,它绑定到容器的生命周期。如果你希望数据在容器重启或删除后仍旧存在,通常必要使用 持久化存储。在 Kubernetes 中,通常使用 Persistent Volumes (PV)Persistent Volume Claims (PVC) 来解决这个问题。
5. 总结:

持久化存储解决方案
对于必要长期存储数据的应用,保举将数据存储在持久化存储上,而不是直接保存在容器的文件系统中。通过挂载 Persistent Volume (PV)Persistent Volume Claim (PVC),数据将独立于容器的生命周期存在,如许纵然容器删除或重启,数据也能得到持久保存。
//没有k8s,直接把容器目录挂载到主机目录即可持久化存储。
PV和PVC

为什么不能直接在 Pod 或容器中存储数据?

直接在 Pod 或容器内存储数据确实是可能的,但如许做有几个问题,尤其是在容器化环境和 Kubernetes 集群中:

什么是 PV和 PVC?


可以使用本地磁盘空间创建PV吗?

可以使用本地磁盘空间创建 Persistent Volume (PV)。在 Kubernetes 中,你可以使用本地磁盘(例如,物理硬盘、SSD 或本地挂载的存储)来创建一个 PV。这通常通过 hostPathlocal 类型的存储来实现。
但是,使用本地磁盘作为持久存储时,必要考虑一些因素,例如 数据的可靠性Pod 的迁移性。因为如果 Pod 运行在某个节点上,而这个节点出现故障或被删除,存储在该节点上的数据将无法访问。为了确保数据的持久性和可靠性,通常会使用 分布式存储系统网络存储(如 NFS、Ceph、iSCSI 等)。但是,若你只是为了测试、开发或某些特定用途,使用本地磁盘作为 PV 是完全可以的。
1. 通过 hostPath 创建本地磁盘的 PV
hostPath 类型的 PV 允许你直接将本地节点的目录或磁盘挂载到容器中。这适用于在单个节点上使用本地磁盘,但不保举在生产环境中使用,因为它依靠于特定的节点,且不支持跨节点共享。
示例:使用 hostPath 创建 PV
  1. apiVersion: v1
  2. kind: PersistentVolume
  3. metadata:
  4.   name: local-pv
  5. spec:
  6.   capacity:
  7.     storage: 10Gi  # 存储大小
  8.   volumeMode: Filesystem
  9.   accessModes:
  10.     - ReadWriteOnce  # 单节点读写
  11.   persistentVolumeReclaimPolicy: Retain  # 数据不会自动删除
  12.   storageClassName: manual  # 存储类(手动配置)
  13.   hostPath:
  14.     path: /mnt/disks/mydisk  # 本地磁盘的挂载路径
  15.     type: DirectoryOrCreate  # 如果目录不存在则创建
复制代码
解释:

2. 通过 local 类型创建本地磁盘的 PV(保举方法)
在 Kubernetes 1.14 及以上版本,官方引入了 local 类型的 PV,它更好地支持本地存储设备,并且可以在集群节点上通过 local 存储提供持久存储。这种方式相较于 hostPath 更得当生产环境中的本地存储。
示例:使用 local 类型创建 PV
  1. apiVersion: v1
  2. kind: PersistentVolume
  3. metadata:
  4.   name: local-pv
  5. spec:
  6.   capacity:
  7.     storage: 10Gi  # 存储大小
  8.   volumeMode: Filesystem
  9.   accessModes:
  10.     - ReadWriteOnce  # 单节点读写
  11.   persistentVolumeReclaimPolicy: Retain  # 数据不会自动删除
  12.   storageClassName: manual  # 存储类(手动配置)
  13.   local:
  14.     path: /mnt/disks/mydisk  # 本地磁盘的挂载路径
  15.     fsType: ext4  # 文件系统类型
复制代码
解释:

3. 创建 PVC(Persistent Volume Claim)来请求本地存储
一旦 PV 创建完毕,你可以创建一个 PVC(Persistent Volume Claim)来请求这个本地存储。PVC 是应用步伐对存储资源的请求,Kubernetes 会根据 PVC 的要求选择合适的 PV。
示例:创建 PVC 来使用本地 PV
  1. apiVersion: v1
  2. kind: PersistentVolumeClaim
  3. metadata:
  4.   name: local-pvc
  5. spec:
  6.   accessModes:
  7.     - ReadWriteOnce  # 单节点读写
  8.   resources:
  9.     requests:
  10.       storage: 10Gi  # 请求的存储大小
  11.   storageClassName: manual  # 与 PV 的 storageClassName 配置一致
复制代码
解释:

4. 将 PVC 挂载到 Pod 中
创建 PVC 后,你可以将其挂载到 Pod 中,使用本地存储。
示例:在 Pod 中挂载 PVC
  1. apiVersion: v1
  2. kind: Pod
  3. metadata:
  4.   name: local-pod
  5. spec:
  6.   containers:
  7.   - name: my-container
  8.     image: nginx
  9.     volumeMounts:
  10.     - mountPath: /data  # 容器中的挂载路径
  11.       name: local-storage
  12.   volumes:
  13.   - name: local-storage
  14.     persistentVolumeClaim:
  15.       claimName: local-pvc  # 引用 PVC
复制代码
解释:

使用 本地磁盘(如 hostPath 或 local 类型)创建的PV节点特定的,这意味着它只能由存储它的节点上的 Pod 访问。简而言之,其他节点上的 Pod 无法访问该 PV,除非它们也在同一节点上运行。
怎样让客户端通过ftp上传到远端服务器的POD里面?

目的是让客户端通过FTP上传文件到一个Kubernetes Pod内,而不是直接上传到服务器上。这是可以做到的,但必要通过一些间接的方式来配置和管理。Kubernetes自己并不提供FTP服务。
以下是实现这个需求的几种方法:
1. 使用FTP服务器作为Pod的容器
你可以在Kubernetes集群中部署一个包含FTP服务的Pod。客户端通过FTP上传文件到该Pod后,文件可以直接存储在Pod的文件系统中。如许,你就实现了客户端通过FTP上传文件到Pod内的需求。
步骤:

示例:

        最常见且保举的方法是使用 Kubernetes 中的 Persistent Volume (PV)Persistent Volume Claim (PVC)。通过将一个 PVC 挂载到 FTP Pod 上的目录并共享该 PVC,另一个 Pod 可以访问同一个存储资源。如许,无论哪个 Pod 上传文件,其他 Pod 都能读取。
步骤:
示例配置:
Persistent Volume(PV) 配置:
  1. apiVersion: v1
  2. kind: PersistentVolume
  3. metadata:
  4.   name: shared-pv
  5. spec:
  6.   capacity:
  7.     storage: 10Gi
  8.   accessModes:
  9.     - ReadWriteMany  # 多个Pod可以读写
  10.   persistentVolumeReclaimPolicy: Retain
  11.   storageClassName: standard
  12.   nfs:
  13.     path: /mnt/data  # NFS共享路径
  14.     server: <nfs-server-ip>  # NFS服务器地址
复制代码
Persistent Volume Claim(PVC) 配置:
  1. apiVersion: v1
  2. kind: PersistentVolumeClaim
  3. metadata:
  4.   name: shared-pvc
  5. spec:
  6.   accessModes:
  7.     - ReadWriteMany
  8.   resources:
  9.     requests:
  10.       storage: 10Gi
复制代码
FTP Pod 配置: 将 PVC 挂载到 FTP Pod 中:
  1. apiVersion: apps/v1
  2. kind: Deployment
  3. metadata:
  4.   name: ftp-server
  5. spec:
  6.   replicas: 1
  7.   selector:
  8.     matchLabels:
  9.       app: ftp-server
  10.   template:
  11.     metadata:
  12.       labels:
  13.         app: ftp-server
  14.     spec:
  15.       containers:
  16.       - name: vsftpd
  17.         image: your-ftp-image:latest
  18.         ports:
  19.           - containerPort: 21
  20.         volumeMounts:
  21.           - mountPath: /srv/ftp  # FTP服务存储目录
  22.             name: ftp-data
  23.       volumes:
  24.       - name: ftp-data
  25.         persistentVolumeClaim:
  26.           claimName: shared-pvc  # 挂载同一个PVC
复制代码
远端 Pod 配置: 另一个 Pod 可以挂载同一个 PVC,读取上传的文件
  1. apiVersion: apps/v1
  2. kind: Deployment
  3. metadata:
  4.   name: data-processor
  5. spec:
  6.   replicas: 1
  7.   selector:
  8.     matchLabels:
  9.       app: data-processor
  10.   template:
  11.     metadata:
  12.       labels:
  13.         app: data-processor
  14.     spec:
  15.       containers:
  16.       - name: processor
  17.         image: your-data-processor-image:latest
  18.         volumeMounts:
  19.           - mountPath: /data/uploads  # 数据存储目录
  20.             name: shared-data
  21.       volumes:
  22.       - name: shared-data
  23.         persistentVolumeClaim:
  24.           claimName: shared-pvc  # 同样挂载同一个PVC
复制代码
如许,FTP Pod 会将文件存储到 /srv/ftp,而 远端 Pod 可以访问 /data/uploads 目录,读取 FTP 上传的文件。

免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。




欢迎光临 ToB企服应用市场:ToB评测及商务社交产业平台 (https://dis.qidao123.com/) Powered by Discuz! X3.4