121. kubernetes中使用NFS创建pv_pvc

 kubernetes中使用NFS创建pv_pvc

 

 

Persistent Volume(持久化卷)简称PV, 是一个K8S资源对象,我们可以单独创建一个PV, 它不和Pod直接发生关系, 而是通过Persistent Volume Claim, 简称PVC来实现动态绑定, 我们会在Pod定义里指定创建好的PVC, 然后PVC会根据Pod的要求去自动绑定合适的PV给Pod使用。

#就是我们在pod定义的时候可以指定一个PVC。然后PVC再去和PV进行绑定(这个过程是自动的,不需要去设置上面)。

类似于linux我们不能直接使用一个磁盘,要格式化成你想要的格式,比如xfs、ext4。只有把磁盘格式化成你系统能识别的文件系统,你才能在里面写数据。那pv也是一样的,pod直接识别不了,需要借助PVC,才能使用它

持久化卷下PV和PVC概念:

Persistent Volume(PV)是由管理员设置的存储,它是群集的一部分(可理解为是物理层面的)。就像节点是集群中的资源一样,PV 也是集群中的资源。 PV 是 Volume 之类的卷插件,但具有独立于使用 PV 的 Pod 的生命周期(pv和pod之间没有直接的关系)。此 API 对象包含存储实现的细节,即 NFS、iSCSI 或特定于云供应商的存储系统。

PersistentVolumeClaim(PVC)是用户存储的请求。它与 Pod 相似,Pod 消耗节点资源,PVC 消耗 PV 资源。Pod 可以请求特定级别的资源(CPU 和内存)。PVC声明可以请求特定的大小和访问模式(例如,可以以读/写一次或只读多次模式挂载)。 #特定大小是请求磁盘存储的大小是多大,还有权限是可读还是可写或是只读

它和普通Volume的区别是什么呢?

普通Volume和使用它的Pod之间是一种静态绑定关系,在定义Pod的文件里,同时定义了它使用的Volume。Volume是Pod的附属品,我们无法单独创建一个Volume,因为它不是一个独立的K8S资源对象。 #我们在pod里面去定义一个 Volume,那么pod没了,Volnme也就没有了。而pv是独立存在的,pod没有了,跟pv没有关系

1 准备一台机器,搭建NFS服务

yum install nfs-utils

vim /etc/exportfs

/data/k8s/ 172.7.15.0/24(sync,rw,no_root_squash) #这里的ip要写node节点网段的ip端,是要分享整个集群的

mkdir /data/k8s #创建该目录

chmod 777 !$ #为方便测试,可加777的权限

systemctl start nfs

systemctl start rpcbind

systemctl enable nfs

systemctl enbale rpcbind

2 在node节点上测试

yum install nfs-utils

showmount -e 172.7.15.113

3 创建pv(master上)

vim mypv.yaml //内容如下

apiVersion: v1

kind: PersistentVolume

metadata:

name: pv001

spec:

capacity:

storage: 10Gi #给他10G的空间

accessModes:

- ReadWriteMany #就是可读可写很多次

nfs:

path: /data/k8s/ #挂载的目录

server: 172.7.15.113 #nfs服务端的ip

·························mypv.yaml文件到此为止································

kubectl create -f mypv.yaml #创建pv

kubectl get pv #查看pv

NAME CAPACITY ACCESS MODES RECLAIM POLICY STATUS CLAIM STORAGECLASS REASON AGE

pv001 10Gi RWX Retain Available 10m

状态为Available,这是因为它还没有绑定到任何的pvc上面,当定义完pvc后,就可以自动绑定了。

4 创建pvc(master上) #让pod去引用他

vim mypvc.yaml //内容如下 #这个pvc文件可以自动的去关联上面创建的pv

kind: PersistentVolumeClaim #注意大小写

apiVersion: v1

metadata:

name: myclaim

spec:

accessModes:

- ReadWriteMany

resources:

requests:

storage: 8Gi

·························mypvc.yaml文件到此为止································

kubectl create -f mypvc.yaml

kubectl get pvc

NAME STATUS VOLUME CAPACITY ACCESS MODES STORAGECLASS AGE

myclaim Bound pv001 10Gi RWX 2m

可以看到,pvc状态为Bound,它绑定了pv001 #这个pv001就是上面我们创建的pv

5 定义pod #定义一个pod去使用pvc

vim pvpod.yaml //内容如下

apiVersion: v1

kind: Pod

metadata:

name: httpd-pvpod #注意名字不能和其他的pod有重复

spec:

containers:

- image: httpd

name: httpd-withpvc-pod

imagePullPolicy: Always

volumeMounts:

- mountPath: "/usr/local/apache2/htdocs/" #指定挂载到哪个目录去

name: httpd-volume

volumes:

- name: httpd-volume

persistentVolumeClaim:

claimName: myclaim #指定你pvc的名字

·························pvpod.yaml文件到此为止································

kubectl create -f pvpod.yaml

kubectl describe pod httpd-pvpod //查看Volumes那部分里的ClaimName

6 验证

1)到NFS的共享目录下创建一个文件

cd /data/k8s/

echo "Test file" > 1.html

2)进入到httpd-pod里

kubectl exec -it httpd-pvpod bash

cat /usr/local/apache2/htdocs/1.html #查看指定的目录下有无挂载的这个文件

3)删除httpd-pvpod

kubectl delete pod httpd-pod #删除这个pod,在master上查看是否有这个。以此证明pvc不受pod的删除而受影响

cat /data/k8s/1.html

4)重建httpd-pod

kubectl create -f pvpod.yaml #再次重建这个pod。然后再访问他,看他是否随着pod的重建而依然持久化这个文件

5)curl访问

kubectl get pod httpd-pvpod -o wide //查看其对应的IP #就是查看这个pod在哪个节点上

NAME READY STATUS RESTARTS AGE IP NODE NOMINATED NODE

httpd-pod 1/1 Running 0 2m 172.20.3.5 172.7.15.114 <none>

curl 172.20.3.5/1.html #访问的时候要访问这个pod的唯一ip,而不是访问节点的ip。通过kubectl get pod httpd-pvpod -o wide这个命令来查看pod的ip

参考 http://www.showerlee.com/archives/2280

 

总结:

首先要搭建一个nfs,共享目录给这个集群里所有的节点,包括master

然后再node节点上测试nfs服务(showmount -e)

再创建pv

再创建pvc,pvc可以自动的去绑定pv

定义pod,指定pvc的名字。实验中的名字时myclin, claimName: myclaim

最后测试

 

 

 

 

 

 

 

 

 

 

 

 

转载于:https://my.oschina.net/u/3866149/blog/3056436

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值